From: Donnie Berkholz Date: Tue, 20 Jun 2006 20:00:51 +0000 (+0000) Subject: Security bump. Failure to check the return value of setuid() in a privileged process... X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=69a2c0465da33d707426cfba2dd1c205a4a79c7c;p=gentoo.git Security bump. Failure to check the return value of setuid() in a privileged process could be used by a local user for file overwriting and possible privilege escalation in corner cases. See lists.freedesktop.org/archives/xorg/2006-June/016146.html for more information. Package-Manager: portage-2.1.1_pre1-r1 --- diff --git a/x11-base/xorg-x11/ChangeLog b/x11-base/xorg-x11/ChangeLog index a64ace0f84fa..216b1e96da0a 100644 --- a/x11-base/xorg-x11/ChangeLog +++ b/x11-base/xorg-x11/ChangeLog @@ -1,6 +1,19 @@ # ChangeLog for x11-base/xorg-x11 # Copyright 1999-2006 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/x11-base/xorg-x11/ChangeLog,v 1.543 2006/05/28 16:46:31 joshuabaergen Exp $ +# $Header: /var/cvsroot/gentoo-x86/x11-base/xorg-x11/ChangeLog,v 1.544 2006/06/20 20:00:51 spyderous Exp $ + +*xorg-x11-6.9.0-r2 (20 Jun 2006) +*xorg-x11-6.8.2-r8 (20 Jun 2006) + + 20 Jun 2006; Donnie Berkholz ; + +files/xorg-68x-setuid.patch, +files/x11r6.9.0-setuid.diff, + +xorg-x11-6.8.2-r8.ebuild, -xorg-x11-6.9.0-r1.ebuild, + +xorg-x11-6.9.0-r2.ebuild: + Security bump. Failure to check the return value of setuid() in a privileged + process could be used by a local user for file overwriting and possible + privilege escalation in corner cases. See + http://lists.freedesktop.org/archives/xorg/2006-June/016146.html for more + information. *xorg-x11-7.1 (28 May 2006) diff --git a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.2-r8 b/x11-base/xorg-x11/files/digest-xorg-x11-6.8.2-r8 new file mode 100644 index 000000000000..3eea5ce674a7 --- /dev/null +++ b/x11-base/xorg-x11/files/digest-xorg-x11-6.8.2-r8 @@ -0,0 +1,21 @@ +MD5 8131cd7ea1e4566e6e05c438a93fcfe1 X11R6.8.2-src.tar.bz2 44371402 +RMD160 80efdaf74a25e43c77aab1d83e817f03f344d105 X11R6.8.2-src.tar.bz2 44371402 +SHA256 f02e3c85572dc9ad7cb77c2a638e3be24cc1b5bea9fdbb0b0299c9668475c534 X11R6.8.2-src.tar.bz2 44371402 +MD5 4d7d5fdc4ed56c144ef998302581478c eurofonts-X11.tar.bz2 8811 +RMD160 d3f54324dcfd961dc128a257917a90a5bc9560da eurofonts-X11.tar.bz2 8811 +SHA256 6028bda00ecf403f1723ca66d24ed3f609bf6d7eaef46e0facb04fb322aac3e3 eurofonts-X11.tar.bz2 8811 +MD5 3d4ee581df78c9dacc6e97aa07a1af72 gemini-koi8-u.tar.bz2 439173 +RMD160 861e7048f0ec5136c898976b092b96da8772d70c gemini-koi8-u.tar.bz2 439173 +SHA256 df70d795be2cfbac04647365495e70c84b3a2119db2297a9deca7f939c135811 gemini-koi8-u.tar.bz2 439173 +MD5 d0fab996daf97adf095e2dad0bd9012e gentoo-cursors-tad-0.3.1.tar.bz2 1196991 +RMD160 cd10e8ffbfd8879e096ba5d31fd16d613c780660 gentoo-cursors-tad-0.3.1.tar.bz2 1196991 +SHA256 90c6775fcd194153b79e06e4232c74054ebf11227a83c5762e6aa539d46ef847 gentoo-cursors-tad-0.3.1.tar.bz2 1196991 +MD5 01a21c248e5ac4ba02cbbea994fc774a xfsft-encodings-0.1.tar.bz2 11892 +RMD160 d51d2110764484dd49cba393510f2f143a7eb0a2 xfsft-encodings-0.1.tar.bz2 11892 +SHA256 a13acec68d913f42cf49c97113da86a90d15867f799fcaa7e9892759c6b37645 xfsft-encodings-0.1.tar.bz2 11892 +MD5 3558cdcca5bdd1d17d468408c794aea6 xorg-x11-6.8.2-files-0.8.tar.bz2 9920 +RMD160 cacc6ebb392dce9b1274b13c3a87ac62f42e2828 xorg-x11-6.8.2-files-0.8.tar.bz2 9920 +SHA256 51b8f9af14a25ba90e61f61f8a8531b8075a59ac41d4f7d0a1812bcaf9623f02 xorg-x11-6.8.2-files-0.8.tar.bz2 9920 +MD5 3f9b8411dc49d38d03d75928e2b42e78 xorg-x11-6.8.2-patches-0.1.13.tar.bz2 191763 +RMD160 d0d363afcf26f78005e380a49ff7c7be4301f6cd xorg-x11-6.8.2-patches-0.1.13.tar.bz2 191763 +SHA256 aebc58cd8e85a50c39f33ca9a1dbb300e972ca8fa50bd1527c71d52864dcc09f xorg-x11-6.8.2-patches-0.1.13.tar.bz2 191763 diff --git a/x11-base/xorg-x11/files/digest-xorg-x11-6.9.0-r2 b/x11-base/xorg-x11/files/digest-xorg-x11-6.9.0-r2 new file mode 100644 index 000000000000..c861623df332 --- /dev/null +++ b/x11-base/xorg-x11/files/digest-xorg-x11-6.9.0-r2 @@ -0,0 +1,21 @@ +MD5 52ad69832db5c36c7041f90625ed4598 X11R6.9.0-src.tar.bz2 46220125 +RMD160 5c830d43607c4550ad44936d77b5adc56f67dbf5 X11R6.9.0-src.tar.bz2 46220125 +SHA256 6509e5bee489ab7c8d0c255c12f6ceb8f06be74b57b060b6e9a61497710a3f4c X11R6.9.0-src.tar.bz2 46220125 +MD5 4d7d5fdc4ed56c144ef998302581478c eurofonts-X11.tar.bz2 8811 +RMD160 d3f54324dcfd961dc128a257917a90a5bc9560da eurofonts-X11.tar.bz2 8811 +SHA256 6028bda00ecf403f1723ca66d24ed3f609bf6d7eaef46e0facb04fb322aac3e3 eurofonts-X11.tar.bz2 8811 +MD5 3d4ee581df78c9dacc6e97aa07a1af72 gemini-koi8-u.tar.bz2 439173 +RMD160 861e7048f0ec5136c898976b092b96da8772d70c gemini-koi8-u.tar.bz2 439173 +SHA256 df70d795be2cfbac04647365495e70c84b3a2119db2297a9deca7f939c135811 gemini-koi8-u.tar.bz2 439173 +MD5 d0fab996daf97adf095e2dad0bd9012e gentoo-cursors-tad-0.3.1.tar.bz2 1196991 +RMD160 cd10e8ffbfd8879e096ba5d31fd16d613c780660 gentoo-cursors-tad-0.3.1.tar.bz2 1196991 +SHA256 90c6775fcd194153b79e06e4232c74054ebf11227a83c5762e6aa539d46ef847 gentoo-cursors-tad-0.3.1.tar.bz2 1196991 +MD5 01a21c248e5ac4ba02cbbea994fc774a xfsft-encodings-0.1.tar.bz2 11892 +RMD160 d51d2110764484dd49cba393510f2f143a7eb0a2 xfsft-encodings-0.1.tar.bz2 11892 +SHA256 a13acec68d913f42cf49c97113da86a90d15867f799fcaa7e9892759c6b37645 xfsft-encodings-0.1.tar.bz2 11892 +MD5 087850f509a70708466d0f2d91a02f01 xorg-x11-6.9.0-files-0.1.tar.bz2 9930 +RMD160 0bf43b280db86b28f4ee93b1c47959f4372d71fc xorg-x11-6.9.0-files-0.1.tar.bz2 9930 +SHA256 207f366cd69ae1b828206f227bd600d5ec9e9dfddb0cab8e418f222f4b787755 xorg-x11-6.9.0-files-0.1.tar.bz2 9930 +MD5 e3e382e5f2fb849224550963fa4bd0ee xorg-x11-6.9.0-patches-0.1.1.tar.bz2 114332 +RMD160 ff9b0f2cd969ccfb1078c5b6f3b2d4a7e5085b10 xorg-x11-6.9.0-patches-0.1.1.tar.bz2 114332 +SHA256 fb6a652fcbf6c8416b675766960850ed104fbd44b71440dcd335f0d3a2f069d3 xorg-x11-6.9.0-patches-0.1.1.tar.bz2 114332 diff --git a/x11-base/xorg-x11/files/x11r6.9.0-setuid.diff b/x11-base/xorg-x11/files/x11r6.9.0-setuid.diff new file mode 100644 index 000000000000..eede645c394b --- /dev/null +++ b/x11-base/xorg-x11/files/x11r6.9.0-setuid.diff @@ -0,0 +1,411 @@ +Index: xc/config/util/chownxterm.c +=================================================================== +RCS file: /cvs/xorg/xc/config/util/chownxterm.c,v +retrieving revision 1.1.1.1 +diff -u -r1.1.1.1 chownxterm.c +--- xc/config/util/chownxterm.c 14 Nov 2003 16:48:20 -0000 1.1.1.1 ++++ xc/config/util/chownxterm.c 5 Jun 2006 10:35:10 -0000 +@@ -41,8 +41,10 @@ + + void help() + { +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ exit(1); ++ if (setuid(getuid()) == -1) ++ exit(1); + printf("chown-xterm makes %s suid root\n", XTERM_PATH); + printf("This is necessary on Ultrix for /dev/tty operation.\n"); + exit(0); +@@ -51,8 +53,10 @@ + void print_error(err_string) + char *err_string; + { +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ exit(1); ++ if (setuid(getuid()) == -1) ++ exit(1); + fprintf(stderr, "%s: \"%s\"", prog_name, err_string); + perror(" failed"); + exit(1); +Index: xc/lib/X11/lcFile.c +=================================================================== +RCS file: /cvs/xorg/xc/lib/X11/lcFile.c,v +retrieving revision 1.6 +diff -u -r1.6 lcFile.c +--- xc/lib/X11/lcFile.c 13 May 2005 22:53:44 -0000 1.6 ++++ xc/lib/X11/lcFile.c 5 Jun 2006 10:35:14 -0000 +@@ -269,7 +269,11 @@ + if (seteuid(0) != 0) { + priv = 0; + } else { +- seteuid(oldeuid); ++ if (seteuid(oldeuid) == -1) { ++ /* XXX ouch, coudn't get back to original uid ++ what can we do ??? */ ++ _exit(127); ++ } + priv = 1; + } + #endif +Index: xc/lib/xtrans/Xtranslcl.c +=================================================================== +RCS file: /cvs/xorg/xc/lib/xtrans/Xtranslcl.c,v +retrieving revision 1.4 +diff -u -r1.4 Xtranslcl.c +--- xc/lib/xtrans/Xtranslcl.c 8 Nov 2005 06:33:26 -0000 1.4 ++++ xc/lib/xtrans/Xtranslcl.c 5 Jun 2006 10:35:15 -0000 +@@ -360,7 +360,10 @@ + uid_t saved_euid; + + saved_euid = geteuid(); +- setuid( getuid() ); /** sets the euid to the actual/real uid **/ ++ /** sets the euid to the actual/real uid **/ ++ if (setuid( getuid() ) == -1) { ++ exit(1); ++ } + if( chown( slave, saved_euid, -1 ) < 0 ) { + exit( 1 ); + } +@@ -369,7 +372,13 @@ + } + + waitpid(saved_pid, &exitval, 0); +- ++ if (WIFEXITED(exitval) && WEXITSTATUS(exitval) != 0) { ++ close(fd); ++ close(server); ++ PRMSG(1, "PTSOpenClient: cannot set the owner of %s\n", ++ slave, 0, 0); ++ return(-1); ++ } + if (chmod(slave, 0666) < 0) { + close(fd); + close(server); +Index: xc/programs/Xserver/hw/xfree86/common/xf86Init.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/hw/xfree86/common/xf86Init.c,v +retrieving revision 1.29 +diff -u -r1.29 xf86Init.c +--- xc/programs/Xserver/hw/xfree86/common/xf86Init.c 14 Dec 2005 20:12:00 -0000 1.29 ++++ xc/programs/Xserver/hw/xfree86/common/xf86Init.c 5 Jun 2006 10:35:19 -0000 +@@ -1905,7 +1905,11 @@ + FatalError("xf86RunVtInit: fork failed (%s)\n", strerror(errno)); + break; + case 0: /* child */ +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ xf86Msg(X_ERROR, "xf86RunVtInit: setuid failed (%s)\n", ++ strerror(errno)); ++ exit(255); ++ } + /* set stdin, stdout to the consoleFd */ + for (i = 0; i < 2; i++) { + if (xf86Info.consoleFd != i) { +Index: xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c,v +retrieving revision 1.9 +diff -u -r1.9 libc_wrapper.c +--- xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c 3 Jul 2005 08:53:48 -0000 1.9 ++++ xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c 5 Jun 2006 10:35:19 -0000 +@@ -1270,7 +1270,10 @@ + #ifndef SELF_CONTAINED_WRAPPER + xf86DisableIO(); + #endif +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ ErrorF("xf86Execl: setuid() failed: %s\n", strerror(errno)); ++ exit(255); ++ } + #if !defined(SELF_CONTAINED_WRAPPER) + /* set stdin, stdout to the consoleFD, and leave stderr alone */ + for (i = 0; i < 2; i++) +Index: xc/programs/Xserver/hw/xfree86/parser/write.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/hw/xfree86/parser/write.c,v +retrieving revision 1.3 +diff -u -r1.3 write.c +--- xc/programs/Xserver/hw/xfree86/parser/write.c 3 Jul 2005 07:01:37 -0000 1.3 ++++ xc/programs/Xserver/hw/xfree86/parser/write.c 5 Jun 2006 10:35:19 -0000 +@@ -170,7 +170,10 @@ + strerror(errno)); + return 0; + case 0: /* child */ +- setuid(getuid()); ++ if (setuid(getuid() == -1) ++ FatalError("xf86writeConfigFile(): " ++ "setuid failed(%s)\n", ++ strerror(errno)); + ret = doWriteConfigFile(filename, cptr); + exit(ret); + break; +Index: xc/programs/Xserver/os/utils.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/os/utils.c,v +retrieving revision 1.21 +diff -u -r1.21 utils.c +--- xc/programs/Xserver/os/utils.c 8 Nov 2005 06:33:30 -0000 1.21 ++++ xc/programs/Xserver/os/utils.c 5 Jun 2006 10:35:20 -0000 +@@ -1718,8 +1718,10 @@ + case -1: /* error */ + p = -1; + case 0: /* child */ +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ _exit(127); ++ if (setuid(getuid()) == -1) ++ _exit(127); + execl("/bin/sh", "sh", "-c", command, (char *)NULL); + _exit(127); + default: /* parent */ +@@ -1770,8 +1772,10 @@ + xfree(cur); + return NULL; + case 0: /* child */ +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ _exit(127); ++ if (setuid(getuid()) == -1) ++ _exit(127); + if (*type == 'r') { + if (pdes[1] != 1) { + /* stdout */ +@@ -1845,8 +1849,10 @@ + xfree(cur); + return NULL; + case 0: /* child */ +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ _exit(127); ++ if (setuid(getuid()) == -1) ++ _exit(127); + if (*type == 'r') { + if (pdes[1] != 1) { + /* stdout */ +Index: xc/programs/xdm/session.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xdm/session.c,v +retrieving revision 1.3 +diff -u -r1.3 session.c +--- xc/programs/xdm/session.c 8 Nov 2005 06:33:31 -0000 1.3 ++++ xc/programs/xdm/session.c 5 Jun 2006 10:35:21 -0000 +@@ -488,8 +488,14 @@ + else + ResetServer (d); + if (removeAuth) { +- setgid (verify.gid); +- setuid (verify.uid); ++ if (setgid (verify.gid) == -1) { ++ LogError( "SessionExit: setgid: %s\n", strerror(errno)); ++ exit(status); ++ } ++ if (setuid (verify.uid) == -1) { ++ LogError( "SessionExit: setuid: %s\n", strerror(errno)); ++ exit(status); ++ } + RemoveUserAuthorization (d, &verify); + #ifdef K5AUTH + /* do like "kdestroy" program */ +Index: xc/programs/xdm/xdmshell.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xdm/xdmshell.c,v +retrieving revision 1.3 +diff -u -r1.3 xdmshell.c +--- xc/programs/xdm/xdmshell.c 14 Jul 2005 22:58:25 -0000 1.3 ++++ xc/programs/xdm/xdmshell.c 5 Jun 2006 10:35:21 -0000 +@@ -183,7 +183,11 @@ + #endif + + /* make xdm run in a non-setuid environment */ +- setuid (geteuid()); ++ if (setuid (geteuid()) == -1) { ++ fprintf(stderr, "%s: cannot setuid (error %d, %s)\r\n", ++ ProgramName, errno, strerror(errno)); ++ exit(1); ++ } + + /* + * exec /usr/bin/X11/xdm -nodaemon -udpPort 0 +Index: xc/programs/xf86dga/dga.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xf86dga/dga.c,v +retrieving revision 1.2 +diff -u -r1.2 dga.c +--- xc/programs/xf86dga/dga.c 23 Apr 2004 19:54:47 -0000 1.2 ++++ xc/programs/xf86dga/dga.c 5 Jun 2006 10:35:21 -0000 +@@ -16,6 +16,7 @@ + #include + #include + #include ++#include + #include + #include + #include +@@ -141,7 +142,10 @@ + + #ifndef __UNIXOS2__ + /* Give up root privs */ +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ fprintf(stderr, "Unable to change uid: %s\n", strerror(errno)); ++ exit(2); ++ } + #endif + + XF86DGASetViewPort(dis, DefaultScreen(dis), 0, 0); +Index: xc/programs/xinit/xinit.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xinit/xinit.c,v +retrieving revision 1.4 +diff -u -r1.4 xinit.c +--- xc/programs/xinit/xinit.c 4 Oct 2005 01:27:34 -0000 1.4 ++++ xc/programs/xinit/xinit.c 5 Jun 2006 10:35:21 -0000 +@@ -692,7 +692,10 @@ + startClient(char *client[]) + { + if ((clientpid = vfork()) == 0) { +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ Error("cannot change uid: %s\n", strerror(errno)); ++ _exit(ERR_EXIT); ++ } + setpgrp(0, getpid()); + environ = newenviron; + #ifdef __UNIXOS2__ +Index: xc/programs/xload/xload.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xload/xload.c,v +retrieving revision 1.2 +diff -u -r1.2 xload.c +--- xc/programs/xload/xload.c 23 Apr 2004 19:54:57 -0000 1.2 ++++ xc/programs/xload/xload.c 5 Jun 2006 10:35:21 -0000 +@@ -34,7 +34,7 @@ + * xload - display system load average in a window + */ + +- ++#include + #include + #include + #include +@@ -162,8 +162,17 @@ + /* For security reasons, we reset our uid/gid after doing the necessary + system initialization and before calling any X routines. */ + InitLoadPoint(); +- setgid(getgid()); /* reset gid first while still (maybe) root */ +- setuid(getuid()); ++ /* reset gid first while still (maybe) root */ ++ if (setgid(getgid()) == -1) { ++ fprintf(stderr, "%s: setgid failed: %s\n", ++ ProgramName, strerror(errno)); ++ exit(1); ++ } ++ if (setuid(getuid()) == -1) { ++ fprintf(stderr, "%s: setuid failed: %s\n", ++ ProgramName, strerror(errno)); ++ exit(1); ++ } + + XtSetLanguageProc(NULL, (XtLanguageProc) NULL, NULL); + +Index: xc/programs/xterm/main.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xterm/main.c,v +retrieving revision 1.8 +diff -u -r1.8 main.c +--- xc/programs/xterm/main.c 14 Dec 2005 23:28:27 -0000 1.8 ++++ xc/programs/xterm/main.c 5 Jun 2006 10:35:22 -0000 +@@ -1592,8 +1592,10 @@ + Window winToEmbedInto = None; + + #ifdef DISABLE_SETUID +- seteuid(getuid()); +- setuid(getuid()); ++ if (seteuid(getuid()) == -1) ++ exit(2); ++ if (setuid(getuid()) == -1) ++ exit(2); + #endif + + ProgramName = argv[0]; +@@ -1619,8 +1621,16 @@ + + #if defined(USE_UTMP_SETGID) + get_pty(NULL, NULL); +- seteuid(getuid()); +- setuid(getuid()); ++ if (seteuid(getuid()) == -1) { ++ fprintf(stderr, ++ "%s: unable to change back euid\n", ProgramName); ++ exit(1); ++ } ++ if (setuid(getuid()) == -1) { ++ fprintf(stderr, ++ "%s: unable to change back uid\n", ProgramName); ++ exit(1); ++ } + #define get_pty(pty, from) really_get_pty(pty, from) + #endif + +Index: xc/programs/xterm/misc.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xterm/misc.c,v +retrieving revision 1.6 +diff -u -r1.6 misc.c +--- xc/programs/xterm/misc.c 14 Dec 2005 23:28:27 -0000 1.6 ++++ xc/programs/xterm/misc.c 5 Jun 2006 10:35:22 -0000 +@@ -1094,8 +1094,10 @@ + pid = fork(); + switch (pid) { + case 0: /* child */ +- setgid(gid); +- setuid(uid); ++ if (setgid(gid) == -1) ++ _exit(ERROR_SETUID); ++ if (setuid(uid) == -1) ++ _exit(ERROR_SETUID); + fd = open(pathname, + O_WRONLY | O_CREAT | (append ? O_APPEND : O_EXCL), + mode); +@@ -1262,8 +1264,10 @@ + signal(SIGCHLD, SIG_DFL); + + /* (this is redundant) */ +- setgid(screen->gid); +- setuid(screen->uid); ++ if (setgid(screen->gid) == -1) ++ exit(ERROR_SETUID); ++ if (setuid(screen->uid) == -1) ++ exit(ERROR_SETUID); + + execl(shell, shell, "-c", &screen->logfile[1], (void *) 0); + +Index: xc/programs/xterm/print.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xterm/print.c,v +retrieving revision 1.5 +diff -u -r1.5 print.c +--- xc/programs/xterm/print.c 5 Aug 2005 16:13:04 -0000 1.5 ++++ xc/programs/xterm/print.c 5 Jun 2006 10:35:22 -0000 +@@ -387,9 +387,11 @@ + dup2(fileno(stderr), 2); + close(fileno(stderr)); + } +- +- setgid(screen->gid); /* don't want privileges! */ +- setuid(screen->uid); ++ /* don't want privileges! */ ++ if (setgid(screen->gid) == -1) ++ exit(2); ++ if (setuid(screen->uid) == -1) ++ exit(2); + + Printer = popen(screen->printer_command, "w"); + input = fdopen(my_pipe[0], "r"); diff --git a/x11-base/xorg-x11/files/xorg-68x-setuid.patch b/x11-base/xorg-x11/files/xorg-68x-setuid.patch new file mode 100644 index 000000000000..65106d6d75c2 --- /dev/null +++ b/x11-base/xorg-x11/files/xorg-68x-setuid.patch @@ -0,0 +1,404 @@ +Index: xc/config/util/chownxterm.c +=================================================================== +RCS file: /cvs/xorg/xc/config/util/chownxterm.c,v +retrieving revision 1.1.1.1 +diff -u -r1.1.1.1 chownxterm.c +--- xc/config/util/chownxterm.c 14 Nov 2003 16:48:20 -0000 1.1.1.1 ++++ xc/config/util/chownxterm.c 19 Jun 2006 20:15:19 -0000 +@@ -41,8 +41,10 @@ + + void help() + { +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ exit(1); ++ if (setuid(getuid()) == -1) ++ exit(1); + printf("chown-xterm makes %s suid root\n", XTERM_PATH); + printf("This is necessary on Ultrix for /dev/tty operation.\n"); + exit(0); +@@ -51,8 +53,10 @@ + void print_error(err_string) + char *err_string; + { +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ exit(1); ++ if (setuid(getuid()) == -1) ++ exit(1); + fprintf(stderr, "%s: \"%s\"", prog_name, err_string); + perror(" failed"); + exit(1); +Index: xc/lib/X11/lcFile.c +=================================================================== +RCS file: /cvs/xorg/xc/lib/X11/lcFile.c,v +retrieving revision 1.2 +diff -u -r1.2 lcFile.c +--- xc/lib/X11/lcFile.c 23 Apr 2004 18:43:24 -0000 1.2 ++++ xc/lib/X11/lcFile.c 19 Jun 2006 20:15:22 -0000 +@@ -230,7 +230,11 @@ + if (seteuid(0) != 0) { + priv = 0; + } else { +- seteuid(oldeuid); ++ if (seteuid(oldeuid) == -1) { ++ /* XXX ouch, coudn't get back to original uid ++ what can we do ??? */ ++ _exit(127); ++ } + priv = 1; + } + #endif +Index: xc/lib/xtrans/Xtranslcl.c +=================================================================== +RCS file: /cvs/xorg/xc/lib/xtrans/Xtranslcl.c,v +retrieving revision 1.2 +diff -u -r1.2 Xtranslcl.c +--- xc/lib/xtrans/Xtranslcl.c 23 Apr 2004 18:44:27 -0000 1.2 ++++ xc/lib/xtrans/Xtranslcl.c 19 Jun 2006 20:15:24 -0000 +@@ -348,7 +348,10 @@ + uid_t saved_euid; + + saved_euid = geteuid(); +- setuid( getuid() ); /** sets the euid to the actual/real uid **/ ++ /** sets the euid to the actual/real uid **/ ++ if (setuid( getuid() ) == -1) { ++ exit(1); ++ } + if( chown( slave, saved_euid, -1 ) < 0 ) { + exit( 1 ); + } +@@ -357,7 +360,13 @@ + } + + waitpid(saved_pid, &exitval, 0); +- ++ if (WIFEXITED(exitval) && WEXITSTATUS(exitval) != 0) { ++ close(fd); ++ close(server); ++ PRMSG(1, "PTSOpenClient: cannot set the owner of %s\n", ++ slave, 0, 0); ++ return(-1); ++ } + if (chmod(slave, 0666) < 0) { + close(fd); + close(server); +Index: xc/programs/Xserver/hw/xfree86/common/xf86Init.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/hw/xfree86/common/xf86Init.c,v +retrieving revision 1.12.2.2 +diff -u -r1.12.2.2 xf86Init.c +--- xc/programs/Xserver/hw/xfree86/common/xf86Init.c 17 Dec 2004 02:01:21 -0000 1.12.2.2 ++++ xc/programs/Xserver/hw/xfree86/common/xf86Init.c 19 Jun 2006 20:15:25 -0000 +@@ -1861,7 +1861,11 @@ + FatalError("xf86RunVtInit: fork failed (%s)\n", strerror(errno)); + break; + case 0: /* child */ +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ xf86Msg(X_ERROR, "xf86RunVtInit: setuid failed (%s)\n", ++ strerror(errno)); ++ exit(255); ++ } + /* set stdin, stdout to the consoleFd */ + for (i = 0; i < 2; i++) { + if (xf86Info.consoleFd != i) { +Index: xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c,v +retrieving revision 1.3 +diff -u -r1.3 libc_wrapper.c +--- xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c 30 Jul 2004 20:51:08 -0000 1.3 ++++ xc/programs/Xserver/hw/xfree86/os-support/shared/libc_wrapper.c 19 Jun 2006 20:15:26 -0000 +@@ -1226,7 +1226,10 @@ + #ifndef SELF_CONTAINED_WRAPPER + xf86DisableIO(); + #endif +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ ErrorF("xf86Execl: setuid() failed: %s\n", strerror(errno)); ++ exit(255); ++ } + #if !defined(SELF_CONTAINED_WRAPPER) + /* set stdin, stdout to the consoleFD, and leave stderr alone */ + for (i = 0; i < 2; i++) +Index: xc/programs/Xserver/hw/xfree86/parser/write.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/hw/xfree86/parser/write.c,v +retrieving revision 1.2 +diff -u -r1.2 write.c +--- xc/programs/Xserver/hw/xfree86/parser/write.c 31 Jul 2004 09:14:06 -0000 1.2 ++++ xc/programs/Xserver/hw/xfree86/parser/write.c 19 Jun 2006 20:15:26 -0000 +@@ -166,7 +166,10 @@ + strerror(errno)); + return 0; + case 0: /* child */ +- setuid(getuid()); ++ if (setuid(getuid() == -1) ++ FatalError("xf86writeConfigFile(): " ++ "setuid failed(%s)\n", ++ strerror(errno)); + ret = doWriteConfigFile(filename, cptr); + exit(ret); + break; +Index: xc/programs/Xserver/os/utils.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/Xserver/os/utils.c,v +retrieving revision 1.6.2.3 +diff -u -r1.6.2.3 utils.c +--- xc/programs/Xserver/os/utils.c 8 Dec 2004 06:34:31 -0000 1.6.2.3 ++++ xc/programs/Xserver/os/utils.c 19 Jun 2006 20:15:26 -0000 +@@ -1,4 +1,4 @@ +-/* $XdotOrg: xc/programs/Xserver/os/utils.c,v 1.6.2.3 2004/12/08 06:34:31 gisburn Exp $ */ ++/* $XdotOrg: xc/programs/Xserver/os/utils.c,v 1.21 2005/11/08 06:33:30 jkj Exp $ */ + /* $Xorg: utils.c,v 1.5 2001/02/09 02:05:24 xorgcvs Exp $ */ + /* + +@@ -1707,8 +1707,10 @@ + case -1: /* error */ + p = -1; + case 0: /* child */ +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ _exit(127); ++ if (setuid(getuid()) == -1) ++ _exit(127); + execl("/bin/sh", "sh", "-c", command, (char *)NULL); + _exit(127); + default: /* parent */ +@@ -1759,8 +1761,10 @@ + xfree(cur); + return NULL; + case 0: /* child */ +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ _exit(127); ++ if (setuid(getuid()) == -1) ++ _exit(127); + if (*type == 'r') { + if (pdes[1] != 1) { + /* stdout */ +@@ -1834,8 +1838,10 @@ + xfree(cur); + return NULL; + case 0: /* child */ +- setgid(getgid()); +- setuid(getuid()); ++ if (setgid(getgid()) == -1) ++ _exit(127); ++ if (setuid(getuid()) == -1) ++ _exit(127); + if (*type == 'r') { + if (pdes[1] != 1) { + /* stdout */ +Index: xc/programs/xdm/session.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xdm/session.c,v +retrieving revision 1.2 +diff -u -r1.2 session.c +--- xc/programs/xdm/session.c 23 Apr 2004 19:54:42 -0000 1.2 ++++ xc/programs/xdm/session.c 19 Jun 2006 20:15:26 -0000 +@@ -1,4 +1,4 @@ +-/* $XdotOrg: xc/programs/xdm/session.c,v 1.2 2004/04/23 19:54:42 eich Exp $ */ ++/* $XdotOrg: xc/programs/xdm/session.c,v 1.3 2005/11/08 06:33:31 jkj Exp $ */ + /* $Xorg: session.c,v 1.8 2001/02/09 02:05:40 xorgcvs Exp $ */ + /* + +@@ -484,8 +484,14 @@ + else + ResetServer (d); + if (removeAuth) { +- setgid (verify.gid); +- setuid (verify.uid); ++ if (setgid (verify.gid) == -1) { ++ LogError( "SessionExit: setgid: %s\n", strerror(errno)); ++ exit(status); ++ } ++ if (setuid (verify.uid) == -1) { ++ LogError( "SessionExit: setuid: %s\n", strerror(errno)); ++ exit(status); ++ } + RemoveUserAuthorization (d, &verify); + #ifdef K5AUTH + /* do like "kdestroy" program */ +Index: xc/programs/xdm/xdmshell.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xdm/xdmshell.c,v +retrieving revision 1.2 +diff -u -r1.2 xdmshell.c +--- xc/programs/xdm/xdmshell.c 23 Apr 2004 19:54:42 -0000 1.2 ++++ xc/programs/xdm/xdmshell.c 19 Jun 2006 20:15:26 -0000 +@@ -179,7 +179,11 @@ + #endif + + /* make xdm run in a non-setuid environment */ +- setuid (geteuid()); ++ if (setuid (geteuid()) == -1) { ++ fprintf(stderr, "%s: cannot setuid (error %d, %s)\r\n", ++ ProgramName, errno, strerror(errno)); ++ exit(1); ++ } + + /* + * exec /usr/bin/X11/xdm -nodaemon -udpPort 0 +Index: xc/programs/xf86dga/dga.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xf86dga/dga.c,v +retrieving revision 1.2 +diff -u -r1.2 dga.c +--- xc/programs/xf86dga/dga.c 23 Apr 2004 19:54:47 -0000 1.2 ++++ xc/programs/xf86dga/dga.c 19 Jun 2006 20:15:27 -0000 +@@ -16,6 +16,7 @@ + #include + #include + #include ++#include + #include + #include + #include +@@ -141,7 +142,10 @@ + + #ifndef __UNIXOS2__ + /* Give up root privs */ +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ fprintf(stderr, "Unable to change uid: %s\n", strerror(errno)); ++ exit(2); ++ } + #endif + + XF86DGASetViewPort(dis, DefaultScreen(dis), 0, 0); +Index: xc/programs/xinit/xinit.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xinit/xinit.c,v +retrieving revision 1.2 +diff -u -r1.2 xinit.c +--- xc/programs/xinit/xinit.c 23 Apr 2004 19:54:49 -0000 1.2 ++++ xc/programs/xinit/xinit.c 19 Jun 2006 20:15:27 -0000 +@@ -678,7 +678,10 @@ + startClient(char *client[]) + { + if ((clientpid = vfork()) == 0) { +- setuid(getuid()); ++ if (setuid(getuid()) == -1) { ++ Error("cannot change uid: %s\n", strerror(errno)); ++ _exit(ERR_EXIT); ++ } + setpgrp(0, getpid()); + environ = newenviron; + #ifdef __UNIXOS2__ +Index: xc/programs/xload/xload.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xload/xload.c,v +retrieving revision 1.2 +diff -u -r1.2 xload.c +--- xc/programs/xload/xload.c 23 Apr 2004 19:54:57 -0000 1.2 ++++ xc/programs/xload/xload.c 19 Jun 2006 20:15:27 -0000 +@@ -34,7 +34,7 @@ + * xload - display system load average in a window + */ + +- ++#include + #include + #include + #include +@@ -162,8 +162,17 @@ + /* For security reasons, we reset our uid/gid after doing the necessary + system initialization and before calling any X routines. */ + InitLoadPoint(); +- setgid(getgid()); /* reset gid first while still (maybe) root */ +- setuid(getuid()); ++ /* reset gid first while still (maybe) root */ ++ if (setgid(getgid()) == -1) { ++ fprintf(stderr, "%s: setgid failed: %s\n", ++ ProgramName, strerror(errno)); ++ exit(1); ++ } ++ if (setuid(getuid()) == -1) { ++ fprintf(stderr, "%s: setuid failed: %s\n", ++ ProgramName, strerror(errno)); ++ exit(1); ++ } + + XtSetLanguageProc(NULL, (XtLanguageProc) NULL, NULL); + +Index: xc/programs/xterm/main.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xterm/main.c,v +retrieving revision 1.4.2.1 +diff -u -r1.4.2.1 main.c +--- xc/programs/xterm/main.c 12 Jan 2005 21:45:10 -0000 1.4.2.1 ++++ xc/programs/xterm/main.c 19 Jun 2006 20:15:28 -0000 +@@ -2789,8 +2789,10 @@ + #ifdef USE_PTY_DEVICE + set_pty_id(ptydev, passedPty); + #endif +- setgid(screen->gid); +- setuid(screen->uid); ++ if (setgid(screen->gid) == -1) ++ SysError(ERROR_SETUID); ++ if (setuid(screen->uid) == -1) ++ SysError(ERROR_SETUID); + } else { + Bool tty_got_hung; + +Index: xc/programs/xterm/misc.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xterm/misc.c,v +retrieving revision 1.3.2.1 +diff -u -r1.3.2.1 misc.c +--- xc/programs/xterm/misc.c 12 Jan 2005 21:45:10 -0000 1.3.2.1 ++++ xc/programs/xterm/misc.c 19 Jun 2006 20:15:28 -0000 +@@ -1045,8 +1045,10 @@ + pid = fork(); + switch (pid) { + case 0: /* child */ +- setgid(gid); +- setuid(uid); ++ if (setgid(gid) == -1) ++ _exit(ERROR_SETUID); ++ if (setuid(uid) == -1) ++ _exit(ERROR_SETUID); + fd = open(pathname, + O_WRONLY | O_CREAT | (append ? O_APPEND : O_EXCL), + mode); +@@ -1212,8 +1214,10 @@ + signal(SIGCHLD, SIG_DFL); + + /* (this is redundant) */ +- setgid(screen->gid); +- setuid(screen->uid); ++ if (setgid(screen->gid) == -1) ++ exit(ERROR_SETUID); ++ if (setuid(screen->uid) == -1) ++ exit(ERROR_SETUID); + + execl(shell, shell, "-c", &screen->logfile[1], (void *) 0); + +Index: xc/programs/xterm/print.c +=================================================================== +RCS file: /cvs/xorg/xc/programs/xterm/print.c,v +retrieving revision 1.3.2.1 +diff -u -r1.3.2.1 print.c +--- xc/programs/xterm/print.c 12 Jan 2005 21:45:10 -0000 1.3.2.1 ++++ xc/programs/xterm/print.c 19 Jun 2006 20:15:28 -0000 +@@ -381,9 +381,11 @@ + dup2(fileno(stderr), 2); + close(fileno(stderr)); + } +- +- setgid(screen->gid); /* don't want privileges! */ +- setuid(screen->uid); ++ /* don't want privileges! */ ++ if (setgid(screen->gid) == -1) ++ exit(2); ++ if (setuid(screen->uid) == -1) ++ exit(2); + + Printer = popen(screen->printer_command, "w"); + input = fdopen(my_pipe[0], "r"); diff --git a/x11-base/xorg-x11/xorg-x11-6.8.2-r8.ebuild b/x11-base/xorg-x11/xorg-x11-6.8.2-r8.ebuild new file mode 100644 index 000000000000..020e12a13df0 --- /dev/null +++ b/x11-base/xorg-x11/xorg-x11-6.8.2-r8.ebuild @@ -0,0 +1,1847 @@ +# Copyright 1999-2006 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/x11-base/xorg-x11/xorg-x11-6.8.2-r8.ebuild,v 1.1 2006/06/20 20:00:51 spyderous Exp $ + +# Set TDFX_RISKY to "yes" to get 16-bit, 1024x768 or higher on low-memory +# voodoo3 cards. + +# Libraries which are now supplied in shared form that were not in the past +# include: libFS.so, libGLw.so, libI810XvMC.so, libXRes.so, libXfontcache.so, +# libXinerama.so, libXss.so, libXvMC.so, libXxf86rush.so, libfontenc.so, +# libxkbfile.so, libxkbui.so + +# TODO +# 1 June 2005 +# TARGET: none +# Consider building shared libraries only, when both are provided +# Combine find loops for "Creating fonts.scale files," "Generating +# fonts.dir files and "Generating Xft cache" +# the loop in pkg_postinst for removing Compose can probably +# be one line of bash expansion like rm -f ${ROOT}/usr/$(get_libdir)/ +# X11/locale/{ja*|ko*|zh*}/Compose +# Clean up migration function +# - loop through lib* instead of repetition +# Fix direction of lib -> libdir symlink +# Generalize any functions that make sense to generalize (i.e., anything +# that might realistically see use elsewhere, or repetitively here) +inherit eutils flag-o-matic toolchain-funcs x11 linux-info multilib + + +# Make sure Portage does _NOT_ strip symbols. We will do it later and make sure +# that only we only strip stuff that are safe to strip ... +RESTRICT="nostrip" + +# IUSE="gatos" disabled because gatos is broken on ~4.4 now (31 Jan 2004) +IUSE="3dfx 3dnow bitmap-fonts cjk debug dlloader dmx doc font-server + insecure-drivers ipv6 minimal mmx nls nocxx opengl pam sdk sse static + truetype-fonts type1-fonts uclibc xprint xv" +# IUSE_INPUT_DEVICES="synaptics wacom" + +FILES_VER="0.8" +PATCH_VER="0.1.13" +XCUR_VER="0.3.1" +XFSFT_ENC_VER="0.1" + +S=${WORKDIR}/xc + +HOMEPAGE="http://xorg.freedesktop.org/" + +# Misc patches we may need to fetch .. +X_PATCHES="http://dev.gentoo.org/~joshuabaergen/distfiles/${P}-patches-${PATCH_VER}.tar.bz2 + mirror://gentoo/${P}-patches-${PATCH_VER}.tar.bz2" + +GENTOO_FILES="http://dev.gentoo.org/~seemant/distfiles/${P}-files-${FILES_VER}.tar.bz2 + mirror://gentoo/${P}-files-${FILES_VER}.tar.bz2" + +SRC_URI="!minimal? ( mirror://gentoo/eurofonts-X11.tar.bz2 ) + font-server? ( http://dev.gentoo.org/~cyfred/xorg/${PN}/patchsets/${PV}/xfsft-encodings-${XFSFT_ENC_VER}.tar.bz2 ) + !minimal? ( mirror://gentoo/gentoo-cursors-tad-${XCUR_VER}.tar.bz2 ) + nls? ( mirror://gentoo/gemini-koi8-u.tar.bz2 ) + ${GENTOO_FILES} + ${X_PATCHES} + http://xorg.freedesktop.org/X11R${PV}/src-single/X11R${PV}-src.tar.bz2" +# http://xorg.freedesktop.org/X11R${PV}/src/X11R${PV}-src1.tar.gz +# http://xorg.freedesktop.org/X11R${PV}/src//X11R${PV}-src2.tar.gz +# http://xorg.freedesktop.org/X11R${PV}/src//X11R${PV}-src3.tar.gz +# http://xorg.freedesktop.org/X11R${PV}/src//X11R${PV}-src4.tar.gz +# http://xorg.freedesktop.org/X11R${PV}/src//X11R${PV}-src5.tar.gz +# doc? ( +# http://xorg.freedesktop.org/X11R${PV}/src//X11R${PV}-src6.tar.gz +# http://xorg.freedesktop.org/X11R${PV}/src//X11R${PV}-src7.tar.gz +# )" + +LICENSE="Adobe-X CID DEC DEC-2 IBM-X NVIDIA-X NetBSD SGI UCB-LBL XC-2 + bigelow-holmes-urw-gmbh-luxi christopher-g-demetriou national-semiconductor + nokia tektronix the-open-group todd-c-miller x-truetype xfree86-1.0 + MIT SGI-B BSD || ( FTL GPL-2 )" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sh ~sparc ~x86" + +DEPEND=">=sys-libs/ncurses-5.1 + >=sys-libs/zlib-1.1.3-r2 + >=sys-devel/flex-2.5.4a-r5 + sys-apps/groff + >=dev-libs/expat-1.95.3 + >=media-libs/freetype-2.1.8 + >=media-libs/fontconfig-2.1-r1 + opengl? ( >=x11-base/opengl-update-2.2.0 ) + !nocxx? ( >=x11-apps/ttmkfdir-3.0.9-r2 ) + >=sys-apps/sed-4 + userland_GNU? ( sys-apps/util-linux ) + dev-lang/perl + media-libs/libpng + !<=app-emulation/emul-linux-x86-xlibs-1.2-r3" +# FBSDTODO: need to check that X is not pulled in before freebsd-ubin for 'col' presence + +RDEPEND=" + >=sys-libs/zlib-1.1.3-r2 + >=sys-devel/flex-2.5.4a-r5 + >=dev-libs/expat-1.95.3 + >=media-libs/freetype-2.1.8 + >=media-libs/fontconfig-2.1-r1 + opengl? ( >=x11-base/opengl-update-2.2.0 ) + !nocxx? ( >=x11-apps/ttmkfdir-3.0.9-r2 ) + media-libs/libpng + >=sys-libs/ncurses-5.1 + !<=app-emulation/emul-linux-x86-xlibs-1.2-r3" + +PDEPEND="x86? ( + input_devices_synaptics? ( x11-drivers/synaptics ) + input_devices_wacom? ( x11-misc/linuxwacom ) + ) + 3dfx? ( >=media-libs/glide-v3-3.10 ) + x11-terms/xterm" + +PROVIDE="virtual/x11 + opengl? ( virtual/opengl + virtual/glu ) + virtual/xft" + +DESCRIPTION="An X11 implementation maintained by the X.Org Foundation" + +pkg_setup() { + FILES_DIR="${WORKDIR}/files" + PATCHDIR="${WORKDIR}/patch" + EXCLUDED="${PATCHDIR}/excluded" + + # Set up CFLAG-related things + cflag_setup + + # See bug #35468, circular pam-X11 dep + check_pam + + # Look for invalid/dangerous USE flags and combinations + check_use_combos + + setup_multilib + + # xfs user + if use font-server; then + enewgroup xfs 33 + enewuser xfs 33 -1 /etc/X11/fs xfs + fi +} + +src_unpack() { + unpack_all + + patch_setup + + do_patch + + host_def_setup + + use_specific_hacks +} + +src_compile() { + build +} + +src_install() { + install_everything + + backward_compat_install + + fix_permissions + + # We zap our CFLAGS in the host.def file, as hardcoded CFLAGS can + # mess up other things that use xmkmf + zap_host_def_cflags + + # EURO support + if ! use minimal; then + add_euro_support + fi + + setup_standard_symlinks + + if use opengl; then + fix_opengl_symlinks + fi + + libtool_archive_install + + compose_files_install + + if use font-server; then + encode_xfsft_files + fi + + if use nls; then + koi8_fonts_install + fi + + etc_files_install + + if use opengl; then + dynamic_libgl_install + fi + + fix_libtool_libdir_paths "$(find ${D} -name *.la)" + + cursor_install + + strip_execs + + if use minimal; then + minimal_install + fi + + # TEMPORARY hack: should be patched in, if it's not already + # For Battoussai's gatos stuffs: + if use sdk; then + insinto /usr/$(get_libdir)/Server/include + doins ${S}/extras/drm/shared/drm.h + fi + + xprint_install + + config_files_install +} + +pkg_preinst() { + # Do migration before anything else, so we do all the rest inside the + # symlink + + # Get rid of "standard" symlinks + # We can't overwrite symlink with directory w/ $(mv -f) + [ -L ${ROOT}usr/$(get_libdir)/X11 ] \ + && rm ${ROOT}usr/$(get_libdir)/X11 + [ -L ${ROOT}usr/include/X11 ] \ + && rm ${ROOT}usr/include/X11 + [ -L ${ROOT}usr/include/GL ] \ + && rm ${ROOT}usr/include/GL + [ -L ${ROOT}usr/bin/X11 ] \ + && rm ${ROOT}usr/bin/X11 + # Get rid of some apparent artifacts of migration + [ -L ${ROOT}usr/include/GL/GL ] \ + && rm ${ROOT}usr/include/GL/GL + [ -L ${ROOT}usr/include/X11/X11 ] \ + && rm ${ROOT}usr/include/X11/X11 + [ -d ${ROOT}usr/share/fonts/fonts ] \ + && rm -rf ${ROOT}usr/share/fonts/fonts + + # No need to do this, if it's already been done + # Also, it'll overwrite a ton of stuff because it won't realize /usr/X11R6 + # is a symlink. + if [ ! -L "/usr/X11R6" ]; then + # Migrate stuff in /usr/X11R6 to /usr + local DIR DIRS + DIRS="bin include lib" + if [ "lib" != "$(get_libdir)" ]; then + DIRS="${DIRS} $(get_libdir)" + fi + for DIR in ${DIRS}; do + migrate /usr/X11R6/${DIR} /usr/${DIR} + done + # Can't do this in the other loop because of different start and end + migrate /usr/X11R6/man /usr/share/man + fi + + update_config_files + + cleanup_fonts + + # See above comment for the same test + if [ ! -L "/usr/X11R6" ]; then + # Needs to happen after cleanup_fonts() + migrate /usr/X11R6/$(get_libdir)/X11/fonts /usr/share/fonts + + # Get rid of symlinks so we can migrate /usr/X11R6 without dying when a + # symlink tries to copy to a dir + einfo "Preparing for /usr/X11R6 -> /usr migration..." + local LINK LINKS + LINKS="bin include lib man share/info" + if [ "lib" != "$(get_libdir)" ]; then + LINKS="${LINKS} $(get_libdir)" + fi + for LINK in ${LINKS}; do + if [ -L "${ROOT}/usr/X11R6/${LINK}" ]; then + rm -fv ${ROOT}/usr/X11R6/${LINK} + fi + done + einfo "Remaining symlinks in /usr/X11R6:" + find ${ROOT}/usr/X11R6/ -type l + + # Woohoo, nothing in /usr/X11R6 after this + migrate /usr/X11R6 /usr + fi + + move_app_defaults_to_etc + + move_xkb_to_usr + + # Run this even for USE=-opengl, to clean out old stuff from possible + # USE=opengl build + dynamic_libgl_preinst +} + +pkg_postinst() { + env-update + + if [ "${ROOT}" = "/" ]; then + font_setup + + if use opengl; then + switch_opengl_implem + fi + fi + + remove_old_compose_files + + setup_tmp_files + + print_info +} + +pkg_postrm() { + fix_links +} + +############### +# pkg_setup() # +############### + +cflag_setup() { + # Set up CFLAGS + filter-flags "-funroll-loops" + + ALLOWED_FLAGS="-fstack-protector -march -mcpu -mtune -O -O0 -O1 -O2 -O3 -Os" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -pipe -fomit-frame-pointer" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -momit-leaf-frame-pointer" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -g -g0 -g1 -g2 -g3" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -ggdb -ggdb0 -ggdb1 -ggdb2 -ggdb3" + # arch-specific section added by popular demand + case "${ARCH}" in + mips) ALLOWED_FLAGS="${ALLOWED_FLAGS} -mips1 -mips2 -mips3 -mips4 -mabi" + ;; + # -fomit-frame-pointer known to break things and is pointless + # according to ciaranm + # And hardened compiler must be softened. -- fmccor, 20.viii.04 + sparc) filter-flags "-fomit-frame-pointer" "-momit-leaf-frame-pointer" + if has_hardened && ! use dlloader; then + einfo "Softening gcc for sparc." + ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-pie -fno-PIE" + append-flags -fno-pie -fno-PIE + fi + + if [[ ${ABI} == "sparc64" ]]; then + ALLOWED_FLAGS="${ALLOWED_FLAGS} -D__sparc_v9__ -D__linux_sparc_64__" + append-flags -D__sparc_v9__ -D__linux_sparc_64__ + fi + ;; + # gcc-3.3.2 causes invalid insn error + hppa ) replace-cpu-flags 2.0 1.0 + ;; + esac + + # Recently there has been a lot of stability problem in Gentoo-land. Many + # things can be the cause to this, but I believe that it is due to gcc3 + # still having issues with optimizations, or with it not filtering bad + # combinations (protecting the user maybe from themselves) yet. + # + # This can clearly be seen in large builds like glibc, where too aggressive + # CFLAGS cause the tests to fail miserbly. + # + # Quote from Nick Jones , who in my opinion + # knows what he is talking about: + # + # People really shouldn't force code-specific options on... It's a + # bad idea. The -march options aren't just to look pretty. They enable + # options that are sensible (and include sse,mmx,3dnow when appropriate). + # + # The next command strips CFLAGS and CXXFLAGS from nearly all flags. If + # you do not like it, comment it, but do not bugreport if you run into + # problems. + # + # (13 Oct 2002) + strip-flags +} + +check_pam() { + if use pam && has_version x11-base/${PN}; then + einfo "Previous ${PN} installation detected." + einfo "Enabling PAM features in ${PN}." + else + einfo "Previous ${PN} installation NOT detected." + einfo "Disabling PAM features in ${PN}." + einfo "You must remerge ${PN} to enable pam." + einfo "See http://bugs.gentoo.org/show_bug.cgi?id=35468." + fi +} + +check_use_combos() { + if use static; then + # A static build disallows building the SDK. + # See config/xf86.rules. + if use sdk; then + die "The static USE flag is incompatible with the sdk USE flag." + fi + fi + + if use dmx && use doc; then + die "The dmx and doc USE flags are temporarily incompatible and result in a dead build." + fi + + # (#77949) + if use minimal && use doc; then + die "The minimal and doc USE flags are temporarily incompatible and result in a dead build." + fi + + if use xv && ! use opengl; then + eerror "See http://bugs.gentoo.org/show_bug.cgi?id=67996" + eerror "The xv USE flag currently requires the opengl flag." + die "This is a known bug. Do not report it." + fi + + if use opengl && ! use xv; then + eerror "See http://bugs.gentoo.org/show_bug.cgi?id=76936" + eerror "The opengl USE flag currently requires the xv flag." + die "This is a known bug. Do not report it." + fi + + # Echo a message to the user about bitmap-fonts + if ! use bitmap-fonts; then + ewarn "Please emerge this with USE=\"bitmap-fonts\" to enable" + ewarn "75dpi and 100dpi fonts. Your GTK+-1.2 fonts may look" + ewarn "screwy otherwise" + + ebeep 5 + epause 10 + fi +} + +setup_multilib() { + # on amd64 we need /usr/lib64/X11/locale/lib to be a symlink + # created by the emul lib ebuild in order for adobe acrobat, staroffice, + # and a few other apps to work. + if ! has_multilib_profile; then + use amd64 && get_libdir_override lib64 + fi +} + +################ +# src_unpack() # +################ + +unpack_all() { + # Unpack source and patches + ebegin "Unpacking ${PV} source" + unpack X11R${PV}-src.tar.bz2 > /dev/null +# unpack X11R${PV}-src{1,2,3,4,5}.tar.gz > /dev/null + eend 0 + +# if use doc; then +# ebegin "Unpacking documentation" +# unpack X11R${PV}-src{6,7}.tar.gz > /dev/null +# eend 0 +# fi + + ebegin "Unpacking Gentoo files and patches" + unpack ${P}-files-${FILES_VER}.tar.bz2 > /dev/null + unpack ${P}-patches-${PATCH_VER}.tar.bz2 > /dev/null + eend 0 + + if ! use minimal; then + # Unpack TaD's gentoo cursors + ebegin "Unpacking Gentoo cursors" + unpack gentoo-cursors-tad-${XCUR_VER}.tar.bz2 > /dev/null + eend 0 + fi + + # Unpack extra fonts stuff from Mandrake + ebegin "Unpacking fonts" + if use nls; then + unpack gemini-koi8-u.tar.bz2 > /dev/null + fi + if ! use minimal; then + unpack eurofonts-X11.tar.bz2 > /dev/null + fi + if use font-server; then + unpack xfsft-encodings-${XFSFT_ENC_VER}.tar.bz2 > /dev/null + fi + eend 0 + + # Remove bum encoding + rm -f ${WORKDIR}/usr/share/fonts/encodings/urdunaqsh-0.enc +} + +do_patch() { + # Bulk patching - based on patch name + # Will create excluded stuff once it's needed + cd ${WORKDIR} + EPATCH_SUFFIX="patch" \ + epatch ${PATCHDIR} + cd ${S} + + # Security patches + epatch ${FILESDIR}/CVE-2006-1526-xrender-mitri.patch + epatch ${FILESDIR}/xorg-68x-setuid.patch +} + +host_def_setup() { + HOSTCONF="config/cf/host.def" + + ebegin "Setting up ${HOSTCONF}" + cd ${S}; cp ${FILES_DIR}/site.def ${HOSTCONF} \ + || die "host.def copy failed" + echo "#define XVendorString \"Gentoo (The X.Org Foundation ${PV}, revision ${PR}-${PATCH_VER})\"" \ + >> ${HOSTCONF} + + # Pending http://bugs.gentoo.org/show_bug.cgi?id=49038 and + # http://freedesktop.org/cgi-bin/bugzilla/show_bug.cgi?id=600 + # + # Makes ld bail at link time on undefined symbols + # Suggested by Mike Harris + #echo "#define SharedLibraryLoadFlags -shared -Wl,-z,defs" \ + # >> ${HOSTCONF} + + # Enable i810 on x86_64 (RH #126687) + if use amd64; then + echo "#define XF86ExtraCardDrivers i810" >> ${HOSTCONF} + fi + + # FHS install locations + echo "#define ManDirectoryRoot /usr/share/man" >> ${HOSTCONF} + echo "#define DocDir /usr/share/doc/${PF}" >> ${HOSTCONF} + echo "#define FontDir /usr/share/fonts" >> ${HOSTCONF} + echo "#define BinDir /usr/bin" >> ${HOSTCONF} + echo "#define IncRoot /usr/include" >> ${HOSTCONF} + # This breaks the case when $(SYSTEMUSRINCDIR) = $(INCDIR) + # See xc/include/Imakefile + echo "#define LinkGLToUsrInclude NO" >> ${HOSTCONF} + # /usr/X11R6/lib/X11 + echo "#define LibDir /usr/$(get_libdir)/X11" >> ${HOSTCONF} + # /usr/X11R6/lib with exception of /usr/X11R6/lib/X11 + echo "#define UsrLibDir /usr/$(get_libdir)" >> ${HOSTCONF} + + # Make man4 and man7 stuff get 'x' suffix like everything else + # Necessary so we can install to /usr/share/man without overwriting + echo "#define DriverManDir \$(MANSOURCEPATH)4" >> ${HOSTCONF} + echo "#define DriverManSuffix 4x /* use just one tab or cpp will die */" \ + >> ${HOSTCONF} + echo "#define MiscManDir \$(MANSOURCEPATH)7" >> ${HOSTCONF} + echo "#define MiscManSuffix 7x /* use just one tab or cpp will die */" \ + >> ${HOSTCONF} + + # Don't build xterm -- use external (#54051) + echo "#define BuildXterm NO" >> ${HOSTCONF} + + # Xwrapper has been removed so we now need to use the set uid server + # again, this mustve happened somewhere after 4.3.0 in the development. + echo "#define InstallXserverSetUID YES" >> ${HOSTCONF} + echo "#define BuildServersOnly NO" >> ${HOSTCONF} + + # Don't use /lib64 if $(get_libdir) != lib64 + # Replaces 0181_all_4.3.0-amd64-nolib64.patch + if [ "$(get_libdir)" == "lib64" ]; then + echo "#define HaveLib64 YES" >> ${HOSTCONF} + sed -i '/^#define Freetype2LibDir/s:^.*$:#define Freetype2LibDir /usr/lib64:' ${HOSTCONF} + else + echo "#define HaveLib64 NO" >> ${HOSTCONF} + fi + + # Set location of DRM source to be installed + echo "#define InstSrcDir ${ROOT}/usr/src/${PF}" >> ${HOSTCONF} + + if [ "$(gcc-major-version)" -eq "3" ]; then + if use x86; then + # Should fix bug #4189. gcc 3.x have problems with + # -march=pentium4 and -march=athlon-tbird + # Seems fixed on 3.3 and higher + if [ "$(gcc-minor-version)" -le "2" ]; then + replace-cpu-flags pentium4 pentium3 + replace-cpu-flags athlon athlon-tbird + fi + + if [ "$(gcc-minor-version)" -eq "4" ]; then + if [ "$(gcc-micro-version)" -lt "4" ]; then + #to fix #57602 for now, thanks Spanky (broken sse2) + if test_flag -mno-sse2; then + append-flags -mno-sse2 + fi + # (#75067) broken sse3 + if test_flag -mno-sse3; then + append-flags -mno-sse3 + fi + fi + fi + + # Try a fix for #49310, see #50931 for more info. + if [ "$(is-flag -fomit-frame-pointer)" ]; then + replace-cpu-flags k6 k6-2 k6-3 i586 + fi + fi + + # Without this, modules breaks with gcc3 + if [ "$(gcc-minor-version)" -eq "1" ]; then + append-flags "-fno-merge-constants" + append-flags "-fno-merge-constants" + fi + + if [ "$(gcc-minor-version)" -eq "2" ]; then + if [ "$(gcc-micro-version)" -lt "2" ]; then + # Bug #12775 .. fails with -Os. + replace-flags "-Os" "-O2" + fi + elif [ "$(gcc-minor-version)" -lt "2" ]; then + # Bug #12775 .. fails with -Os. + replace-flags "-Os" "-O2" + fi + elif [ "$(gcc-major-version)" -lt "3" ]; then + # Bug #12775 .. fails with -Os. + replace-flags "-Os" "-O2" + fi + + echo "#define CcCmd $(tc-getCC)" >> ${HOSTCONF} + echo "#define OptimizedCDebugFlags ${CFLAGS} GccAliasingArgs" >> ${HOSTCONF} + echo "#define OptimizedCplusplusDebugFlags ${CXXFLAGS} GccAliasingArgs" >> ${HOSTCONF} + + if use static; then + echo "#define DoLoadableServer NO" >>${HOSTCONF} + else + einfo "Setting DoLoadableServer to YES." + echo "#define DoLoadableServer YES" >> ${HOSTCONF} + + if use dlloader; then + einfo "Setting MakeDllModules to YES." + echo "#define MakeDllModules YES" >> ${HOSTCONF} + if has_hardened; then + echo "#define HardenedGccSpecs YES" >> ${HOSTCONF} + fi + else + einfo "Setting MakeDllModules to NO." + echo "#define MakeDllModules NO" >> ${HOSTCONF} + fi + fi + + use_build debug XFree86Devel + use_build debug BuildDebug + use_build debug DebuggableLibraries + + if ! use debug; then + # use less ram .. got this from Spider's makeedit.eclass :) + echo "#define GccWarningOptions -Wno-return-type -w" \ + >> ${HOSTCONF} + fi + + # Remove circular dep between pam and X11, bug #35468 + # If pam is in USE and we have X11, then we can enable PAM +# if use pam && has_version x11-base/xorg-x11 + if has_version x11-base/xorg-x11; then + # If you want to have optional pam support, do it properly ... + use_build pam HasPam + use_build pam HasPamMisc + fi + + if use x86 || use alpha; then + # build with glide3 support? (build the tdfx_dri.o module) + if use 3dfx; then + echo "#define HasGlide3 YES" >> ${HOSTCONF} + fi +# This won't work unless we can disable building the tdfx stuff +# entirely :/ +# use_build 3dfx HasGlide3 + fi + + if use x86; then + # optimize Mesa for architecture + use_build mmx HasMMXSupport + use_build 3dnow Has3DNowSupport + use_build sse HasSSESupport + fi + + # optimize Mesa for architecture + if use amd64; then + use_build amd64 HasMMXSupport + use_build amd64 Has3DNowSupport + use_build amd64 HasSSESupport + fi + + # Do we want the glx extension? This will turn off XF86DRI if it's off. + # DRI can't build if glx isn't built, so keep this below DRI define. + # Do this before hppa so they can turn DRI off + use_build opengl BuildGlxExt + use_build opengl BuildGLXLibrary + use_build opengl BuildXF86DRI + # Needs GL headers + use_build opengl BuildGLULibrary + + + + if use mips; then + echo "#define XF86CardDrivers fbdev newport" >> ${HOSTCONF} + fi + + # Make xv optional for more minimal builds + use_build xv BuildXvLibrary + use_build xv BuildXvExt + # Depends on X11/extensions/Xv.h + use_build xv BuildXF86RushExt + use_build xv BuildXF86RushLibrary + + if use hppa; then + echo "#define DoLoadableServer NO" >> ${HOSTCONF} + echo "#define BuildXF86DRI NO" >> config/cf/host.def + echo "#undef DriDrivers" >> config/cf/host.def + echo "#define XF86CardDrivers fbdev" >> config/cf/host.def + echo "#define BuildXvExt YES" >> config/cf/host.def + fi + + + if use alpha; then + echo "#define XF86CardDrivers mga nv tga s3virge sis rendition \ + i740 tdfx cirrus tseng fbdev \ + ati vga v4l glint s3 vesa" >> ${HOSTCONF} + fi + + if use ppc; then + echo "#define XF86CardDrivers mga glint s3virge sis savage trident \ + chips tdfx fbdev ati DevelDrivers vga nv imstt \ + XF86OSCardDrivers XF86ExtraCardDrivers" >> ${HOSTCONF} + fi + + if use ppc64; then + echo "#define MakeDllModules YES" >> ${HOSTCONF} + echo "#define XF86VgaHw YES" >> ${HOSTCONF} + echo "#define XF86FBDevHw YES" >> ${HOSTCONF} + echo "#define XF86CardDrivers mga fbdev v4l ati vga nv" >> ${HOSTCONF} + fi + + if use sparc; then + echo "#define XF86CardDrivers sunffb sunleo suncg6 suncg3 suncg14 \ + suntcx sunbw2 glint mga tdfx ati savage vesa vga fbdev \ + XF86OSCardDrivers XF86ExtraCardDrivers \ + DevelDrivers" >> ${HOSTCONF} + if has_hardened && ! use dlloader; then + einfo "Softening the assembler so cfb modules will play nice with sunffb." + echo "#define AsCmd CcCmd -c -x assembler -fno-pie -fno-PIE" >> ${HOSTCONF} + echo "#define ModuleAsCmd CcCmd -c -x assembler -fno-pie -fno-PIE" >> ${HOSTCONF} + fi + if ( [ -e "${ROOT}/usr/src/linux" ] \ + && ! kernel_is "2" "6" ) \ + || [ "$(uname -r | cut -d. -f1,2)" != "2.6" ]; then + # Commented out next two lines due to patch from bug #61940 + # Joshua Baergen, Sept 19, 2005 +# einfo "Building for kernels less than 2.6 requires special treatment." +# echo "#define UseDeprecatedKeyboardDriver YES" >> ${HOSTCONF} + einfo "Avoid bug #46593 for sparc32-SMP with kernel 2.4.xx." + echo "/* Add a line to avoid bug #56593 on sparc32 */" >> \ + programs/Xserver/hw/xfree86/drivers/ati/r128_driver.c + fi + fi + + # The definitions for fontconfig + echo "#define UseFontconfig YES" >> ${HOSTCONF} + echo "#define HasFontconfig YES" >> ${HOSTCONF} + + # Use the xorg Xft2 lib + echo "#define SharedLibXft YES" >> ${HOSTCONF} + + # with USE="X doc' circular dep w/ virtual/ghostscript + # echo "#define HasGhostScript ${DOC}" >> ${HOSTCONF} + # Caused issues, basic docs aren't installed + use_build doc BuildLinuxDocPS + use_build doc BuildSpecsDocs + use_build doc BuildHtmlManPages + use_build doc InstallHardcopyDocs + + # enable Japanese docs, optionally + use doc && use_build cjk InstallJapaneseDocs + + # Native Language Support Fonts + use_build nls BuildCyrillicFonts + use_build nls BuildArabicFonts + use_build nls BuildGreekFonts + use_build nls BuildHebrewFonts + use_build nls BuildThaiFonts + + if use nls; then + use_build cjk BuildCIDFonts + use_build cjk BuildJapaneseFonts + use_build cjk BuildKoreanFonts + use_build cjk BuildChineseFonts + fi + + # Crappy bitmap fonts + use_build bitmap-fonts Build75DpiFonts + use_build bitmap-fonts Build100DpiFonts + + # Type1 fonts + use_build type1-fonts BuildType1Fonts + + # TrueType fonts + use_build truetype-fonts BuildTrueTypeFonts + + # X Font Server + use_build font-server BuildFontServer + + # Distributed Multiheaded X + use_build dmx BuildDmx + + use_build insecure-drivers BuildDevelDRIDrivers + + if use ipv6; then + # In case Gentoo ever works on a system with IPv6 sockets that don't + # also listen on IPv4 (see config/cf/X11.tmpl) + echo "#define PreferXdmcpIPv6 YES" >> ${HOSTCONF} + fi + + use_build ipv6 BuildIPv6 + + if use minimal; then + # Don't build static libs + echo "#define ForceNormalLib NO" >> ${HOSTCONF} + # Turn back on needed ones + echo "#define NormalLibXau YES" >> ${HOSTCONF} + + echo "#define BuildDPSLibraries NO" >> ${HOSTCONF} + echo "#define BuildClients NO" >> ${HOSTCONF} + # BuildClients doesn't catch things in xc/programs/Xserver + # Also had to add + # 9250_all_6.8.1.904-respect-xfree86configtools-setting.patch + echo "#define BuildXFree86ConfigTools NO" >> ${HOSTCONF} + echo "#define BuildLBX NO" >> ${HOSTCONF} + + # Weird crap we don't need + echo "#define XF8_32Wid NO" >> ${HOSTCONF} + echo "#define XF8_32Bpp NO" >> ${HOSTCONF} + echo "#define XF8_16Bpp NO" >> ${HOSTCONF} + echo "#define XF24_32Bpp NO" >> ${HOSTCONF} + + # Without nls, truetype-fonts, type1-fonts, we only build misc + # Now let's try to reduce what gets built in misc + # iso8859-1 has the "fixed" font + echo "#define BuildISO8859_2Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_3Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_4Fonts NO" >> ${HOSTCONF} + # 5 is cyrillic, 6 isn't in misc, 7 is greek, 8 is hebrew + echo "#define BuildISO8859_9Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_10Fonts NO" >> ${HOSTCONF} + # 11 is thai, 12 isn't in misc + echo "#define BuildISO8859_13Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_14Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_15Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_16Fonts NO" >> ${HOSTCONF} + + echo "#define XnestServer NO" >> ${HOSTCONF} + echo "#define XVirtualFramebufferServer NO" >> ${HOSTCONF} + echo "#define XInputDrivers mouse keyboard" >> ${HOSTCONF} + + # If you want more drivers built with minimal, file a bug + # -Donnie Berkholz + if use x86; then + # Remove glint, tga, s3, s3virge, rendition, neomagic, i740, + # cirrus, tseng, trident, chips, apm, ark, cyrix, siliconmotion + # mga, nv, sis, tdfx, savage, GlideDriver, i386Drivers + # (nsc, i810), ati, DevelDrivers, via + # Leave vmware driver for testing minimal setups using VMWare + # XF86OSCardDrivers includes v4l and fbdev on linux + # DevelDrivers includes imstt and newport on x86 + echo "#define XF86CardDrivers vmware vesa vga dummy \ + XF86OSCardDrivers XF86ExtraCardDrivers" >> ${HOSTCONF} + # (#93339) + elif use sparc; then + echo "#define XF86CardDrivers vesa vga fbdev sunffb suncg6 \ + sunleo" >> ${HOSTCONF} + fi + fi + + # Ajax is the man for getting this going for us + echo "#define ProPoliceSupport YES" >> ${HOSTCONF} + + # Make xprint optional + use_build xprint BuildXprint + use_build xprint BuildXprintClients + # Build libXp even when xprint is off. It's just for clients, server + if ! use xprint; then + echo "#define BuildXprintLib YES" >> ${HOSTCONF} + fi + + # End the host.def definitions here + eend 0 +} + +patch_setup() { + einfo "Excluding patches..." + + # This patch is just plain broken. Results in random failures. + patch_exclude 0120*parallel-make + + # Hardened patches (both broken) + patch_exclude 9960_all_4.3.0-exec-shield-GNU + patch_exclude 9961_all_4.3.0-libGL-exec-shield + + # Xbox nvidia driver, patch is a total hack, tears apart xc/config/cf + # (#68726). Only apply when necessary so we don't screw other stuff up. + # 9990 is the driver, 9991 is xbox pci scanning (potentially useful) + if [ ! "${PROFILE_ARCH}" = "xbox" ]; then + patch_exclude 9990 9991 + fi + + # this patch comments out the Xserver line in xdm's config + # We only want it here + if ! use s390; then + patch_exclude 7500 + fi + + # if ! use gatos; then + # patch_exclude 9841_all_4.3.0-gatos-mesa + # fi + + if use debug; then + patch_exclude 5901*acecad-debug + fi + + # TDFX_RISKY - 16-bit, 1024x768 or higher on low-memory voodoo3's + if use 3dfx && [ "${TDFX_RISKY}" = "yes" ]; then + patch_exclude 5850 + else + patch_exclude 5851 + fi + + # Glibc-specific patches to exclude for non-glibc systems + if use elibc_FreeBSD || use elibc_OpenBSD; then + patch_exclude 0700 + fi + einfo "Done excluding patches." +} + +use_specific_hacks() { + # uclibc lacks sinf and cosf + if use uclibc; then + sed -i -e 's:GLXCLIENTDIRS = glxinfo glxgears:GLXCLIENTDIRS = :' \ + ${S}/programs/Imakefile + fi + + # Get rid of cursor sets other than core and handhelds, saves ~4MB + if use minimal; then + sed -i -e 's:SUBDIRS = redglass whiteglass handhelds:SUBDIRS = handhelds:' \ + ${S}/programs/xcursorgen/Imakefile + fi + + cd ${S} + if use doc; then + # These are not included anymore as they are obsolete + local x + for x in ${S}/programs/Xserver/hw/xfree86/{XF98Conf.cpp,XF98Config}; do + if [ -f ${x} ]; then + sed -i '/Load[[:space:]]*"\(pex5\|xie\)"/d' ${x} + fi + done + fi +} + +################# +# src_compile() # +################# + +build() { + # If a user defines the MAKE_OPTS variable in /etc/make.conf instead of + # MAKEOPTS, they'll redefine an internal xorg Makefile variable and the + # xorg build will silently die. This is tricky to track down, so I'm + # adding a preemptive fix for this issue by making sure that MAKE_OPTS is + # unset. (drobbins, 08 Mar 2003) + unset MAKE_OPTS + + einfo "Building xorg-x11..." + if use debug; then + chmod u+x ${S}/config/util/makeg.sh + FAST=1 ${S}/config/util/makeg.sh World WORLDOPTS="" MAKE="make" \ + || die "debug make World failed" + else + FAST=1 emake -j1 World WORLDOPTS="" MAKE="make" || die "make World failed" + fi + + if use nls; then + emake -j1 -C ${S}/nls MAKE="make" || die "nls build failed" + fi +} + +################# +# src_install() # +################# + +install_everything() { + unset MAKE_OPTS + + einfo "Installing X.org X11..." + # gcc3 related fix. Do this during install, so that our + # whole build will not be compiled without mmx instructions. + if [ "$(gcc-version)" != "2.95" ] && use x86; then + make install MAKE="make" DESTDIR=${D} \ + || make CDEBUGFLAGS="${CDEBUGFLAGS} -mno-mmx" \ + CXXDEBUGFLAGS="${CXXDEBUGFLAGS} -mno-mmx" \ + install MAKE="make" DESTDIR=${D} || die "install failed" + else + make install MAKE="make" DESTDIR=${D} || die "install failed" + fi + + if use sdk; then + einfo "Installing X.org X11 SDK..." + make install.sdk MAKE="make" DESTDIR=${D} || die "sdk install failed" + fi + + if ! use minimal; then + einfo "Installing man pages..." + make install.man MAKE="make" DESTDIR=${D} || die "man page install failed" + einfo "Compressing man pages..." + prepman /usr + fi + + if use nls; then + cd ${S}/nls + make MAKE="make" DESTDIR=${D} install || die "nls install failed" + fi + dodoc ${S}/RELNOTES +} + +backward_compat_install() { + # Backwards compatibility for /usr/share move + dosym ../../share/fonts /usr/$(get_libdir)/X11/fonts + + # Have the top-level libdir symlink made first, so real dirs don't get created + local DIR DIRS + if [ "lib" != "$(get_libdir)" ]; then + DIRS="${DIRS} $(get_libdir)" + fi + for DIR in ${DIRS}; do + dosym ../${DIR} /usr/X11R6/${DIR} + done + + dosym ../../../share/doc/${PF} /usr/X11R6/$(get_libdir)/X11/doc +} + +fix_permissions() { + # Fix permissions on locale/common/*.so + local x + for x in ${D}/usr/$(get_libdir)/X11/locale/$(get_libdir)/common/*.so*; do + if [ -f ${x} ]; then + fperms 0755 ${x/${D}} + fi + done + + # Fix permissions on modules ... + for x in $(find ${D}/usr/$(get_libdir)/modules -name '*.o' -o -name '*.so'); do + if [ -f ${x} ]; then + fperms 0755 ${x/${D}} + fi + done + + # Fix perms + if ! use minimal; then + fperms 755 /usr/$(get_libdir)/X11/xkb/geometry/sgi /usr/bin/dga + fi +} + +zap_host_def_cflags() { + ebegin "Fixing $(get_libdir)/X11/config/host.def" + cp ${D}/usr/$(get_libdir)/X11/config/host.def ${T} + awk '!/OptimizedCDebugFlags|OptimizedCplusplusDebugFlags|GccWarningOptions/ {print $0}' \ + ${T}/host.def > ${D}/usr/$(get_libdir)/X11/config/host.def \ + || eerror "Munging host.def failed" + # theoretically, /usr/lib/X11/config is a possible candidate for + # config file management. If we find that people really worry about imake + # stuff, we may add it. But for now, we leave the dir unprotected. + eend 0 +} + +add_euro_support() { + ebegin "Adding Euro support" + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ + ${D}/usr/bin/bdftopcf -t ${WORKDIR}/Xlat9-8x14.bdf | \ + gzip -9 > ${D}/usr/share/fonts/misc/Xlat9-8x14-lat9.pcf.gz + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ + ${D}/usr/bin/bdftopcf -t ${WORKDIR}/Xlat9-9x16.bdf | \ + gzip -9 > ${D}/usr/share/fonts/misc/Xlat9-9x16-lat9.pcf.gz + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ + ${D}/usr/bin/bdftopcf -t ${WORKDIR}/Xlat9-10x20.bdf | \ + gzip -9 > ${D}/usr/share/fonts/misc/Xlat9-10x20-lat9.pcf.gz + eend 0 +} + +setup_standard_symlinks() { + # Standard symlinks + dodir /usr/{bin,include,$(get_libdir)} + dosym ../bin /usr/bin/X11 + # Stop complains about "file or directory not existing" + dodir /usr/X11R6 + dosym ../include /usr/X11R6/include + dosym ../../usr/$(get_libdir)/X11/xkb /etc/X11/xkb + + # Some critical directories + if ! use minimal; then + keepdir /var/lib/xdm + dosym ../../../var/lib/xdm /etc/X11/xdm/authdir + fi + + # Backwards compat, FHS, etc. + dosym ../../usr/X11R6/bin/Xorg /etc/X11/X +} + +libtool_archive_install() { + if use opengl; then + # .la files for libtool support + insinto /usr/$(get_libdir) + # (#67729) Needs to be lib, not $(get_libdir) + doins ${FILES_DIR}/lib/*.la + fi +} + +fix_libtool_libdir_paths() { + local dirpath + for archive in ${*} ; do + dirpath=$(dirname ${archive} | sed -e "s:^${D}::") + [[ ${dirpath::1} == "/" ]] || dirpath="/"${dirpath} + sed -i ${archive} -e "s:^libdir.*:libdir=\'${dirpath}\':" + done +} + +compose_files_install() { + # Hack from Mandrake (update ours that just created Compose files for + # all locales) + local x + for x in $(find ${D}/usr/$(get_libdir)/X11/locale/ -mindepth 1 -type d); do + # make empty Compose files for some locales + # CJK must not have that file (otherwise XIM don't works some times) + case $(basename ${x}) in + C|microsoft-*|iso8859-*|koi8-*) + if [ ! -f ${x}/Compose ]; then + touch ${x}/Compose + fi + ;; + ja*|ko*|zh*) + if [ -r ${x}/Compose ]; then + rm -f ${x}/Compose + fi + ;; + esac + done + + # Another hack from Mandrake -- to fix dead + space for the us + # international keyboard + local i + for i in ${D}/usr/$(get_libdir)/X11/locale/*/Compose; do + sed -i \ + -e 's/\( \).*$/\1 : "\\"" quotedbl/' \ + -e "s/\( \).*$/\1 : \"'\" apostrophe/" ${i} \ + || eerror "sed ${i} failed" + done +} + +encode_xfsft_files() { + # Yet more Mandrake + ebegin "Encoding files for xfsft font server" + dodir /usr/share/fonts/encodings + cp -pPR ${WORKDIR}/usr/share/fonts/encodings/* \ + ${D}/usr/share/fonts/encodings + + for x in ${D}/usr/share/fonts/encodings/{.,large}/*.enc; do + if [ -f "${x}" ]; then + gzip -9 -f ${x} \ + || eerror "gzipping ${x} failed" + fi + done + eend 0 +} + +koi8_fonts_install() { + ebegin "Adding gemini-koi8 fonts" + cd ${WORKDIR}/ukr + gunzip *.Z || eerror "gunzipping gemini-koi8 fonts failed" + gzip -9 *.pcf || eerror "gzipping gemini-koi8 fonts failed" + cd ${S} + cp -pPR ${WORKDIR}/ukr ${D}/usr/share/fonts \ + || eerror "copying gemini-koi8 fonts failed" + eend 0 +} + +etc_files_install() { + insinto /etc/X11 + + # Install example config file + newins ${S}/programs/Xserver/hw/xfree86/xorg.conf xorg.conf.example + + exeinto /etc/X11 + # new session management script + doexe ${FILES_DIR}/chooser.sh + # new display manager script + doexe ${FILES_DIR}/startDM.sh + exeinto /etc/X11/Sessions + # doexe skips directories, so this should be safe + doexe ${FILES_DIR}/Sessions/* + insinto /etc/env.d + doins ${FILES_DIR}/10xorg + insinto /etc/X11/xinit + doins ${FILES_DIR}/xinitrc + if ! use minimal; then + exeinto /etc/X11/xdm + doexe ${FILES_DIR}/Xsession + exeinto /etc/init.d + newexe ${FILES_DIR}/xdm.start xdm + fi + if use font-server; then + insinto /etc/X11/fs + newins ${FILES_DIR}/xfs.config config + fi + if use pam; then + insinto /etc/pam.d + newins ${FILES_DIR}/xdm.pamd xdm + # Need to fix console permissions first + newins ${FILES_DIR}/xserver.pamd xserver + fi + if use font-server; then + newexe ${FILES_DIR}/xfs.start xfs + insinto /etc/conf.d + newins ${FILES_DIR}/xfs.conf.d xfs + fi +} + +dynamic_libgl_install() { + # next section is to setup the dynamic libGL stuff + ebegin "Moving libGL and friends for dynamic switching" + dodir /usr/$(get_libdir)/opengl/${PN}/{lib,extensions,include} + local x="" + for x in ${D}/usr/$(get_libdir)/libGL.so* \ + ${D}/usr/$(get_libdir)/libGL.la \ + ${D}/usr/$(get_libdir)/libGL.a; do + if [ -f ${x} -o -L ${x} ]; then + # libGL.a cause problems with tuxracer, etc + mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/lib + fi + done + for x in ${D}/usr/$(get_libdir)/modules/extensions/libglx*; do + if [ -f ${x} -o -L ${x} ]; then + mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/extensions + fi + done + # glext.h added for #54984 + for x in ${D}/usr/include/GL/{gl.h,glx.h,glxtokens.h,glext.h,glxext.h,glxmd.h,glxproto.h}; do + if [ -f ${x} -o -L ${x} ]; then + mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/include + fi + done + eend 0 +} + +cursor_install() { + # Make the core cursor the default. People seem not to like whiteglass + # for some reason. + dosed 's:whiteglass:core:' /usr/share/cursors/${PN}/default/index.theme + + if ! use minimal; then + install_extra_cursors + fi +} + +strip_execs() { + if use debug || has nostrip ${FEATURES}; then + ewarn "Debug build turned on by USE=debug or FEATURES=nostrip" + ewarn "NOT stripping binaries and libraries" + else + local STRIP + if [ ! -z "${CBUILD}" ] && [ "${CBUILD}" != "${CHOST}" ]; then + STRIP=${CHOST}-strip + else + STRIP=strip + fi + einfo "Stripping binaries and libraries..." + # This bit I got from Redhat ... strip binaries and drivers .. + # NOTE: We do NOT want to strip the drivers, modules or DRI modules! + local x + for x in $(find ${D}/ -type f -perm +0111 -exec file {} \; | \ + grep -v ' shared object,' | \ + sed -n -e 's/^\(.*\):[ ]*ELF.*, not stripped/\1/p'); do + if [ -f ${x} ]; then + # Dont do the modules ... + if [ "${x/\/usr\/$(get_libdir)\/modules}" = "${x}" ]; then + echo "$(echo ${x/${D}})" + ${STRIP} ${x} || : + fi + fi + done + # Now do the libraries ... + for x in ${D}/usr/{$(get_libdir),$(get_libdir)/opengl/${PN}/lib}/*.so.* \ + $(get_libdir)/X11/locale/$(get_libdir)/common}/*.so.*; do + if [ -f ${x} ]; then + echo "$(echo ${x/${D}})" + ${STRIP} --strip-debug ${x} || : + fi + done + fi +} + +install_extra_cursors() { + # Install TaD's gentoo cursors + insinto /usr/share/cursors/${PN}/gentoo/cursors + doins ${WORKDIR}/cursors/gentoo/cursors/* + insinto /usr/share/cursors/${PN}/gentoo-blue/cursors + doins ${WORKDIR}/cursors/gentoo-blue/cursors/* + insinto /usr/share/cursors/${PN}/gentoo-silver/cursors + doins ${WORKDIR}/cursors/gentoo-silver/cursors/* +} + +minimal_install() { + # Get rid of all unnecessary fonts (saves ~5.5 MB) + find ${D}/usr/share/fonts/misc/ -name '*.pcf.gz' \ + -not -name '*6x13*' -not -name 'cursor.pcf.gz' -exec rm {} \; + # Woohoo, another 772K + rm -rf ${D}/usr/share/doc +} + +xprint_install() { + # If we want xprint, save the init script before deleting /etc/rc.d/ + # Requested on #68316 + if use xprint; then + xprint_init_install + else + # delete xprint stuff + rm -f ${D}/etc/{init,profile}.d/xprint* + rmdir --ignore-fail-on-non-empty ${D}/etc/{init,profile}.d + fi + + # Remove the /etc/rc.d nonsense -- not everyone is RedHat + rm -rf ${D}/etc/rc.d +} + +xprint_init_install() { + # RH-style init script, we provide a wrapper + exeinto /usr/$(get_libdir)/misc + doexe ${D}/etc/init.d/xprint + rm -f ${D}/etc/init.d/xprint + # Install the wrapper + newinitd ${FILES_DIR}/xprint.init xprint + # patch profile scripts + sed -i -e "s:/bin/sh.*get_xpserverlist:/usr/$(get_libdir)/misc/xprint get_xpserverlist:g" ${D}/etc/profile.d/xprint* + # move profile scripts, we can't touch /etc/profile.d/ in Gentoo + dodoc ${D}/etc/profile.d/xprint* + rm -f ${D}/etc/profile.d/xprint* +} + +config_files_install() { + + # Fix default config files after installing fonts to /usr/share/fonts + sed -i -e "s:/usr/X11R6/$(get_libdir)/X11/fonts:/usr/share/fonts:g" \ + -e "s:/usr/$(get_libdir)/X11/fonts:/usr/share/fonts:g" \ + -e "s:/usr/$(get_libdir)/fonts:/usr/share/fonts:g" \ + ${D}/etc/X11/xorg.conf.example + if use font-server; then + sed -i "s:/usr/X11R6/$(get_libdir)/X11/fonts:/usr/share/fonts:g" \ + ${D}/etc/X11/fs/config + fi + + # Work around upgrade problem where people have + # Option "XkbRules" "xfree86" in their config file + sed -i "s:^.*Option.*"XkbRules".*$::g" ${D}/etc/X11/xorg.conf.example +} + +fix_opengl_symlinks() { + # Remove invalid symlinks + local LINK + for LINK in $(find ${D}/usr/$(get_libdir) \ + -name libGL.* -type l); do + rm -f ${LINK} + done + # Create required symlinks + dosym libGL.so.1.2 /usr/$(get_libdir)/libGL.so + dosym libGL.so.1.2 /usr/$(get_libdir)/libGL.so.1 +} + +################# +# pkg_preinst() # +################# + +# We need a symlink /usr/X11R6/dir -> /usr/dir so all the packages +# whose files we move don't lose track of them. As such, we need +# _absolutely nothing_ in /usr/X11R6/dir so we can make such a symlink. +# Donnie Berkholz 20 October 2004 +# +# Takes two arguments -- starting location and ending location +migrate() { + einfo "Migrating from ${1} to ${2}..." + + # Strip trailing slash + if [ -z "${1##*/}" ]; then + set -- ${1%/} ${2} + fi + + if [ -e ${ROOT}${1} ]; then + # If it's not a symlink (in other words, it should be a directory) + if [ ! -L ${ROOT}${1} ]; then + einfo " ${1} isn't a symlink, migrating..." + # Move everything + rsync \ + --archive \ + --update \ + --links \ + --hard-links \ + --ignore-existing \ + --stats \ + --progress \ + --verbose \ + ${ROOT}${1}/ ${ROOT}${2} > ${T}/migrate-${1//\//-}.log 2>&1 + + check_migrate_return + remove_migrated_files ${1} + + if [ -e "${ROOT}${1}" ]; then + # Remove any floating .keep files so we can run rmdir + find ${ROOT}${1} -name '\.keep' -exec rm -f {} \; + # Get rid of the directory + rmdir ${ROOT}${1} + fi + + make_symlinks ${1} + else + ewarn " ${1} is a symlink, not migrating" + fi + else + ewarn " ${1} doesn't exist, not migrating" + make_symlinks ${1} + fi +} + +check_migrate_return() { + MIGRATE_RETURN="$?" + if [ "${MIGRATE_RETURN}" -eq "0" ]; then + einfo "rsync successful!" + else + eerror "rsync failed." + eerror "Check for migrate-* files in ${T}." + die "rsync failed. Exit code: ${MIGRATE_RETURN}." + fi + + # Migration fubars lib symlinks -- eradicator + if use amd64; then + if [[ -L ${ROOT}usr/lib64 ]]; then + rm ${ROOT}usr/lib64 + ln -s lib ${ROOT}usr/lib64 + elif [[ -L ${ROOT}usr/lib ]]; then + rm -f ${ROOT}usr/lib + ln -s lib64 ${ROOT}usr/lib + elif [[ -L ${ROOT}usr/lib32 ]]; then + if has_multilib_profile; then + ln -s lib ${ROOT}usr/lib32 + else + ln -s ../emul/linux/x86/usr/lib ${ROOT}usr/lib32 + fi + fi + fi +} + +remove_migrated_files() { + # This is a copy instead of a move, so we need to get rid of what + # we copied. This is a little risky if it fails, so just do it on + # success. + + # DO NOT proceed if we don't have an argument, or we kill root filesystem + if [ -z "${1}" ]; then + die "No argument to remove_migrated_files(). Want to `rm -rf ${ROOT}`?" + fi + + if [ "${MIGRATE_RETURN}" -eq "0" ]; then +# rm -rfv ${ROOT}${1} > ${T}/migrate-remove-${1//\//-}.log 2>&1 + rm -rfv ${ROOT}${1} + fi +} + +make_symlinks() { + # Put a symlink in its place + + # Special case: lib != libdir + if [ "${1##*/}" = "$(get_libdir)" -a "$(get_libdir)" != "lib" ]; then + einfo " Symlinking ${ROOT}usr/X11R6/lib -> $(get_libdir)" + ln -s $(get_libdir) ${ROOT}usr/X11R6/lib + # Special case: fonts + elif [ "${1##*/}" = "fonts" ]; then + einfo " Symlinking ${ROOT}${1} -> ../../share/fonts" + ln -s ../../share/fonts ${ROOT}${1} + # Special case: X11R6 + elif [ "${1##*/}" = "X11R6" ]; then + einfo " Symlinking ${ROOT}${1} -> ../usr" + ln -s ../usr ${ROOT}${1} + else + einfo " Symlinking ${ROOT}${1} -> ../${1##*/}" + ln -s ../${1##*/} ${ROOT}${1} + fi +} + +update_config_files() { + # Fix any installed config files for installing fonts to /usr/share/fonts + # This *needs* to be after all other installation so files aren't + # overwritten. + + if [ "${ROOT}" = "/" ]; then + einfo "Preparing any installed configuration files for font move..." + FILES="/etc/X11/xorg.conf + /etc/X11/XF86Config-4 + /etc/X11/XF86Config" + if use font-server; then + FILES="${FILES} /etc/X11/fs/config" + fi + # /etc/fonts/fonts.conf + # /etc/fonts/local.conf + + local FILE + for FILE in ${FILES}; do + if [ -e ${FILE} ]; then + # New font paths + sed "s,/usr/X11R6/$(get_libdir)/X11/fonts,/usr/share/fonts,g" \ + ${ROOT}${FILE} > ${IMAGE}${FILE} + + if [ "${FILE}" = "/etc/X11/xorg.conf" ] \ + || [ "${FILE}" = "/etc/X11/XF86Config" ] \ + || [ "${FILE}" = "/etc/X11/XF86Config-4" ]; then + # "keyboard" driver is deprecated and will be removed, + # switch to "kbd" + sed -i 's~^\([ \t]*Driver[ \t]\+\)"[kK]eyboard"~\1"kbd"~' \ + ${IMAGE}${FILE} + + # This moved in the /usr/X11R6/libdir -> /usr/libdir change + sed -i \ + -e 's~^\([ \t]*RgbPath[ \t]\+\)"/usr/X11R6/$(get_libdir)/X11/rgb"~\1"/usr/$(get_libdir)/X11/rgb"~' \ + -e 's~^\([ \t]*RgbPath[ \t]\+\)"/usr/X11R6/lib/X11/rgb"~\1"/usr/lib/X11/rgb"~' \ + ${IMAGE}${FILE} + + # Work around upgrade problem where people have + # Option "XkbRules" "xfree86" in their config file + sed -i "s:^.*Option.*\"XkbRules\".*$::g" \ + ${IMAGE}${FILE} + fi + fi + done + fi +} + +cleanup_fonts() { + local G_FONTDIRS + G_FONTDIRS="Speedo encodings local misc util" + if use truetype-fonts; then + G_FONTDIRS="${G_FONTDIRS} TTF" + fi + if use type1-fonts; then + G_FONTDIRS="${G_FONTDIRS} Type1" + fi + if use cjk; then + G_FONTDIRS="${G_FONTDIRS} CID" + fi + if use bitmap-fonts; then + G_FONTDIRS="${G_FONTDIRS} 75dpi 100dpi" + fi + if use nls; then + G_FONTDIRS="${G_FONTDIRS} cyrillic ukr" + fi + + for G_FONTDIR in ${G_FONTDIRS}; do + # clean out old fonts.* and encodings.dir files, as we + # will regenerate them + # Not Speedo or CID, as their fonts.scale files are "real" + if [ "${G_FONTDIR}" != "CID" -a "${G_FONTDIR}" != "Speedo" ]; then + find ${ROOT}/usr/share/fonts/${G_FONTDIR} -type f -name 'fonts.*' \ + -o -name 'encodings.dir' -exec rm -fv {} \; + fi + done + + # Get rid of deprecated directories so our symlinks in the same location + # work -- users shouldn't be placing fonts here so that should be fine, + # they should be using ~/.fonts or /usr/share/fonts. + remove_font_dirs +} + +remove_font_dirs() { + if [ -e ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts ]; then + if [ ! -L ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts ]; then + local G_FONTDIR + for G_FONTDIR in ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/*; do + if [ -L "${G_FONTDIR}" ]; then + einfo "Removing ${G_FONTDIR} symlink." + rm -rfv ${G_FONTDIR} + else + ewarn "${G_FONTDIR} not a symlink, moving to /usr/share/fonts" + if [ -d ${G_FONTDIR} ]; then + if [ ! -e /usr/share/fonts/${G_FONTDIR##*/} ]; then + einfo "Moving ${G_FONTDIR} to /usr/share/fonts/." + mv ${G_FONTDIR} /usr/share/fonts/ + else + ewarn "/usr/share/fonts/${G_FONTDIR##*/} exists. Remove it and try again." + fi + else + ewarn "${G_FONTDIR} does not exist." + fi + fi + done + fi + else + ewarn "${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts does not exist." + fi +} + +move_app_defaults_to_etc() { + if [ -L ${ROOT}/etc/X11/app-defaults ]; then + rm -f ${ROOT}/etc/X11/app-defaults + fi + + if [ ! -L ${ROOT}/usr/$(get_libdir)/app-defaults ] \ + && [ -d ${ROOT}/usr/$(get_libdir)/app-defaults ]; then + if [ ! -d ${ROOT}/etc/X11/app-defaults ]; then + mkdir -p ${ROOT}/etc/X11/app-defaults + fi + + mv -f ${ROOT}/usr/$(get_libdir)/app-defaults ${ROOT}/etc/X11 + fi +} + +move_xkb_to_usr() { + if [ -L ${ROOT}/usr/$(get_libdir)/xkb ]; then + rm -f ${ROOT}/usr/$(get_libdir)/xkb + fi + + if [ ! -L ${ROOT}/etc/X11/xkb ] \ + && [ -d ${ROOT}/etc/X11/xkb ]; then + if [ ! -d ${ROOT}/usr/$(get_libdir)/xkb ]; then + mkdir -p ${ROOT}/usr/$(get_libdir) + fi + + mv -f ${ROOT}/etc/X11/xkb ${ROOT}/usr/$(get_libdir) + fi +} + +dynamic_libgl_preinst() { + # clean the dynamic libGL stuff's home to ensure + # we don't have stale libs floating around + if [ -d ${ROOT}/usr/$(get_libdir)/opengl/${PN} ]; then + rm -rf ${ROOT}/usr/$(get_libdir)/opengl/${PN}/* + fi + + # make sure we do not have any stale files lying around + # that could break things. Check old and new locations. + rm -f ${ROOT}/usr/X11R6/$(get_libdir)/libGL\.* \ + ${ROOT}/usr/$(get_libdir)/libGL\.* +} + +################## +# pkg_postinst() # +################## + +font_setup() { + umask 022 + + # These cause ttmkfdir to segfault :/ + rm -f ${ROOT}/usr/share/fonts/encodings/iso8859-6.8x.enc.gz + rm -f ${ROOT}/usr/share/fonts/encodings/iso8859-6.16.enc.gz +# rm -f ${ROOT}/usr/share/fonts/encodings/large/cns11643-1.enc +# rm -f ${ROOT}/usr/share/fonts/encodings/large/cns11643-2.enc +# rm -f ${ROOT}/usr/share/fonts/encodings/large/cns11643-3.enc +# rm -f ${ROOT}/usr/share/fonts/encodings/suneu-greek.enc + + # ******************************************************************** + # A note about fonts and needed files: + # + # 1) Create /usr/share/fonts/encodings/encodings.dir + # + # 2) Create fonts.scale for TrueType fonts (need to do this before + # we create fonts.dir files, else fonts.dir files will be + # invalid for TrueType fonts...) + # + # 3) Now Generate fonts.dir files. + # + # CID fonts is a bit more involved, but as we do not install any, + # thus I am not going to bother. + # + # (20 Oct 2002) + # + # ******************************************************************** + + ebegin "Generating encodings.dir" + # Create the encodings.dir in /usr/share/fonts/encodings + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontdir -n \ + -e ${ROOT}/usr/share/fonts/encodings \ + -e ${ROOT}/usr/share/fonts/encodings/large \ + -- ${ROOT}/usr/share/fonts/encodings + + eend 0 + + ebegin "Creating fonts.scale files" + local x + for x in $(find ${ROOT}/usr/share/fonts/* -maxdepth 1 -type d); do + [ -z "$(ls ${x}/)" ] && continue + [ "$(ls ${x}/)" = "fonts.cache-1" ] && continue + + # Only generate .scale files if truetype, opentype or type1 + # fonts are present ... + + # First truetype (ttf,ttc) + # NOTE: ttmkfdir does NOT work on type1 fonts (#53753) + # Also, there is no way to regenerate Speedo/CID fonts.scale + # 2 August 2004 + if [ "${x/encodings}" = "${x}" -a \ + -n "$(find ${x} -iname '*.tt[cf]' -print)" ]; then + if [ -x ${ROOT}/usr/bin/ttmkfdir ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/ttmkfdir -x 2 \ + -e ${ROOT}/usr/share/fonts/encodings/encodings.dir \ + -o ${x}/fonts.scale -d ${x} + # ttmkfdir fails on some stuff, so try mkfontscale if it does + local ttmkfdir_return=$? + else + # We didn't use ttmkfdir at all + local ttmkfdir_return=2 + fi + if [ ${ttmkfdir_return} -ne 0 ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontscale \ + -a /usr/share/fonts/encodings/encodings.dir \ + -- ${x} + fi + # Next type1 and opentype (pfa,pfb,otf,otc) + elif [ "${x/encodings}" = "${x}" -a \ + -n "$(find ${x} -iname '*.[po][ft][abcf]' -print)" ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontscale \ + -a ${ROOT}/usr/share/fonts/encodings/encodings.dir \ + -- ${x} + fi + done + eend 0 + + ebegin "Generating fonts.dir files" + for x in $(find ${ROOT}/usr/share/fonts/* -maxdepth 1 -type d); do + [ -z "$(ls ${x}/)" ] && continue + [ "$(ls ${x}/)" = "fonts.cache-1" ] && continue + + if [ "${x/encodings}" = "${x}" ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontdir \ + -e ${ROOT}/usr/share/fonts/encodings \ + -e ${ROOT}/usr/share/fonts/encodings/large \ + -- ${x} + fi + done + eend 0 + + ebegin "Generating Xft cache" + for x in $(find ${ROOT}/usr/share/fonts/* -maxdepth 1 -type d); do + [ -z "$(ls ${x}/)" ] && continue + [ "$(ls ${x}/)" = "fonts.cache-1" ] && continue + + # Only generate XftCache files if there are truetype + # fonts present ... + if [ "${x/encodings}" = "${x}" -a \ + -n "$(find ${x} -iname '*.[otps][pft][cfad]' -print)" ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/xftcache ${x} &> /dev/null + fi + done + eend 0 + + ebegin "Fixing permissions" + find ${ROOT}/usr/share/fonts/ -type f -name 'font.*' \ + -exec chmod 0644 {} \; + eend 0 + + # danarmak found out that fc-cache should be run AFTER all the above + # stuff, as otherwise the cache is invalid, and has to be run again + # as root anyway + if [ -x ${ROOT}/usr/bin/fc-cache ]; then + ebegin "Creating FC font cache" + HOME="/root" ${ROOT}/usr/bin/fc-cache + eend 0 + fi +} + +switch_opengl_implem() { + # Switch to the xorg implementation. + # Use new opengl-update that will not reset user selected + # OpenGL interface ... + echo + local opengl_implem="$(${ROOT}/usr/sbin/opengl-update --get-implementation)" + ${ROOT}/usr/sbin/opengl-update --use-old ${PN} +} + +remove_old_compose_files() { + for x in $(find ${ROOT}/usr/$(get_libdir)/X11/locale/ -mindepth 1 -type d); do + # Remove old compose files we might have created incorrectly + # CJK must not have that file (otherwise XIM don't works some times) + case $(basename ${x}) in + ja*|ko*|zh*) + if [ -r "${x}/Compose" ]; then + rm -f ${x}/Compose + fi + ;; + esac + done +} + +setup_tmp_files() { + # These need to be owned by root and the correct permissions + # (bug #8281) + local x="" + for x in ${ROOT}/tmp/.{ICE,X11}-unix; do + if [ ! -d ${x} ]; then + mkdir -p ${x} + fi + + chown root:wheel ${x} + chmod 1777 ${x} + done +} + +print_info() { + echo + einfo "Please note that the xcursors are in /usr/share/cursors/${PN}." + einfo "Any custom cursor sets should be placed in that directory." + echo + einfo "If you wish to set system-wide default cursors, please create" + einfo "/usr/local/share/cursors/${PN}/default/index.theme" + einfo "with content: \"Inherits=theme_name\" so that future" + einfo "emerges will not overwrite those settings." + echo + einfo "Listening on TCP is disabled by default with startx." + einfo "To enable it, edit /usr/bin/startx." + echo + + echo + ewarn "BEWARE:" + ewarn "/usr/X11R6/$(get_libdir) has MOVED" + ewarn "to /usr/$(get_libdir)" + ewarn "Run etc-update to update your config files." + ewarn "Old locations for anything in /usr/X11R6/$(get_libdir)" + ewarn "are deprecated." + echo + # (#76985) + einfo "Visit http://www.gentoo.org/doc/en/index.xml?catid=desktop" + einfo "for more information on configuring X." + + # Try to get people to read /usr/X11R6/libdir move + ebeep 5 + epause 10 +} + +fix_links() { + # Fix problematic links + if [ -x ${ROOT}/usr/bin/Xorg ]; then + ln -snf ../bin ${ROOT}/usr/bin/X11 + fi +} diff --git a/x11-base/xorg-x11/xorg-x11-6.9.0-r2.ebuild b/x11-base/xorg-x11/xorg-x11-6.9.0-r2.ebuild new file mode 100644 index 000000000000..492a8814d24f --- /dev/null +++ b/x11-base/xorg-x11/xorg-x11-6.9.0-r2.ebuild @@ -0,0 +1,1793 @@ +# Copyright 1999-2006 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/x11-base/xorg-x11/xorg-x11-6.9.0-r2.ebuild,v 1.1 2006/06/20 20:00:51 spyderous Exp $ + +# Set TDFX_RISKY to "yes" to get 16-bit, 1024x768 or higher on low-memory +# voodoo3 cards. + +# Libraries which are now supplied in shared form that were not in the past +# include: libFS.so, libGLw.so, libI810XvMC.so, libXRes.so, libXfontcache.so, +# libXinerama.so, libXss.so, libXvMC.so, libXxf86rush.so, libfontenc.so, +# libxkbfile.so, libxkbui.so + +# TODO +# 1 June 2005 +# TARGET: none +# Consider building shared libraries only, when both are provided +# Combine find loops for "Creating fonts.scale files," "Generating +# fonts.dir files and "Generating Xft cache" +# the loop in pkg_postinst for removing Compose can probably +# be one line of bash expansion like rm -f ${ROOT}/usr/$(get_libdir)/ +# X11/locale/{ja*|ko*|zh*}/Compose +# Clean up migration function +# - loop through lib* instead of repetition +# Fix direction of lib -> libdir symlink +# Generalize any functions that make sense to generalize (i.e., anything +# that might realistically see use elsewhere, or repetitively here) +inherit eutils flag-o-matic toolchain-funcs x11 linux-info multilib + + +# Make sure Portage does _NOT_ strip symbols. We will do it later and make sure +# that only we only strip stuff that are safe to strip ... +RESTRICT="nostrip" + +# IUSE="gatos" disabled because gatos is broken on ~4.4 now (31 Jan 2004) +IUSE="3dfx bitmap-fonts cjk debug doc font-server insecure-drivers ipv6 minimal + nls nocxx opengl pam sdk static truetype-fonts type1-fonts uclibc xprint xv" +# IUSE_INPUT_DEVICES="synaptics wacom" + +FILES_VER="0.1" +PATCH_VER="0.1.1" +XCUR_VER="0.3.1" +XFSFT_ENC_VER="0.1" + +S=${WORKDIR}/xc + +HOMEPAGE="http://xorg.freedesktop.org/" + +# Misc patches we may need to fetch .. +X_PATCHES="http://dev.gentoo.org/~spyderous/${PN}/patchsets/${PV}/${P}-patches-${PATCH_VER}.tar.bz2 + http://dev.gentoo.org/~joshuabaergen/distfiles/${P}-patches-${PATCH_VER}.tar.bz2 + mirror://gentoo/${P}-patches-${PATCH_VER}.tar.bz2" + +GENTOO_FILES="http://dev.gentoo.org/~spyderous/${PN}/patchsets/${PV}/${P}-files-${FILES_VER}.tar.bz2 + http://dev.gentoo.org/~cyfred/distfiles/${P}-files-${FILES_VER}.tar.bz2 + mirror://gentoo/${P}-files-${FILES_VER}.tar.bz2" + +SRC_URI="!minimal? ( mirror://gentoo/eurofonts-X11.tar.bz2 ) + font-server? ( http://dev.gentoo.org/~cyfred/xorg/${PN}/patchsets/${PV}/xfsft-encodings-${XFSFT_ENC_VER}.tar.bz2 ) + !minimal? ( mirror://gentoo/gentoo-cursors-tad-${XCUR_VER}.tar.bz2 ) + nls? ( mirror://gentoo/gemini-koi8-u.tar.bz2 ) + ${GENTOO_FILES} + ${X_PATCHES} + http://xorg.freedesktop.org/releases/X11R${PV}/src-single/X11R${PV}-src.tar.bz2" + +LICENSE="Adobe-X CID DEC DEC-2 IBM-X NVIDIA-X NetBSD SGI UCB-LBL XC-2 + bigelow-holmes-urw-gmbh-luxi christopher-g-demetriou national-semiconductor + nokia tektronix the-open-group todd-c-miller x-truetype xfree86-1.0 + MIT SGI-B BSD || ( FTL GPL-2 )" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86" + +DEPEND=">=sys-libs/ncurses-5.1 + >=sys-libs/zlib-1.1.3-r2 + >=sys-devel/flex-2.5.4a-r5 + sys-apps/groff + >=dev-libs/expat-1.95.3 + >=media-libs/freetype-2.1.8 + >=media-libs/fontconfig-2.1-r1 + opengl? ( >=x11-base/opengl-update-2.2.0 ) + !nocxx? ( >=x11-apps/ttmkfdir-3.0.9-r2 ) + >=sys-apps/sed-4 + userland_GNU? ( sys-apps/util-linux ) + dev-lang/perl + media-libs/libpng + !<=app-emulation/emul-linux-x86-xlibs-1.2-r3" +# FBSDTODO: need to check that X is not pulled in before freebsd-ubin for 'col' presence + +RDEPEND=" + >=sys-libs/zlib-1.1.3-r2 + >=sys-devel/flex-2.5.4a-r5 + >=dev-libs/expat-1.95.3 + >=media-libs/freetype-2.1.8 + >=media-libs/fontconfig-2.1-r1 + opengl? ( >=x11-base/opengl-update-2.2.0 ) + !nocxx? ( >=x11-apps/ttmkfdir-3.0.9-r2 ) + media-libs/libpng + >=sys-libs/ncurses-5.1 + !<=app-emulation/emul-linux-x86-xlibs-1.2-r3" + +PDEPEND="x86? ( + input_devices_synaptics? ( x11-drivers/synaptics ) + input_devices_wacom? ( x11-misc/linuxwacom ) + ) + 3dfx? ( >=media-libs/glide-v3-3.10 ) + x11-terms/xterm" + +PROVIDE="virtual/x11 + opengl? ( virtual/opengl + virtual/glu ) + virtual/xft" + +DESCRIPTION="An X11 implementation maintained by the X.Org Foundation" + +pkg_setup() { + FILES_DIR="${WORKDIR}/files" + PATCHDIR="${WORKDIR}/patch" + EXCLUDED="${PATCHDIR}/excluded" + + # Set up CFLAG-related things + cflag_setup + + # See bug #35468, circular pam-X11 dep + check_pam + + # Look for invalid/dangerous USE flags and combinations + check_use_combos + + setup_multilib + + # xfs user + if use font-server; then + enewgroup xfs 33 + enewuser xfs 33 -1 /etc/X11/fs xfs + fi +} + +src_unpack() { + unpack_all + + patch_setup + + do_patch + + host_def_setup + + use_specific_hacks +} + +src_compile() { + build +} + +src_install() { + install_everything + + backward_compat_install + + fix_permissions + + # We zap our CFLAGS in the host.def file, as hardcoded CFLAGS can + # mess up other things that use xmkmf + zap_host_def_cflags + + # EURO support + if ! use minimal; then + add_euro_support + fi + + setup_standard_symlinks + + if use opengl; then + fix_opengl_symlinks + fi + + libtool_archive_install + + compose_files_install + + if use font-server; then + encode_xfsft_files + fi + + if use nls; then + koi8_fonts_install + fi + + etc_files_install + + if use opengl; then + dynamic_libgl_install + fi + + fix_libtool_libdir_paths "$(find ${D} -name *.la)" + + cursor_install + + strip_execs + + if use minimal; then + minimal_install + fi + + # TEMPORARY hack: should be patched in, if it's not already + # For Battoussai's gatos stuffs: + if use sdk; then + insinto /usr/$(get_libdir)/Server/include + doins ${S}/extras/drm/shared/drm.h + fi + + xprint_install + + config_files_install +} + +pkg_preinst() { + # Do migration before anything else, so we do all the rest inside the + # symlink + + # Get rid of "standard" symlinks + # We can't overwrite symlink with directory w/ $(mv -f) + [ -L ${ROOT}usr/$(get_libdir)/X11 ] \ + && rm ${ROOT}usr/$(get_libdir)/X11 + [ -L ${ROOT}usr/include/X11 ] \ + && rm ${ROOT}usr/include/X11 + [ -L ${ROOT}usr/include/GL ] \ + && rm ${ROOT}usr/include/GL + [ -L ${ROOT}usr/bin/X11 ] \ + && rm ${ROOT}usr/bin/X11 + # Get rid of some apparent artifacts of migration + [ -L ${ROOT}usr/include/GL/GL ] \ + && rm ${ROOT}usr/include/GL/GL + [ -L ${ROOT}usr/include/X11/X11 ] \ + && rm ${ROOT}usr/include/X11/X11 + [ -d ${ROOT}usr/share/fonts/fonts ] \ + && rm -rf ${ROOT}usr/share/fonts/fonts + + # No need to do this, if it's already been done + # Also, it'll overwrite a ton of stuff because it won't realize /usr/X11R6 + # is a symlink. + if [ ! -L "/usr/X11R6" ]; then + # Migrate stuff in /usr/X11R6 to /usr + local DIR DIRS + DIRS="bin include lib" + if [ "lib" != "$(get_libdir)" ]; then + DIRS="${DIRS} $(get_libdir)" + fi + for DIR in ${DIRS}; do + migrate /usr/X11R6/${DIR} /usr/${DIR} + done + # Can't do this in the other loop because of different start and end + migrate /usr/X11R6/man /usr/share/man + fi + + update_config_files + + cleanup_fonts + + # See above comment for the same test + if [ ! -L "/usr/X11R6" ]; then + # Needs to happen after cleanup_fonts() + migrate /usr/X11R6/$(get_libdir)/X11/fonts /usr/share/fonts + + # Get rid of symlinks so we can migrate /usr/X11R6 without dying when a + # symlink tries to copy to a dir + einfo "Preparing for /usr/X11R6 -> /usr migration..." + local LINK LINKS + LINKS="bin include lib man share/info" + if [ "lib" != "$(get_libdir)" ]; then + LINKS="${LINKS} $(get_libdir)" + fi + for LINK in ${LINKS}; do + if [ -L "${ROOT}/usr/X11R6/${LINK}" ]; then + rm -fv ${ROOT}/usr/X11R6/${LINK} + fi + done + einfo "Remaining symlinks in /usr/X11R6:" + find ${ROOT}/usr/X11R6/ -type l + + # Woohoo, nothing in /usr/X11R6 after this + migrate /usr/X11R6 /usr + fi + + move_app_defaults_to_etc + + move_xkb_to_usr + + # Run this even for USE=-opengl, to clean out old stuff from possible + # USE=opengl build + dynamic_libgl_preinst +} + +pkg_postinst() { + env-update + + if [ "${ROOT}" = "/" ]; then + font_setup + + if use opengl; then + switch_opengl_implem + fi + fi + + remove_old_compose_files + + setup_tmp_files + + print_info +} + +pkg_postrm() { + fix_links +} + +############### +# pkg_setup() # +############### + +cflag_setup() { + # Set up CFLAGS + filter-flags "-funroll-loops" + + ALLOWED_FLAGS="-fstack-protector -march -mcpu -mtune -O -O0 -O1 -O2 -O3 -Os" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -pipe -fomit-frame-pointer" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -momit-leaf-frame-pointer" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -g -g0 -g1 -g2 -g3" + ALLOWED_FLAGS="${ALLOWED_FLAGS} -ggdb -ggdb0 -ggdb1 -ggdb2 -ggdb3" + # arch-specific section added by popular demand + case "${ARCH}" in + mips) ALLOWED_FLAGS="${ALLOWED_FLAGS} -mips1 -mips2 -mips3 -mips4 -mabi" + ;; + # -fomit-frame-pointer known to break things and is pointless + # according to ciaranm + # And hardened compiler must be softened. -- fmccor, 20.viii.04 + sparc) filter-flags "-fomit-frame-pointer" "-momit-leaf-frame-pointer" + if [[ ${ABI} == "sparc64" ]]; then + ALLOWED_FLAGS="${ALLOWED_FLAGS} -D__sparc_v9__ -D__linux_sparc_64__" + append-flags -D__sparc_v9__ -D__linux_sparc_64__ + fi + ;; + # gcc-3.3.2 causes invalid insn error + hppa ) replace-cpu-flags 2.0 1.0 + ;; + esac + + # Recently there has been a lot of stability problem in Gentoo-land. Many + # things can be the cause to this, but I believe that it is due to gcc3 + # still having issues with optimizations, or with it not filtering bad + # combinations (protecting the user maybe from themselves) yet. + # + # This can clearly be seen in large builds like glibc, where too aggressive + # CFLAGS cause the tests to fail miserbly. + # + # Quote from Nick Jones , who in my opinion + # knows what he is talking about: + # + # People really shouldn't force code-specific options on... It's a + # bad idea. The -march options aren't just to look pretty. They enable + # options that are sensible (and include sse,mmx,3dnow when appropriate). + # + # The next command strips CFLAGS and CXXFLAGS from nearly all flags. If + # you do not like it, comment it, but do not bugreport if you run into + # problems. + # + # (13 Oct 2002) + strip-flags +} + +check_pam() { + if use pam && has_version x11-base/${PN}; then + einfo "Previous ${PN} installation detected." + einfo "Enabling PAM features in ${PN}." + else + einfo "Previous ${PN} installation NOT detected." + einfo "Disabling PAM features in ${PN}." + einfo "You must remerge ${PN} to enable pam." + einfo "See http://bugs.gentoo.org/show_bug.cgi?id=35468." + fi +} + +check_use_combos() { + if use static; then + # A static build disallows building the SDK. + # See config/xf86.rules. + if use sdk; then + die "The static USE flag is incompatible with the sdk USE flag." + fi + fi + + # (#77949) + if use minimal && use doc; then + die "The minimal and doc USE flags are incompatible and result in a dead build." + fi + + if use xv && ! use opengl; then + eerror "See http://bugs.gentoo.org/show_bug.cgi?id=67996" + eerror "The xv USE flag currently requires the opengl flag." + die "This is a known bug. Do not report it." + fi + + if use opengl && ! use xv; then + eerror "See http://bugs.gentoo.org/show_bug.cgi?id=76936" + eerror "The opengl USE flag currently requires the xv flag." + die "This is a known bug. Do not report it." + fi + + # Echo a message to the user about bitmap-fonts + if ! use bitmap-fonts; then + ewarn "Please emerge this with USE=\"bitmap-fonts\" to enable" + ewarn "75dpi and 100dpi fonts. Your GTK+-1.2 fonts may look" + ewarn "screwy otherwise" + + ebeep 5 + epause 10 + fi +} + +setup_multilib() { + # on amd64 we need /usr/lib64/X11/locale/lib to be a symlink + # created by the emul lib ebuild in order for adobe acrobat, staroffice, + # and a few other apps to work. + if ! has_multilib_profile; then + use amd64 && get_libdir_override lib64 + fi +} + +################ +# src_unpack() # +################ + +unpack_all() { + # Unpack source and patches + ebegin "Unpacking ${PV} source" + unpack X11R${PV}-src.tar.bz2 > /dev/null + eend 0 + + ebegin "Unpacking Gentoo files and patches" + unpack ${P}-files-${FILES_VER}.tar.bz2 > /dev/null + unpack ${P}-patches-${PATCH_VER}.tar.bz2 > /dev/null + eend 0 + + if ! use minimal; then + # Unpack TaD's gentoo cursors + ebegin "Unpacking Gentoo cursors" + unpack gentoo-cursors-tad-${XCUR_VER}.tar.bz2 > /dev/null + eend 0 + fi + + # Unpack extra fonts stuff from Mandrake + ebegin "Unpacking fonts" + if use nls; then + unpack gemini-koi8-u.tar.bz2 > /dev/null + fi + if ! use minimal; then + unpack eurofonts-X11.tar.bz2 > /dev/null + fi + if use font-server; then + unpack xfsft-encodings-${XFSFT_ENC_VER}.tar.bz2 > /dev/null + fi + eend 0 + + # Remove bum encoding + rm -f ${WORKDIR}/usr/share/fonts/encodings/urdunaqsh-0.enc +} + +do_patch() { + # Bulk patching - based on patch name + # Will create excluded stuff once it's needed + cd ${WORKDIR} + EPATCH_SUFFIX="patch" \ + epatch ${PATCHDIR} + cd ${S} + + # Security patches + epatch ${FILESDIR}/CVE-2006-1526-xrender-mitri.patch + epatch ${FILESDIR}/x11r6.9.0-setuid.diff +} + +host_def_setup() { + HOSTCONF="config/cf/host.def" + + ebegin "Setting up ${HOSTCONF}" + cd ${S}; cp ${FILES_DIR}/site.def ${HOSTCONF} \ + || die "host.def copy failed" + echo "#define XVendorString \"Gentoo (The X.Org Foundation ${PV}, revision ${PR}-${PATCH_VER})\"" \ + >> ${HOSTCONF} + + # Pending http://bugs.gentoo.org/show_bug.cgi?id=49038 and + # http://freedesktop.org/cgi-bin/bugzilla/show_bug.cgi?id=600 + # + # Makes ld bail at link time on undefined symbols + # Suggested by Mike Harris + #echo "#define SharedLibraryLoadFlags -shared -Wl,-z,defs" \ + # >> ${HOSTCONF} + + # Enable i810 on x86_64 (RH #126687) + if use amd64; then + echo "#define XF86ExtraCardDrivers i810" >> ${HOSTCONF} + fi + + # FHS install locations + echo "#define ManDirectoryRoot /usr/share/man" >> ${HOSTCONF} + echo "#define DocDir /usr/share/doc/${PF}" >> ${HOSTCONF} + echo "#define FontDir /usr/share/fonts" >> ${HOSTCONF} + # Single quotes so FONTDIR doesn't get run + echo '#define FontEncDir $(FONTDIR)/encodings' >> ${HOSTCONF} + echo "#define BinDir /usr/bin" >> ${HOSTCONF} + echo "#define IncRoot /usr/include" >> ${HOSTCONF} + # This breaks the case when $(SYSTEMUSRINCDIR) = $(INCDIR) + # See xc/include/Imakefile + echo "#define LinkGLToUsrInclude NO" >> ${HOSTCONF} + # /usr/X11R6/lib/X11 + echo "#define LibDir /usr/$(get_libdir)/X11" >> ${HOSTCONF} + # /usr/X11R6/lib with exception of /usr/X11R6/lib/X11 + echo "#define UsrLibDir /usr/$(get_libdir)" >> ${HOSTCONF} + + # Make man4 and man7 stuff get 'x' suffix like everything else + # Necessary so we can install to /usr/share/man without overwriting + echo "#define DriverManDir \$(MANSOURCEPATH)4" >> ${HOSTCONF} + echo "#define DriverManSuffix 4x /* use just one tab or cpp will die */" \ + >> ${HOSTCONF} + echo "#define MiscManDir \$(MANSOURCEPATH)7" >> ${HOSTCONF} + echo "#define MiscManSuffix 7x /* use just one tab or cpp will die */" \ + >> ${HOSTCONF} + + # Don't build xterm -- use external (#54051) + echo "#define BuildXterm NO" >> ${HOSTCONF} + + # Xwrapper has been removed so we now need to use the set uid server + # again, this mustve happened somewhere after 4.3.0 in the development. + echo "#define InstallXserverSetUID YES" >> ${HOSTCONF} + echo "#define BuildServersOnly NO" >> ${HOSTCONF} + + # Don't use /lib64 if $(get_libdir) != lib64 + # Replaces 0181_all_4.3.0-amd64-nolib64.patch + if [ "$(get_libdir)" == "lib64" ]; then + echo "#define HaveLib64 YES" >> ${HOSTCONF} + sed -i '/^#define Freetype2LibDir/s:^.*$:#define Freetype2LibDir /usr/lib64:' ${HOSTCONF} + else + echo "#define HaveLib64 NO" >> ${HOSTCONF} + fi + + # Set location of DRM source to be installed + echo "#define InstSrcDir ${ROOT}/usr/src/${PF}" >> ${HOSTCONF} + + if [ "$(gcc-major-version)" -eq "3" ]; then + if use x86; then + # Should fix bug #4189. gcc 3.x have problems with + # -march=pentium4 and -march=athlon-tbird + # Seems fixed on 3.3 and higher + if [ "$(gcc-minor-version)" -le "2" ]; then + replace-cpu-flags pentium4 pentium3 + replace-cpu-flags athlon athlon-tbird + fi + + if [ "$(gcc-minor-version)" -eq "4" ]; then + if [ "$(gcc-micro-version)" -lt "4" ]; then + #to fix #57602 for now, thanks Spanky (broken sse2) + if test_flag -mno-sse2; then + append-flags -mno-sse2 + fi + # (#75067) broken sse3 + if test_flag -mno-sse3; then + append-flags -mno-sse3 + fi + fi + fi + + # Try a fix for #49310, see #50931 for more info. + if [ "$(is-flag -fomit-frame-pointer)" ]; then + replace-cpu-flags k6 k6-2 k6-3 i586 + fi + fi + + # Without this, modules breaks with gcc3 + if [ "$(gcc-minor-version)" -eq "1" ]; then + append-flags "-fno-merge-constants" + append-flags "-fno-merge-constants" + fi + + if [ "$(gcc-minor-version)" -eq "2" ]; then + if [ "$(gcc-micro-version)" -lt "2" ]; then + # Bug #12775 .. fails with -Os. + replace-flags "-Os" "-O2" + fi + elif [ "$(gcc-minor-version)" -lt "2" ]; then + # Bug #12775 .. fails with -Os. + replace-flags "-Os" "-O2" + fi + elif [ "$(gcc-major-version)" -lt "3" ]; then + # Bug #12775 .. fails with -Os. + replace-flags "-Os" "-O2" + fi + + echo "#define CcCmd $(tc-getCC)" >> ${HOSTCONF} + echo "#define OptimizedCDebugFlags ${CFLAGS} GccAliasingArgs" >> ${HOSTCONF} + echo "#define OptimizedCplusplusDebugFlags ${CXXFLAGS} GccAliasingArgs" >> ${HOSTCONF} + + if use static; then + echo "#define DoLoadableServer NO" >>${HOSTCONF} + else + einfo "Setting DoLoadableServer to YES." + echo "#define DoLoadableServer YES" >> ${HOSTCONF} + + if has_hardened; then + echo "#define HardenedGccSpecs YES" >> ${HOSTCONF} + fi + fi + + use_build debug XFree86Devel + use_build debug BuildDebug + use_build debug DebuggableLibraries + + if ! use debug; then + # use less ram .. got this from Spider's makeedit.eclass :) + echo "#define GccWarningOptions -Wno-return-type -w" \ + >> ${HOSTCONF} + fi + + # Remove circular dep between pam and X11, bug #35468 + # If pam is in USE and we have X11, then we can enable PAM +# if use pam && has_version x11-base/xorg-x11 + if has_version x11-base/xorg-x11; then + # If you want to have optional pam support, do it properly ... + use_build pam HasPam + use_build pam HasPamMisc + fi + + if use x86 || use alpha; then + # build with glide3 support? (build the tdfx_dri.o module) + if use 3dfx; then + echo "#define HasGlide3 YES" >> ${HOSTCONF} + fi +# This won't work unless we can disable building the tdfx stuff +# entirely :/ +# use_build 3dfx HasGlide3 + fi + + # Do we want the glx extension? This will turn off XF86DRI if it's off. + # DRI can't build if glx isn't built, so keep this below DRI define. + # Do this before hppa so they can turn DRI off + use_build opengl BuildGlxExt + use_build opengl BuildGLXLibrary + use_build opengl BuildXF86DRI + # Needs GL headers + use_build opengl BuildGLULibrary + + + + if use mips; then + echo "#define XF86CardDrivers fbdev newport" >> ${HOSTCONF} + fi + + # Make xv optional for more minimal builds + use_build xv BuildXvLibrary + use_build xv BuildXvExt + # Depends on X11/extensions/Xv.h + use_build xv BuildXF86RushExt + use_build xv BuildXF86RushLibrary + + if use hppa; then + echo "#define DoLoadableServer NO" >> ${HOSTCONF} + echo "#define BuildXF86DRI NO" >> config/cf/host.def + echo "#undef DriDrivers" >> config/cf/host.def + echo "#define XF86CardDrivers fbdev" >> config/cf/host.def + echo "#define BuildXvExt YES" >> config/cf/host.def + fi + + + if use alpha; then + echo "#define XF86CardDrivers mga nv tga s3virge sis rendition \ + i740 tdfx cirrus tseng fbdev \ + ati vga v4l glint s3 vesa" >> ${HOSTCONF} + fi + + if use ppc; then + echo "#define XF86CardDrivers mga glint s3virge sis savage trident \ + chips tdfx fbdev ati DevelDrivers vga nv imstt \ + XF86OSCardDrivers XF86ExtraCardDrivers" >> ${HOSTCONF} + fi + + if use ppc64; then + echo "#define MakeDllModules YES" >> ${HOSTCONF} + echo "#define XF86VgaHw YES" >> ${HOSTCONF} + echo "#define XF86FBDevHw YES" >> ${HOSTCONF} + echo "#define XF86CardDrivers mga fbdev v4l ati vga nv" >> ${HOSTCONF} + fi + + if use sparc; then + echo "#define XF86CardDrivers sunffb sunleo suncg6 suncg3 suncg14 \ + suntcx sunbw2 glint mga tdfx ati savage vesa vga fbdev \ + XF86OSCardDrivers XF86ExtraCardDrivers \ + DevelDrivers" >> ${HOSTCONF} + if ( [ -e "${ROOT}/usr/src/linux" ] \ + && ! kernel_is "2" "6" ) \ + || [ "$(uname -r | cut -d. -f1,2)" != "2.6" ]; then + einfo "Avoid bug #46593 for sparc32-SMP with kernel 2.4.xx." + echo "/* Add a line to avoid bug #56593 on sparc32 */" >> \ + programs/Xserver/hw/xfree86/drivers/ati/r128_driver.c + fi + fi + + # The definitions for fontconfig + echo "#define UseFontconfig YES" >> ${HOSTCONF} + echo "#define HasFontconfig YES" >> ${HOSTCONF} + + # Use the xorg Xft2 lib + echo "#define SharedLibXft YES" >> ${HOSTCONF} + + # with USE="X doc' circular dep w/ virtual/ghostscript + # echo "#define HasGhostScript ${DOC}" >> ${HOSTCONF} + # Caused issues, basic docs aren't installed + use_build doc BuildLinuxDocPS + use_build doc BuildSpecsDocs + use_build doc BuildHtmlManPages + use_build doc InstallHardcopyDocs + + # enable Japanese docs, optionally + use doc && use_build cjk InstallJapaneseDocs + + # Native Language Support Fonts + use_build nls BuildCyrillicFonts + use_build nls BuildArabicFonts + use_build nls BuildGreekFonts + use_build nls BuildHebrewFonts + use_build nls BuildThaiFonts + + if use nls; then + use_build cjk BuildCIDFonts + use_build cjk BuildJapaneseFonts + use_build cjk BuildKoreanFonts + use_build cjk BuildChineseFonts + fi + + # Crappy bitmap fonts + use_build bitmap-fonts Build75DpiFonts + use_build bitmap-fonts Build100DpiFonts + + # Type1 fonts + use_build type1-fonts BuildType1Fonts + + # TrueType fonts + use_build truetype-fonts BuildTrueTypeFonts + + # X Font Server + use_build font-server BuildFontServer + + use_build insecure-drivers BuildDevelDRIDrivers + + if use ipv6; then + # In case Gentoo ever works on a system with IPv6 sockets that don't + # also listen on IPv4 (see config/cf/X11.tmpl) + echo "#define PreferXdmcpIPv6 YES" >> ${HOSTCONF} + fi + + use_build ipv6 BuildIPv6 + + if use minimal; then + # Don't build static libs + echo "#define ForceNormalLib NO" >> ${HOSTCONF} + # Turn back on needed ones + echo "#define NormalLibXau YES" >> ${HOSTCONF} + + echo "#define BuildDPSLibraries NO" >> ${HOSTCONF} + echo "#define BuildClients NO" >> ${HOSTCONF} + + # BuildClients doesn't catch things in xc/programs/Xserver + # Also had to add + # 9250_all_6.8.1.904-respect-xfree86configtools-setting.patch + echo "#define BuildXFree86ConfigTools NO" >> ${HOSTCONF} + echo "#define BuildLBX NO" >> ${HOSTCONF} + + # Weird crap we don't need + echo "#define XF8_32Wid NO" >> ${HOSTCONF} + echo "#define XF8_32Bpp NO" >> ${HOSTCONF} + echo "#define XF8_16Bpp NO" >> ${HOSTCONF} + echo "#define XF24_32Bpp NO" >> ${HOSTCONF} + + # Without nls, truetype-fonts, type1-fonts, we only build misc + # Now let's try to reduce what gets built in misc + # iso8859-1 has the "fixed" font + echo "#define BuildISO8859_2Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_3Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_4Fonts NO" >> ${HOSTCONF} + # 5 is cyrillic, 6 isn't in misc, 7 is greek, 8 is hebrew + echo "#define BuildISO8859_9Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_10Fonts NO" >> ${HOSTCONF} + # 11 is thai, 12 isn't in misc + echo "#define BuildISO8859_13Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_14Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_15Fonts NO" >> ${HOSTCONF} + echo "#define BuildISO8859_16Fonts NO" >> ${HOSTCONF} + + echo "#define BuildDmx NO" >> ${HOSTCONF} + echo "#define XnestServer NO" >> ${HOSTCONF} + echo "#define XVirtualFramebufferServer NO" >> ${HOSTCONF} + echo "#define XInputDrivers mouse keyboard" >> ${HOSTCONF} + + # If you want more drivers built with minimal, file a bug + # -Donnie Berkholz + if use x86; then + # Remove glint, tga, s3, s3virge, rendition, neomagic, i740, + # cirrus, tseng, trident, chips, apm, ark, cyrix, siliconmotion + # mga, nv, sis, tdfx, savage, GlideDriver, i386Drivers + # (nsc, i810), ati, DevelDrivers, via + # Leave vmware driver for testing minimal setups using VMWare + # XF86OSCardDrivers includes v4l and fbdev on linux + # DevelDrivers includes imstt and newport on x86 + echo "#define XF86CardDrivers vmware vesa vga dummy \ + XF86OSCardDrivers XF86ExtraCardDrivers" >> ${HOSTCONF} + # (#93339) + elif use sparc; then + echo "#define XF86CardDrivers vesa vga fbdev sunffb suncg6 \ + sunleo" >> ${HOSTCONF} + fi + fi + + # Ajax is the man for getting this going for us + echo "#define ProPoliceSupport YES" >> ${HOSTCONF} + + # Make xprint optional + use_build xprint BuildXprint + use_build xprint BuildXprintClients + # Build libXp even when xprint is off. It's just for clients, server + if ! use xprint; then + echo "#define BuildXprintLib YES" >> ${HOSTCONF} + fi + + # End the host.def definitions here + eend 0 +} + +patch_setup() { + einfo "Excluding patches..." + + patch_exclude 9020 9030 + patch_exclude 9913 9914 9915 9920 + + # This patch is just plain broken. Results in random failures. + patch_exclude 0120*parallel-make + + # Hardened patches (both broken) + patch_exclude 9960_all_4.3.0-exec-shield-GNU + patch_exclude 9961_all_4.3.0-libGL-exec-shield + + # Xbox nvidia driver, patch is a total hack, tears apart xc/config/cf + # (#68726). Only apply when necessary so we don't screw other stuff up. + # 9990 is the driver, 9991 is xbox pci scanning (potentially useful) + if [ ! "${PROFILE_ARCH}" = "xbox" ]; then + patch_exclude 9990 9991 + fi + + # this patch comments out the Xserver line in xdm's config + # We only want it here + if ! use s390; then + patch_exclude 7500 + fi + + # if ! use gatos; then + # patch_exclude 9841_all_4.3.0-gatos-mesa + # fi + + if use debug; then + patch_exclude 5901*acecad-debug + fi + + # TDFX_RISKY - 16-bit, 1024x768 or higher on low-memory voodoo3's + if use 3dfx && [ "${TDFX_RISKY}" = "yes" ]; then + patch_exclude 5850 + else + patch_exclude 5851 + fi + + # Glibc-specific patches to exclude for non-glibc systems + if use elibc_FreeBSD || use elibc_OpenBSD; then + patch_exclude 0700 + fi + einfo "Done excluding patches." +} + +use_specific_hacks() { + # uclibc lacks sinf and cosf + if use uclibc; then + sed -i -e 's:GLXCLIENTDIRS = glxinfo glxgears:GLXCLIENTDIRS = :' \ + ${S}/programs/Imakefile + fi + + # Get rid of cursor sets other than core and handhelds, saves ~4MB + if use minimal; then + sed -i -e 's:SUBDIRS = redglass whiteglass handhelds:SUBDIRS = handhelds:' \ + ${S}/programs/xcursorgen/Imakefile + fi + + cd ${S} + if use doc; then + # These are not included anymore as they are obsolete + local x + for x in ${S}/programs/Xserver/hw/xfree86/{XF98Conf.cpp,XF98Config}; do + if [ -f ${x} ]; then + sed -i '/Load[[:space:]]*"\(pex5\|xie\)"/d' ${x} + fi + done + fi +} + +################# +# src_compile() # +################# + +build() { + # If a user defines the MAKE_OPTS variable in /etc/make.conf instead of + # MAKEOPTS, they'll redefine an internal xorg Makefile variable and the + # xorg build will silently die. This is tricky to track down, so I'm + # adding a preemptive fix for this issue by making sure that MAKE_OPTS is + # unset. (drobbins, 08 Mar 2003) + unset MAKE_OPTS + + einfo "Building xorg-x11..." + if use debug; then + chmod u+x ${S}/config/util/makeg.sh + FAST=1 ${S}/config/util/makeg.sh World WORLDOPTS="" MAKE="make" \ + || die "debug make World failed" + else + FAST=1 emake -j1 World WORLDOPTS="" MAKE="make" || die "make World failed" + fi + + if use nls; then + emake -j1 -C ${S}/nls MAKE="make" || die "nls build failed" + fi +} + +################# +# src_install() # +################# + +install_everything() { + unset MAKE_OPTS + + einfo "Installing X.org X11..." + # gcc3 related fix. Do this during install, so that our + # whole build will not be compiled without mmx instructions. + if [ "$(gcc-version)" != "2.95" ] && use x86; then + make install MAKE="make" DESTDIR=${D} \ + || make CDEBUGFLAGS="${CDEBUGFLAGS} -mno-mmx" \ + CXXDEBUGFLAGS="${CXXDEBUGFLAGS} -mno-mmx" \ + install MAKE="make" DESTDIR=${D} || die "install failed" + else + make install MAKE="make" DESTDIR=${D} || die "install failed" + fi + + if use sdk; then + einfo "Installing X.org X11 SDK..." + make install.sdk MAKE="make" DESTDIR=${D} || die "sdk install failed" + fi + + if ! use minimal; then + einfo "Installing man pages..." + make install.man MAKE="make" DESTDIR=${D} || die "man page install failed" + einfo "Compressing man pages..." + prepman /usr + fi + + if use nls; then + cd ${S}/nls + make MAKE="make" DESTDIR=${D} install || die "nls install failed" + fi + dodoc ${S}/RELNOTES +} + +backward_compat_install() { + # Backwards compatibility for /usr/share move + dosym ../../share/fonts /usr/$(get_libdir)/X11/fonts + + # Have the top-level libdir symlink made first, so real dirs don't get created + local DIR DIRS + if [ "lib" != "$(get_libdir)" ]; then + DIRS="${DIRS} $(get_libdir)" + fi + for DIR in ${DIRS}; do + dosym ../${DIR} /usr/X11R6/${DIR} + done + + dosym ../../../share/doc/${PF} /usr/X11R6/$(get_libdir)/X11/doc +} + +fix_permissions() { + # Fix permissions on locale/common/*.so + local x + for x in ${D}/usr/$(get_libdir)/X11/locale/$(get_libdir)/common/*.so*; do + if [ -f ${x} ]; then + fperms 0755 ${x/${D}} + fi + done + + # Fix permissions on modules ... + for x in $(find ${D}/usr/$(get_libdir)/modules -name '*.o' -o -name '*.so'); do + if [ -f ${x} ]; then + fperms 0755 ${x/${D}} + fi + done + + # Fix perms + if ! use minimal; then + fperms 755 /usr/$(get_libdir)/X11/xkb/geometry/sgi /usr/bin/dga + fi +} + +zap_host_def_cflags() { + ebegin "Fixing $(get_libdir)/X11/config/host.def" + cp ${D}/usr/$(get_libdir)/X11/config/host.def ${T} + awk '!/OptimizedCDebugFlags|OptimizedCplusplusDebugFlags|GccWarningOptions/ {print $0}' \ + ${T}/host.def > ${D}/usr/$(get_libdir)/X11/config/host.def \ + || eerror "Munging host.def failed" + # theoretically, /usr/lib/X11/config is a possible candidate for + # config file management. If we find that people really worry about imake + # stuff, we may add it. But for now, we leave the dir unprotected. + eend 0 +} + +add_euro_support() { + ebegin "Adding Euro support" + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ + ${D}/usr/bin/bdftopcf -t ${WORKDIR}/Xlat9-8x14.bdf | \ + gzip -9 > ${D}/usr/share/fonts/misc/Xlat9-8x14-lat9.pcf.gz + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ + ${D}/usr/bin/bdftopcf -t ${WORKDIR}/Xlat9-9x16.bdf | \ + gzip -9 > ${D}/usr/share/fonts/misc/Xlat9-9x16-lat9.pcf.gz + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ + ${D}/usr/bin/bdftopcf -t ${WORKDIR}/Xlat9-10x20.bdf | \ + gzip -9 > ${D}/usr/share/fonts/misc/Xlat9-10x20-lat9.pcf.gz + eend 0 +} + +setup_standard_symlinks() { + # Standard symlinks + dodir /usr/{bin,include,$(get_libdir)} + dosym ../bin /usr/bin/X11 + # Stop complains about "file or directory not existing" + dodir /usr/X11R6 + dosym ../include /usr/X11R6/include + dosym ../../usr/$(get_libdir)/X11/xkb /etc/X11/xkb + + # Some critical directories + if ! use minimal; then + keepdir /var/lib/xdm + dosym ../../../var/lib/xdm /etc/X11/xdm/authdir + fi + + # Backwards compat, FHS, etc. + dosym ../../usr/X11R6/bin/Xorg /etc/X11/X +} + +libtool_archive_install() { + if use opengl; then + # .la files for libtool support + insinto /usr/$(get_libdir) + # (#67729) Needs to be lib, not $(get_libdir) + doins ${FILES_DIR}/lib/*.la + fi +} + +fix_libtool_libdir_paths() { + local dirpath + for archive in ${*} ; do + dirpath=$(dirname ${archive} | sed -e "s:^${D}::") + [[ ${dirpath::1} == "/" ]] || dirpath="/"${dirpath} + sed -i ${archive} -e "s:^libdir.*:libdir=\'${dirpath}\':" + done +} + +compose_files_install() { + # Hack from Mandrake (update ours that just created Compose files for + # all locales) + local x + for x in $(find ${D}/usr/$(get_libdir)/X11/locale/ -mindepth 1 -type d); do + # make empty Compose files for some locales + # CJK must not have that file (otherwise XIM don't works some times) + case $(basename ${x}) in + C|microsoft-*|iso8859-*|koi8-*) + if [ ! -f ${x}/Compose ]; then + touch ${x}/Compose + fi + ;; + ja*|ko*|zh*) + if [ -r ${x}/Compose ]; then + rm -f ${x}/Compose + fi + ;; + esac + done + + # Another hack from Mandrake -- to fix dead + space for the us + # international keyboard + local i + for i in ${D}/usr/$(get_libdir)/X11/locale/*/Compose; do + sed -i \ + -e 's/\( \).*$/\1 : "\\"" quotedbl/' \ + -e "s/\( \).*$/\1 : \"'\" apostrophe/" ${i} \ + || eerror "sed ${i} failed" + done +} + +encode_xfsft_files() { + # Yet more Mandrake + ebegin "Encoding files for xfsft font server" + dodir /usr/share/fonts/encodings + cp -pPR ${WORKDIR}/usr/share/fonts/encodings/* \ + ${D}/usr/share/fonts/encodings + + for x in ${D}/usr/share/fonts/encodings/{.,large}/*.enc; do + if [ -f "${x}" ]; then + gzip -9 -f ${x} \ + || eerror "gzipping ${x} failed" + fi + done + eend 0 +} + +koi8_fonts_install() { + ebegin "Adding gemini-koi8 fonts" + cd ${WORKDIR}/ukr + gunzip *.Z || eerror "gunzipping gemini-koi8 fonts failed" + gzip -9 *.pcf || eerror "gzipping gemini-koi8 fonts failed" + cd ${S} + cp -pPR ${WORKDIR}/ukr ${D}/usr/share/fonts \ + || eerror "copying gemini-koi8 fonts failed" + eend 0 +} + +etc_files_install() { + insinto /etc/X11 + + # Install example config file + newins ${S}/programs/Xserver/hw/xfree86/xorg.conf xorg.conf.example + + exeinto /etc/X11 + # new session management script + doexe ${FILES_DIR}/chooser.sh + # new display manager script + doexe ${FILES_DIR}/startDM.sh + exeinto /etc/X11/Sessions + # doexe skips directories, so this should be safe + doexe ${FILES_DIR}/Sessions/* + insinto /etc/env.d + doins ${FILES_DIR}/10xorg + insinto /etc/X11/xinit + doins ${FILES_DIR}/xinitrc + if ! use minimal; then + exeinto /etc/X11/xdm + doexe ${FILES_DIR}/Xsession + exeinto /etc/init.d + newexe ${FILES_DIR}/xdm.start xdm + fi + if use font-server; then + insinto /etc/X11/fs + newins ${FILES_DIR}/xfs.config config + fi + if use pam; then + insinto /etc/pam.d + newins ${FILES_DIR}/xdm.pamd xdm + # Need to fix console permissions first + newins ${FILES_DIR}/xserver.pamd xserver + fi + if use font-server; then + newexe ${FILES_DIR}/xfs.start xfs + insinto /etc/conf.d + newins ${FILES_DIR}/xfs.conf.d xfs + fi +} + +dynamic_libgl_install() { + # next section is to setup the dynamic libGL stuff + ebegin "Moving libGL and friends for dynamic switching" + dodir /usr/$(get_libdir)/opengl/${PN}/{lib,extensions,include} + local x="" + for x in ${D}/usr/$(get_libdir)/libGL.so* \ + ${D}/usr/$(get_libdir)/libGL.la \ + ${D}/usr/$(get_libdir)/libGL.a; do + if [ -f ${x} -o -L ${x} ]; then + # libGL.a cause problems with tuxracer, etc + mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/lib + fi + done + for x in ${D}/usr/$(get_libdir)/modules/extensions/libglx*; do + if [ -f ${x} -o -L ${x} ]; then + mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/extensions + fi + done + # glext.h added for #54984 + for x in ${D}/usr/include/GL/{gl.h,glx.h,glxtokens.h,glext.h,glxext.h,glxmd.h,glxproto.h}; do + if [ -f ${x} -o -L ${x} ]; then + mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/include + fi + done + eend 0 +} + +cursor_install() { + # Make the core cursor the default. People seem not to like whiteglass + # for some reason. + dosed 's:whiteglass:core:' /usr/share/cursors/${PN}/default/index.theme + + if ! use minimal; then + install_extra_cursors + fi +} + +strip_execs() { + if use debug || has nostrip ${FEATURES}; then + ewarn "Debug build turned on by USE=debug or FEATURES=nostrip" + ewarn "NOT stripping binaries and libraries" + else + local STRIP + if [ ! -z "${CBUILD}" ] && [ "${CBUILD}" != "${CHOST}" ]; then + STRIP=${CHOST}-strip + else + STRIP=strip + fi + einfo "Stripping binaries and libraries..." + # This bit I got from Redhat ... strip binaries and drivers .. + # NOTE: We do NOT want to strip the drivers, modules or DRI modules! + local x + for x in $(find ${D}/ -type f -perm +0111 -exec file {} \; | \ + grep -v ' shared object,' | \ + sed -n -e 's/^\(.*\):[ ]*ELF.*, not stripped/\1/p'); do + if [ -f ${x} ]; then + # Dont do the modules ... + if [ "${x/\/usr\/$(get_libdir)\/modules}" = "${x}" ]; then + echo "$(echo ${x/${D}})" + ${STRIP} ${x} || : + fi + fi + done + # Now do the libraries ... + for x in ${D}/usr/{$(get_libdir),$(get_libdir)/opengl/${PN}/lib}/*.so.* \ + $(get_libdir)/X11/locale/$(get_libdir)/common}/*.so.*; do + if [ -f ${x} ]; then + echo "$(echo ${x/${D}})" + ${STRIP} --strip-debug ${x} || : + fi + done + fi +} + +install_extra_cursors() { + # Install TaD's gentoo cursors + insinto /usr/share/cursors/${PN}/gentoo/cursors + doins ${WORKDIR}/cursors/gentoo/cursors/* + insinto /usr/share/cursors/${PN}/gentoo-blue/cursors + doins ${WORKDIR}/cursors/gentoo-blue/cursors/* + insinto /usr/share/cursors/${PN}/gentoo-silver/cursors + doins ${WORKDIR}/cursors/gentoo-silver/cursors/* +} + +minimal_install() { + # Get rid of all unnecessary fonts (saves ~5.5 MB) + find ${D}/usr/share/fonts/misc/ -name '*.pcf.gz' \ + -not -name '*6x13*' -not -name 'cursor.pcf.gz' -exec rm {} \; + # Woohoo, another 772K + rm -rf ${D}/usr/share/doc +} + +xprint_install() { + # If we want xprint, save the init script before deleting /etc/rc.d/ + # Requested on #68316 + if use xprint; then + xprint_init_install + else + # delete xprint stuff + rm -f ${D}/etc/{init,profile}.d/xprint* + rmdir --ignore-fail-on-non-empty ${D}/etc/{init,profile}.d + fi + + # Remove the /etc/rc.d nonsense -- not everyone is RedHat + rm -rf ${D}/etc/rc.d +} + +xprint_init_install() { + # RH-style init script, we provide a wrapper + exeinto /usr/$(get_libdir)/misc + doexe ${D}/etc/init.d/xprint + rm -f ${D}/etc/init.d/xprint + # Install the wrapper + newinitd ${FILES_DIR}/xprint.init xprint + # patch profile scripts + sed -i -e "s:/bin/sh.*get_xpserverlist:/usr/$(get_libdir)/misc/xprint get_xpserverlist:g" ${D}/etc/profile.d/xprint* + # move profile scripts, we can't touch /etc/profile.d/ in Gentoo + dodoc ${D}/etc/profile.d/xprint* + rm -f ${D}/etc/profile.d/xprint* +} + +config_files_install() { + + # Fix default config files after installing fonts to /usr/share/fonts + sed -i -e "s:/usr/X11R6/$(get_libdir)/X11/fonts:/usr/share/fonts:g" \ + -e "s:/usr/$(get_libdir)/X11/fonts:/usr/share/fonts:g" \ + -e "s:/usr/$(get_libdir)/fonts:/usr/share/fonts:g" \ + ${D}/etc/X11/xorg.conf.example + if use font-server; then + sed -i "s:/usr/X11R6/$(get_libdir)/X11/fonts:/usr/share/fonts:g" \ + ${D}/etc/X11/fs/config + fi + + # Work around upgrade problem where people have + # Option "XkbRules" "xfree86" in their config file + sed -i "s:^.*Option.*"XkbRules".*$::g" ${D}/etc/X11/xorg.conf.example +} + +fix_opengl_symlinks() { + # Remove invalid symlinks + local LINK + for LINK in $(find ${D}/usr/$(get_libdir) \ + -name libGL.* -type l); do + rm -f ${LINK} + done + # Create required symlinks + dosym libGL.so.1.2 /usr/$(get_libdir)/libGL.so + dosym libGL.so.1.2 /usr/$(get_libdir)/libGL.so.1 +} + +################# +# pkg_preinst() # +################# + +# We need a symlink /usr/X11R6/dir -> /usr/dir so all the packages +# whose files we move don't lose track of them. As such, we need +# _absolutely nothing_ in /usr/X11R6/dir so we can make such a symlink. +# Donnie Berkholz 20 October 2004 +# +# Takes two arguments -- starting location and ending location +migrate() { + einfo "Migrating from ${1} to ${2}..." + + # Strip trailing slash + if [ -z "${1##*/}" ]; then + set -- ${1%/} ${2} + fi + + if [ -e ${ROOT}${1} ]; then + # If it's not a symlink (in other words, it should be a directory) + if [ ! -L ${ROOT}${1} ]; then + einfo " ${1} isn't a symlink, migrating..." + # Move everything + rsync \ + --archive \ + --update \ + --links \ + --hard-links \ + --ignore-existing \ + --stats \ + --progress \ + --verbose \ + ${ROOT}${1}/ ${ROOT}${2} > ${T}/migrate-${1//\//-}.log 2>&1 + + check_migrate_return + remove_migrated_files ${1} + + if [ -e "${ROOT}${1}" ]; then + # Remove any floating .keep files so we can run rmdir + find ${ROOT}${1} -name '\.keep' -exec rm -f {} \; + # Get rid of the directory + rmdir ${ROOT}${1} + fi + + make_symlinks ${1} + else + ewarn " ${1} is a symlink, not migrating" + fi + else + ewarn " ${1} doesn't exist, not migrating" + make_symlinks ${1} + fi +} + +check_migrate_return() { + MIGRATE_RETURN="$?" + if [ "${MIGRATE_RETURN}" -eq "0" ]; then + einfo "rsync successful!" + else + die "rsync failed. Exit code: ${MIGRATE_RETURN}." + fi + + # Migration fubars lib symlinks -- eradicator + if use amd64; then + if [[ -L ${ROOT}usr/lib64 ]]; then + rm ${ROOT}usr/lib64 + ln -s lib ${ROOT}usr/lib64 + elif [[ -L ${ROOT}usr/lib ]]; then + rm -f ${ROOT}usr/lib + ln -s lib64 ${ROOT}usr/lib + elif [[ -L ${ROOT}usr/lib32 ]]; then + if has_multilib_profile; then + ln -s lib ${ROOT}usr/lib32 + else + ln -s ../emul/linux/x86/usr/lib ${ROOT}usr/lib32 + fi + fi + fi +} + +remove_migrated_files() { + # This is a copy instead of a move, so we need to get rid of what + # we copied. This is a little risky if it fails, so just do it on + # success. + + # DO NOT proceed if we don't have an argument, or we kill root filesystem + if [ -z "${1}" ]; then + die "No argument to remove_migrated_files(). Want to `rm -rf ${ROOT}`?" + fi + + if [ "${MIGRATE_RETURN}" -eq "0" ]; then +# rm -rfv ${ROOT}${1} > ${T}/migrate-remove-${1//\//-}.log 2>&1 + rm -rfv ${ROOT}${1} + fi +} + +make_symlinks() { + # Put a symlink in its place + + # Special case: lib != libdir + if [ "${1##*/}" = "$(get_libdir)" -a "$(get_libdir)" != "lib" ]; then + einfo " Symlinking ${ROOT}usr/X11R6/lib -> $(get_libdir)" + ln -s $(get_libdir) ${ROOT}usr/X11R6/lib + # Special case: fonts + elif [ "${1##*/}" = "fonts" ]; then + einfo " Symlinking ${ROOT}${1} -> ../../share/fonts" + ln -s ../../share/fonts ${ROOT}${1} + # Special case: X11R6 + elif [ "${1##*/}" = "X11R6" ]; then + einfo " Symlinking ${ROOT}${1} -> ../usr" + ln -s ../usr ${ROOT}${1} + else + einfo " Symlinking ${ROOT}${1} -> ../${1##*/}" + ln -s ../${1##*/} ${ROOT}${1} + fi +} + +update_config_files() { + # Fix any installed config files for installing fonts to /usr/share/fonts + # This *needs* to be after all other installation so files aren't + # overwritten. + + if [ "${ROOT}" = "/" ]; then + einfo "Preparing any installed configuration files for font move..." + FILES="/etc/X11/xorg.conf + /etc/X11/XF86Config-4 + /etc/X11/XF86Config" + if use font-server; then + FILES="${FILES} /etc/X11/fs/config" + fi + # /etc/fonts/fonts.conf + # /etc/fonts/local.conf + + local FILE + for FILE in ${FILES}; do + if [ -e ${FILE} ]; then + # New font paths + sed "s,/usr/X11R6/$(get_libdir)/X11/fonts,/usr/share/fonts,g" \ + ${ROOT}${FILE} > ${IMAGE}${FILE} + + if [ "${FILE}" = "/etc/X11/xorg.conf" ] \ + || [ "${FILE}" = "/etc/X11/XF86Config" ] \ + || [ "${FILE}" = "/etc/X11/XF86Config-4" ]; then + # "keyboard" driver is deprecated and will be removed, + # switch to "kbd" + sed -i 's~^\([ \t]*Driver[ \t]\+\)"[kK]eyboard"~\1"kbd"~' \ + ${IMAGE}${FILE} + + # This moved in the /usr/X11R6/libdir -> /usr/libdir change + sed -i \ + -e 's~^\([ \t]*RgbPath[ \t]\+\)"/usr/X11R6/$(get_libdir)/X11/rgb"~\1"/usr/$(get_libdir)/X11/rgb"~' \ + -e 's~^\([ \t]*RgbPath[ \t]\+\)"/usr/X11R6/lib/X11/rgb"~\1"/usr/lib/X11/rgb"~' \ + ${IMAGE}${FILE} + + # Work around upgrade problem where people have + # Option "XkbRules" "xfree86" in their config file + sed -i "s:^.*Option.*\"XkbRules\".*$::g" \ + ${IMAGE}${FILE} + fi + fi + done + fi +} + +cleanup_fonts() { + local G_FONTDIRS + G_FONTDIRS="Speedo encodings local misc util" + if use truetype-fonts; then + G_FONTDIRS="${G_FONTDIRS} TTF" + fi + if use type1-fonts; then + G_FONTDIRS="${G_FONTDIRS} Type1" + fi + if use cjk; then + G_FONTDIRS="${G_FONTDIRS} CID" + fi + if use bitmap-fonts; then + G_FONTDIRS="${G_FONTDIRS} 75dpi 100dpi" + fi + if use nls; then + G_FONTDIRS="${G_FONTDIRS} cyrillic ukr" + fi + + for G_FONTDIR in ${G_FONTDIRS}; do + # clean out old fonts.* and encodings.dir files, as we + # will regenerate them + # Not Speedo or CID, as their fonts.scale files are "real" + if [ "${G_FONTDIR}" != "CID" -a "${G_FONTDIR}" != "Speedo" ]; then + find ${ROOT}/usr/share/fonts/${G_FONTDIR} -type f -name 'fonts.*' \ + -o -name 'encodings.dir' -exec rm -fv {} \; + fi + done + + # Get rid of deprecated directories so our symlinks in the same location + # work -- users shouldn't be placing fonts here so that should be fine, + # they should be using ~/.fonts or /usr/share/fonts. + remove_font_dirs +} + +remove_font_dirs() { + if [ -e ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts ]; then + if [ ! -L ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts ]; then + local G_FONTDIR + for G_FONTDIR in ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/*; do + if [ -L "${G_FONTDIR}" ]; then + einfo "Removing ${G_FONTDIR} symlink." + rm -rfv ${G_FONTDIR} + else + ewarn "${G_FONTDIR} not a symlink, moving to /usr/share/fonts" + if [ -d ${G_FONTDIR} ]; then + if [ ! -e /usr/share/fonts/${G_FONTDIR##*/} ]; then + einfo "Moving ${G_FONTDIR} to /usr/share/fonts/." + mv ${G_FONTDIR} /usr/share/fonts/ + else + ewarn "/usr/share/fonts/${G_FONTDIR##*/} exists. Remove it and try again." + fi + else + ewarn "${G_FONTDIR} does not exist." + fi + fi + done + fi + else + ewarn "${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts does not exist." + fi +} + +move_app_defaults_to_etc() { + if [ -L ${ROOT}/etc/X11/app-defaults ]; then + rm -f ${ROOT}/etc/X11/app-defaults + fi + + if [ ! -L ${ROOT}/usr/$(get_libdir)/app-defaults ] \ + && [ -d ${ROOT}/usr/$(get_libdir)/app-defaults ]; then + if [ ! -d ${ROOT}/etc/X11/app-defaults ]; then + mkdir -p ${ROOT}/etc/X11/app-defaults + fi + + mv -f ${ROOT}/usr/$(get_libdir)/app-defaults ${ROOT}/etc/X11 + fi +} + +move_xkb_to_usr() { + if [ -L ${ROOT}/usr/$(get_libdir)/xkb ]; then + rm -f ${ROOT}/usr/$(get_libdir)/xkb + fi + + if [ ! -L ${ROOT}/etc/X11/xkb ] \ + && [ -d ${ROOT}/etc/X11/xkb ]; then + if [ ! -d ${ROOT}/usr/$(get_libdir)/xkb ]; then + mkdir -p ${ROOT}/usr/$(get_libdir) + fi + + mv -f ${ROOT}/etc/X11/xkb ${ROOT}/usr/$(get_libdir) + fi +} + +dynamic_libgl_preinst() { + # clean the dynamic libGL stuff's home to ensure + # we don't have stale libs floating around + if [ -d ${ROOT}/usr/$(get_libdir)/opengl/${PN} ]; then + rm -rf ${ROOT}/usr/$(get_libdir)/opengl/${PN}/* + fi + + # make sure we do not have any stale files lying around + # that could break things. Check old and new locations. + rm -f ${ROOT}/usr/X11R6/$(get_libdir)/libGL\.* \ + ${ROOT}/usr/$(get_libdir)/libGL\.* +} + +################## +# pkg_postinst() # +################## + +font_setup() { + umask 022 + + # These cause ttmkfdir to segfault :/ + rm -f ${ROOT}/usr/share/fonts/encodings/iso8859-6.8x.enc.gz + rm -f ${ROOT}/usr/share/fonts/encodings/iso8859-6.16.enc.gz +# rm -f ${ROOT}/usr/share/fonts/encodings/large/cns11643-1.enc +# rm -f ${ROOT}/usr/share/fonts/encodings/large/cns11643-2.enc +# rm -f ${ROOT}/usr/share/fonts/encodings/large/cns11643-3.enc +# rm -f ${ROOT}/usr/share/fonts/encodings/suneu-greek.enc + + # ******************************************************************** + # A note about fonts and needed files: + # + # 1) Create /usr/share/fonts/encodings/encodings.dir + # + # 2) Create fonts.scale for TrueType fonts (need to do this before + # we create fonts.dir files, else fonts.dir files will be + # invalid for TrueType fonts...) + # + # 3) Now Generate fonts.dir files. + # + # CID fonts is a bit more involved, but as we do not install any, + # thus I am not going to bother. + # + # (20 Oct 2002) + # + # ******************************************************************** + + ebegin "Generating encodings.dir" + # Create the encodings.dir in /usr/share/fonts/encodings + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontdir -n \ + -e ${ROOT}/usr/share/fonts/encodings \ + -e ${ROOT}/usr/share/fonts/encodings/large \ + -- ${ROOT}/usr/share/fonts/encodings + + eend 0 + + ebegin "Creating fonts.scale files" + local x + for x in $(find ${ROOT}/usr/share/fonts/* -maxdepth 1 -type d); do + [ -z "$(ls ${x}/)" ] && continue + [ "$(ls ${x}/)" = "fonts.cache-1" ] && continue + + # Only generate .scale files if truetype, opentype or type1 + # fonts are present ... + + # First truetype (ttf,ttc) + # NOTE: ttmkfdir does NOT work on type1 fonts (#53753) + # Also, there is no way to regenerate Speedo/CID fonts.scale + # 2 August 2004 + if [ "${x/encodings}" = "${x}" -a \ + -n "$(find ${x} -iname '*.tt[cf]' -print)" ]; then + if [ -x ${ROOT}/usr/bin/ttmkfdir ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/ttmkfdir -x 2 \ + -e ${ROOT}/usr/share/fonts/encodings/encodings.dir \ + -o ${x}/fonts.scale -d ${x} + # ttmkfdir fails on some stuff, so try mkfontscale if it does + local ttmkfdir_return=$? + else + # We didn't use ttmkfdir at all + local ttmkfdir_return=2 + fi + if [ ${ttmkfdir_return} -ne 0 ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontscale \ + -a /usr/share/fonts/encodings/encodings.dir \ + -- ${x} + fi + # Next type1 and opentype (pfa,pfb,otf,otc) + elif [ "${x/encodings}" = "${x}" -a \ + -n "$(find ${x} -iname '*.[po][ft][abcf]' -print)" ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontscale \ + -a ${ROOT}/usr/share/fonts/encodings/encodings.dir \ + -- ${x} + fi + done + eend 0 + + ebegin "Generating fonts.dir files" + for x in $(find ${ROOT}/usr/share/fonts/* -maxdepth 1 -type d); do + [ -z "$(ls ${x}/)" ] && continue + [ "$(ls ${x}/)" = "fonts.cache-1" ] && continue + + if [ "${x/encodings}" = "${x}" ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/mkfontdir \ + -e ${ROOT}/usr/share/fonts/encodings \ + -e ${ROOT}/usr/share/fonts/encodings/large \ + -- ${x} + fi + done + eend 0 + + ebegin "Generating Xft cache" + for x in $(find ${ROOT}/usr/share/fonts/* -maxdepth 1 -type d); do + [ -z "$(ls ${x}/)" ] && continue + [ "$(ls ${x}/)" = "fonts.cache-1" ] && continue + + # Only generate XftCache files if there are truetype + # fonts present ... + if [ "${x/encodings}" = "${x}" -a \ + -n "$(find ${x} -iname '*.[otps][pft][cfad]' -print)" ]; then + LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ + ${ROOT}/usr/bin/xftcache ${x} &> /dev/null + fi + done + eend 0 + + ebegin "Fixing permissions" + find ${ROOT}/usr/share/fonts/ -type f -name 'font.*' \ + -exec chmod 0644 {} \; + eend 0 + + # danarmak found out that fc-cache should be run AFTER all the above + # stuff, as otherwise the cache is invalid, and has to be run again + # as root anyway + if [ -x ${ROOT}/usr/bin/fc-cache ]; then + ebegin "Creating FC font cache" + HOME="/root" ${ROOT}/usr/bin/fc-cache + eend 0 + fi +} + +switch_opengl_implem() { + # Switch to the xorg implementation. + # Use new opengl-update that will not reset user selected + # OpenGL interface ... + echo + local opengl_implem="$(${ROOT}/usr/sbin/opengl-update --get-implementation)" + ${ROOT}/usr/sbin/opengl-update --use-old ${PN} +} + +remove_old_compose_files() { + for x in $(find ${ROOT}/usr/$(get_libdir)/X11/locale/ -mindepth 1 -type d); do + # Remove old compose files we might have created incorrectly + # CJK must not have that file (otherwise XIM don't works some times) + case $(basename ${x}) in + ja*|ko*|zh*) + if [ -r "${x}/Compose" ]; then + rm -f ${x}/Compose + fi + ;; + esac + done +} + +setup_tmp_files() { + # These need to be owned by root and the correct permissions + # (bug #8281) + local x="" + for x in ${ROOT}/tmp/.{ICE,X11}-unix; do + if [ ! -d ${x} ]; then + mkdir -p ${x} + fi + + chown root:wheel ${x} + chmod 1777 ${x} + done +} + +print_info() { + echo + einfo "Please note that the xcursors are in /usr/share/cursors/${PN}." + einfo "Any custom cursor sets should be placed in that directory." + echo + einfo "If you wish to set system-wide default cursors, please create" + einfo "/usr/local/share/cursors/${PN}/default/index.theme" + einfo "with content: \"Inherits=theme_name\" so that future" + einfo "emerges will not overwrite those settings." + echo + einfo "Listening on TCP is disabled by default with startx." + einfo "To enable it, edit /usr/bin/startx." + echo + + einfo "If you have a Radeon, set this option for direct rendering:" + einfo "Option \"ColorTiling\" \"false\"" + einfo "The Mesa in these developmental snapshots is out of date." + echo + einfo "Binary drivers may be broken in >=6.8.99.8." + einfo "See https://bugs.freedesktop.org/show_bug.cgi?id=3066." + + # (#76985) + einfo "Visit http://www.gentoo.org/doc/en/index.xml?catid=desktop" + einfo "for more information on configuring X." + + # Try to get people to read this, pending #11359 + ebeep 5 + epause 10 +} + +fix_links() { + # Fix problematic links + if [ -x ${ROOT}/usr/bin/Xorg ]; then + ln -snf ../bin ${ROOT}/usr/bin/X11 + fi +}