# 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 <spyderous@gentoo.org>;
+ +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)
--- /dev/null
+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
--- /dev/null
+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
--- /dev/null
+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 <X11/Xmd.h>
+ #include <X11/extensions/xf86dga.h>
+ #include <ctype.h>
++#include <errno.h>
+ #include <stdio.h>
+ #include <stdlib.h>
+ #include <signal.h>
+@@ -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 <errno.h>
+ #include <stdio.h>
+ #include <stdlib.h>
+ #include <unistd.h>
+@@ -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");
--- /dev/null
+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 <X11/Xmd.h>
+ #include <X11/extensions/xf86dga.h>
+ #include <ctype.h>
++#include <errno.h>
+ #include <stdio.h>
+ #include <stdlib.h>
+ #include <signal.h>
+@@ -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 <errno.h>
+ #include <stdio.h>
+ #include <stdlib.h>
+ #include <unistd.h>
+@@ -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");
--- /dev/null
+# 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 <spyderous@gentoo.org>
+# 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"
+# <Mr_Bones_> 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 <carpaski@gentoo.org>, 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.
+ #
+ # <azarah@gentoo.org> (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 <mharris@redhat.com>
+ #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. <spyderous>
+ 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 <spyderous@gentoo.org>
+ 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/\(<dead_diaeresis> <space>\).*$/\1 : "\\"" quotedbl/' \
+ -e "s/\(<dead_acute> <space>\).*$/\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 <spyderous@gentoo.org> 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. <spyderous>
+ 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.
+ #
+ # <azarah@gentoo.org> (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
+ # <spyderous@gentoo.org> 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
+}
--- /dev/null
+# 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 <spyderous@gentoo.org>
+# 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"
+# <Mr_Bones_> 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 <carpaski@gentoo.org>, 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.
+ #
+ # <azarah@gentoo.org> (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 <mharris@redhat.com>
+ #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. <spyderous>
+ 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 <spyderous@gentoo.org>
+ 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/\(<dead_diaeresis> <space>\).*$/\1 : "\\"" quotedbl/' \
+ -e "s/\(<dead_acute> <space>\).*$/\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 <spyderous@gentoo.org> 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. <spyderous>
+ 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.
+ #
+ # <azarah@gentoo.org> (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
+ # <spyderous@gentoo.org> 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
+}