diff options
author | Donnie Berkholz <dberkholz@gentoo.org> | 2005-02-11 16:32:25 +0000 |
---|---|---|
committer | Donnie Berkholz <dberkholz@gentoo.org> | 2005-02-11 16:32:25 +0000 |
commit | d01f92c24a8ef35f12342d1249da54a123fa6d31 (patch) | |
tree | 76bca7e9afa1c026dfd11d67f72014e60b7b9221 /x11-base | |
parent | Initial import - replaces kicker-* (diff) | |
download | historical-d01f92c24a8ef35f12342d1249da54a123fa6d31.tar.gz historical-d01f92c24a8ef35f12342d1249da54a123fa6d31.tar.bz2 historical-d01f92c24a8ef35f12342d1249da54a123fa6d31.zip |
Pull old versions. Still waiting for 6.8.2 to be ~alpha so 6.8.1.901-r1 can be pulled.
Package-Manager: portage-2.0.51-r15
Diffstat (limited to 'x11-base')
-rw-r--r-- | x11-base/xorg-x11/ChangeLog | 8 | ||||
-rw-r--r-- | x11-base/xorg-x11/Manifest | 10 | ||||
-rw-r--r-- | x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902 | 7 | ||||
-rw-r--r-- | x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902-r1 | 7 | ||||
-rw-r--r-- | x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.903 | 7 | ||||
-rw-r--r-- | x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.904 | 7 | ||||
-rw-r--r-- | x11-base/xorg-x11/xorg-x11-6.8.1.902-r1.ebuild | 1663 | ||||
-rw-r--r-- | x11-base/xorg-x11/xorg-x11-6.8.1.902.ebuild | 1621 | ||||
-rw-r--r-- | x11-base/xorg-x11/xorg-x11-6.8.1.903.ebuild | 1934 | ||||
-rw-r--r-- | x11-base/xorg-x11/xorg-x11-6.8.1.904.ebuild | 1963 |
10 files changed, 8 insertions, 7219 deletions
diff --git a/x11-base/xorg-x11/ChangeLog b/x11-base/xorg-x11/ChangeLog index d28105c8ef64..6a2b0270520a 100644 --- a/x11-base/xorg-x11/ChangeLog +++ b/x11-base/xorg-x11/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for x11-base/xorg-x11 # Copyright 2000-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/x11-base/xorg-x11/ChangeLog,v 1.331 2005/02/11 16:29:00 spyderous Exp $ +# $Header: /var/cvsroot/gentoo-x86/x11-base/xorg-x11/ChangeLog,v 1.332 2005/02/11 16:32:25 spyderous Exp $ + + 11 Feb 2005; Donnie Berkholz <spyderous@gentoo.org>; + -xorg-x11-6.8.1.902-r1.ebuild, -xorg-x11-6.8.1.902.ebuild, + -xorg-x11-6.8.1.903.ebuild, -xorg-x11-6.8.1.904.ebuild: + Pull old versions. Still waiting for 6.8.2 to be ~alpha so 6.8.1.901-r1 can + be pulled. 11 Feb 2005; Donnie Berkholz <spyderous@gentoo.org>; xorg-x11-6.8.2.ebuild: diff --git a/x11-base/xorg-x11/Manifest b/x11-base/xorg-x11/Manifest index 5f8b7a2ce7d6..e00d438042cd 100644 --- a/x11-base/xorg-x11/Manifest +++ b/x11-base/xorg-x11/Manifest @@ -3,19 +3,11 @@ MD5 2b9b70a8a132d04ffa84b047fc2736bb xorg-x11-6.7.0-r3.ebuild 38110 MD5 e33b194fdfcdaa928956aa1e5e937b72 xorg-x11-6.8.0-r3.ebuild 40114 MD5 1a41dee2ee7de099201ab7b03c17b409 xorg-x11-6.8.0-r4.ebuild 52259 MD5 964bf2fe7bbddb6eab73140faa911397 xorg-x11-6.8.1.901-r1.ebuild 52453 -MD5 44835fc4c8bb9d475d312cfb96671654 xorg-x11-6.8.1.902-r1.ebuild 50722 -MD5 ce42c938819216d0ca122f33b4d2b8ab xorg-x11-6.8.1.902.ebuild 50073 -MD5 27d801e7c37bd2bf6a28420da0ca959b ChangeLog 79999 -MD5 5ae63ce2f3f20585850a27e5f35ea347 xorg-x11-6.8.1.903.ebuild 57952 -MD5 3eeccf3dd28725e08ff04d3e2cf82cce xorg-x11-6.8.1.904.ebuild 59025 +MD5 1f145aad09cf57ff080d3d819ed3b12b ChangeLog 80265 MD5 25d5ff773b8d39f1589868421cca296a xorg-x11-6.8.2.ebuild 59119 MD5 a3314fbdc270d7d84ea14fd477b8d048 files/digest-xorg-x11-6.7.0-r3 904 MD5 70facbdb85b7ef2bc9b9b702442eda7e files/digest-xorg-x11-6.8.0-r3 908 MD5 0fa47dcdfd673d5824ea3a6cfe17ade0 files/digest-xorg-x11-6.8.0-r4 911 MD5 31a8fa39480a7053afd4ebd7493c09c4 files/digest-xorg-x11-6.8.1.901-r1 517 -MD5 b59b9e9b5fe5a900264d9e6766a4b3f9 files/digest-xorg-x11-6.8.1.902 517 -MD5 b59b9e9b5fe5a900264d9e6766a4b3f9 files/digest-xorg-x11-6.8.1.902-r1 517 MD5 f14e22fa0891e99c1000c0d61d7e8a0c files/xpm-secfix-thomas.diff 55674 -MD5 24b596cf50b39b2198ce67257bef8717 files/digest-xorg-x11-6.8.1.903 517 -MD5 5f3b2617d72c973605a9d3ca31fb502f files/digest-xorg-x11-6.8.1.904 517 MD5 a89ceac8aaa19a446dab3a634a027d0b files/digest-xorg-x11-6.8.2 504 diff --git a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902 b/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902 deleted file mode 100644 index e8d7cc1d8440..000000000000 --- a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902 +++ /dev/null @@ -1,7 +0,0 @@ -MD5 4d7d5fdc4ed56c144ef998302581478c eurofonts-X11.tar.bz2 8811 -MD5 01a21c248e5ac4ba02cbbea994fc774a xfsft-encodings-0.1.tar.bz2 11892 -MD5 d0fab996daf97adf095e2dad0bd9012e gentoo-cursors-tad-0.3.1.tar.bz2 1196991 -MD5 3d4ee581df78c9dacc6e97aa07a1af72 gemini-koi8-u.tar.bz2 439173 -MD5 fa04d16a9ad4dfbf7dbb42f61aafe2ae xorg-x11-6.8.1.902-files-0.3.tar.bz2 10061 -MD5 73cf1efd8841549cff52a28227bb0e87 xorg-x11-6.8.1.902-patches-0.1.2.tar.bz2 157513 -MD5 70ac870d6e531cfcd239400eca6bd6e6 xorg-x11-6.8.1.902.tar.bz2 44137497 diff --git a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902-r1 b/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902-r1 deleted file mode 100644 index e8d7cc1d8440..000000000000 --- a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.902-r1 +++ /dev/null @@ -1,7 +0,0 @@ -MD5 4d7d5fdc4ed56c144ef998302581478c eurofonts-X11.tar.bz2 8811 -MD5 01a21c248e5ac4ba02cbbea994fc774a xfsft-encodings-0.1.tar.bz2 11892 -MD5 d0fab996daf97adf095e2dad0bd9012e gentoo-cursors-tad-0.3.1.tar.bz2 1196991 -MD5 3d4ee581df78c9dacc6e97aa07a1af72 gemini-koi8-u.tar.bz2 439173 -MD5 fa04d16a9ad4dfbf7dbb42f61aafe2ae xorg-x11-6.8.1.902-files-0.3.tar.bz2 10061 -MD5 73cf1efd8841549cff52a28227bb0e87 xorg-x11-6.8.1.902-patches-0.1.2.tar.bz2 157513 -MD5 70ac870d6e531cfcd239400eca6bd6e6 xorg-x11-6.8.1.902.tar.bz2 44137497 diff --git a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.903 b/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.903 deleted file mode 100644 index 33fefcda0c74..000000000000 --- a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.903 +++ /dev/null @@ -1,7 +0,0 @@ -MD5 4d7d5fdc4ed56c144ef998302581478c eurofonts-X11.tar.bz2 8811 -MD5 01a21c248e5ac4ba02cbbea994fc774a xfsft-encodings-0.1.tar.bz2 11892 -MD5 d0fab996daf97adf095e2dad0bd9012e gentoo-cursors-tad-0.3.1.tar.bz2 1196991 -MD5 3d4ee581df78c9dacc6e97aa07a1af72 gemini-koi8-u.tar.bz2 439173 -MD5 fa04d16a9ad4dfbf7dbb42f61aafe2ae xorg-x11-6.8.1.903-files-0.1.tar.bz2 10061 -MD5 73cf1efd8841549cff52a28227bb0e87 xorg-x11-6.8.1.903-patches-0.1.1.tar.bz2 157513 -MD5 d3008407381364a3e8a6e0cce5620d37 xorg-x11-6.8.1.903.tar.bz2 44140307 diff --git a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.904 b/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.904 deleted file mode 100644 index 6512eb336630..000000000000 --- a/x11-base/xorg-x11/files/digest-xorg-x11-6.8.1.904 +++ /dev/null @@ -1,7 +0,0 @@ -MD5 4d7d5fdc4ed56c144ef998302581478c eurofonts-X11.tar.bz2 8811 -MD5 01a21c248e5ac4ba02cbbea994fc774a xfsft-encodings-0.1.tar.bz2 11892 -MD5 d0fab996daf97adf095e2dad0bd9012e gentoo-cursors-tad-0.3.1.tar.bz2 1196991 -MD5 3d4ee581df78c9dacc6e97aa07a1af72 gemini-koi8-u.tar.bz2 439173 -MD5 a39fda8a9d6a2b40a439a4cda6e93218 xorg-x11-6.8.1.904-files-0.2.tar.bz2 10047 -MD5 b0b2815cf203961365d5c37616d499ca xorg-x11-6.8.1.904-patches-0.1.3.tar.bz2 160592 -MD5 c454efee52ce34ea2462825a5c37c209 xorg-x11-6.8.1.904.tar.bz2 44140160 diff --git a/x11-base/xorg-x11/xorg-x11-6.8.1.902-r1.ebuild b/x11-base/xorg-x11/xorg-x11-6.8.1.902-r1.ebuild deleted file mode 100644 index a0317d053ce3..000000000000 --- a/x11-base/xorg-x11/xorg-x11-6.8.1.902-r1.ebuild +++ /dev/null @@ -1,1663 +0,0 @@ -# Copyright 1999-2005 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.1.902-r1.ebuild,v 1.8 2005/01/30 07:15:47 spyderous Exp $ - -# Set TDFX_RISKY to "yes" to get 16-bit, 1024x768 or higher on low-memory -# voodoo3 cards. - -# Removing any unnecessary fonts: find /usr/share/fonts/misc/ -name '*.pcf.gz' \ -# -not -name '*6x13*' -not -name 'cursor.pcf.gz' -exec rm {} \; - -# 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 -# 24 January 2005 <spyderous@gentoo.org> -# TARGET: 6.8.1.902-r1 -# 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 -# Move /usr/X11R6/include to /usr/include/X11 -# - find imake define for this -# Move /usr/X11R6/bin to /usr/bin -# Clean up migration function -# - generalize to take arguments like: -# `migrate /usr/X11R6/lib /usr/lib` so we can use for bin, include -# - loop through lib* instead of repetition -# - consider alternate to 'mv', which dies when dirs exist in both -# - cpio, rsync, tar suggested -# - cpio dereferences symlinks, tar wastes time -# Fix direction of lib -> libdir symlink -# Functionalize ebuild more cleanly -- only call subfunctions in primary -# ebuild functions, no direct code, no functions of more than 60 lines -# 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 - - -# 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 hardened - insecure-drivers ipv6 minimal mmx nls opengl pam sdk sse static - truetype-fonts type1-fonts uclibc xprint xv" -# IUSE_INPUT_DEVICES="synaptics wacom" - -FILES_VER="0.3" -PATCH_VER="0.1.2" -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/~cyfred/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/X11R6.8.2/${P}.tar.bz2" -# http://freedesktop.org/~xorg/X11R${PV}/src/X11R${PV}-src1.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src2.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src3.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src4.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src5.tar.gz -# doc? ( -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src6.tar.gz -# http://freedesktop.org/~xorg/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" -# Don't use this, work in progress -KEYWORDS="-*" - -DEPEND=">=sys-libs/ncurses-5.1 - >=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-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - >=sys-apps/sed-4 - sys-apps/util-linux - dev-lang/perl - media-libs/libpng - !virtual/xft - !virtual/x11" -# x11-libs/xft -- blocked because of interference with xorg's - -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.4 - >=media-libs/fontconfig-2.1-r1 - opengl? ( >=x11-base/opengl-update-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - media-libs/libpng - >=sys-libs/ncurses-5.1 - !virtual/xft - !virtual/x11" - -PDEPEND="x86? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - input_devices_synaptics? ( x11-misc/synaptics ) - input_devices_wacom? ( x11-misc/linuxwacom ) - ) - alpha? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - ) - !uclibc? ( x11-terms/xterm )" - -PROVIDE="virtual/x11 - opengl? virtual/opengl - 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 -} - -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 - - # We move libGLU to /usr/lib now - if use opengl; then - dosym libGLU.so.1.3 /usr/$(get_libdir)/libMesaGLU.so - fi - - if use opengl; then - dynamic_libgl_install - fi - - 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 -} - -pkg_preinst() { - # Do this before anything else, so we do all the rest inside the symlink - migrate_usr_x11r6_lib - - update_config_files - - cleanup_fonts - - 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 use hardened && ! use dlloader; then - einfo "Softening gcc for sparc" - ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-pie -fno-PIE" - append-flags "-fno-pie -fno-PIE" - 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 && best_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 - - 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 [ -z "${MULTILIB_ABIS}" ]; then - use amd64 && get_libdir_override lib64 - # lib32 isnt a supported configuration (yet?) - [ "$(get_libdir)" == "lib32" ] && get_libdir_override lib - fi -} - -################ -# src_unpack() # -################ - -unpack_all() { - # Unpack source and patches - ebegin "Unpacking source" - unpack ${P}.tar.bz2 -# unpack X11R${PV}-src{1,2,3,4,5}.tar.gz - eend 0 - -# if use doc; then -# ebegin "Unpacking documentation" -# unpack X11R${PV}-src{6,7}.tar.gz -# 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 - unpack eurofonts-X11.tar.bz2 > /dev/null - 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} -} - -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 Linux (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} - # Saving this for a later revision - # echo "#define BinDir /usr/bin" >> ${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} - 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 - #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 - - # 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 - - if ( [ -e "${ROOT}/usr/src/linux" ] \ - && ! kernel_is "2" "2" ) \ - || [ "$(uname -r | cut -d. -f1,2)" != "2.2" ]; then - echo "#define HasLinuxInput YES" >> ${HOSTCONF} - 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 - if use dlloader; then - einfo "Setting DoLoadableServer/MakeDllModules to YES." - echo "#define DoLoadableServer YES" >> ${HOSTCONF} - echo "#define MakeDllModules YES" >> ${HOSTCONF} - if use hardened; then - echo "#define HardenedGccSpecs YES" >> ${HOSTCONF} - fi - fi - fi - - use_build debug XFree86Devel - use_build debug BuildDebug - use_build debug DebuggableLibraries - - if ! use debug; then - echo "#define ExtraXInputDrivers acecad" >> ${HOSTCONF} - - # 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 && [ "$(best_version x11-base/xorg-x11)" ] - if [ "$(best_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 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 - fi - - 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 alpha; then - echo "#define XF86CardDrivers mga nv tga s3virge sis rendition \ - i740 tdfx cirrus tseng fbdev \ - ati vga v4l glint" >> ${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 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 use 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 - 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 BuildLinuxDocText - 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 - echo "#define BuildClients NO" >> ${HOSTCONF} - echo "#define BuildLBX 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} - - # Don't want to add to defaults for other archs, set above - if use x86; then - # If you want more drivers built with minimal, file a bug - # -Donnie Berkholz <spyderous@gentoo.org> - # 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} - fi - fi - - # Ajax is the man for getting this going for us - echo "#define ProPoliceSupport YES" >> ${HOSTCONF} - - # Make xprint optional - use_build xprint BuildXprint - # 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. - if [ ! "${PROFILE_ARCH}" = "xbox" ]; then - patch_exclude 9990 - 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 - 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="" \ - || die "debug make World failed" - else - FAST=1 emake World WORLDOPTS="" || die "make World failed" - fi - - if use nls; then - emake -C ${S}/nls || 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 DESTDIR=${D} \ - || make CDEBUGFLAGS="${CDEBUGFLAGS} -mno-mmx" \ - CXXDEBUGFLAGS="${CXXDEBUGFLAGS} -mno-mmx" \ - install DESTDIR=${D} || die "install failed" - else - make install DESTDIR=${D} || die "install failed" - fi - - if use sdk; then - einfo "Installing X.org X11 SDK..." - make install.sdk DESTDIR=${D} || die "sdk install failed" - fi - - if ! use minimal; then - einfo "Installing man pages..." - make install.man DESTDIR=${D} || die "man page install failed" - einfo "Compressing man pages..." - prepman /usr - fi - - if use nls; then - cd ${S}/nls - make DESTDIR=${D} install || die "nls install failed" - fi -} - -backward_compat_install() { - # Backwards compatibility for /usr/share move - G_FONTDIRS="Speedo TTF Type1 encodings local misc util" - if use cjk; then - G_FONTDIRS="${G_FONTDIRS} CID" - fi - if use bitmap-fonts; then - G_FONTDIRS="${G_FONTDIRS} 75dpi 100dpi" - fi - - dodir /usr/$(get_libdir)/X11/fonts/ - for G_FONTDIR in ${G_FONTDIRS}; do - dosym ../../../share/fonts/${G_FONTDIR} /usr/$(get_libdir)/X11/fonts/${G_FONTDIR} - done - - if ! use minimal; then - dosym ../share/man /usr/X11R6/man - fi - # Have the top-level libdir symlink made first, so real dirs don't get created - dosym ../$(get_libdir) /usr/X11R6/$(get_libdir) - dosym ../../../share/doc/${PF} /usr/X11R6/$(get_libdir)/X11/doc -# dosym ../share/bin /usr/X11R6/bin - -} - -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/X11R6/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 "Euro Support..." - LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ - ${D}/usr/X11R6/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/X11R6/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/X11R6/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 ../X11R6/bin /usr/bin/X11 - dosym ../X11R6/include/X11 /usr/include/X11 - dosym ../X11R6/include/DPS /usr/include/DPS - dosym ../X11R6/include/GL /usr/include/GL - 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() { - # .la files for libtool support - insinto /usr/$(get_libdir) - # (#67729) Needs to be lib, not $(get_libdir) - doins ${FILES_DIR}/lib/*.la -} - -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 -a ${WORKDIR}/usr/share/fonts/encodings/* \ - ${D}/usr/share/fonts/encodings - - for x in ${D}/usr/share/fonts/encodings/{.,large}/*.enc; do - [ -f "${x}" ] && gzip -9 -f ${x} \ - || eerror "gzipping ${x} failed" - done - eend 0 -} - -koi8_fonts_install() { - ebegin "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 -a ${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 ${FILES_DIR}/Xsetup_0 - 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/X11R6/include/GL/{gl.h,glx.h,glxtokens.h,glext.h}; do - if [ -f ${x} -o -L ${x} ]; then - mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/include - fi - done - # Since we added glext.h and don't have new opengl-update yet, do this - # Avoids circular opengl-update/xorg-x11 dependency - dosym ../../../$(get_libdir)/opengl/${PN}/include/glext.h /usr/X11R6/include/GL/ - 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" - 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/lib/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/lib/misc/xprint get_xpserverlist:g" ${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() # -################# - -migrate_usr_x11r6_lib() { - # We need a symlink /usr/X11R6/libdir -> /usr/libdir so all the packages - # whose files we move don't lose track of them. As such, we need - # _absolutely nothing_ in /usr/X11R6/libdir so we can make such a symlink. - # Donnie Berkholz <spyderous@gentoo.org> 20 October 2004 - - einfo "Migrating from /usr/X11R6/$(get_libdir) to /usr/$(get_libdir)..." - # Get rid of "standard" symlink from <6.8.0-r2 - # We can't overwrite symlink with directory w/ $(mv -f) - [ -L ${ROOT}usr/$(get_libdir)/X11 ] \ - && rm ${ROOT}usr/$(get_libdir)/X11 - - # If it's not a symlink (in other words, it should be a directory) - if [ ! -L ${ROOT}usr/X11R6/$(get_libdir) ]; then - einfo " /usr/X11R6/$(get_libdir) isn't a symlink, migrating..." - # Move everything - mv -f \ - ${ROOT}usr/X11R6/$(get_libdir)/* \ - ${ROOT}usr/X11R6/$(get_libdir)/.* \ - ${ROOT}usr/$(get_libdir) - # Remove any floating .keep files so we can run rmdir - find ${ROOT}usr/X11R6/$(get_libdir) -name '\.keep' -exec rm -f {} \; - # Get rid of the directory - rmdir ${ROOT}usr/X11R6/$(get_libdir) - # Put a symlink in its place - ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) - else - # If ${ROOT}usr/X11R6/$(get_libdir) is a symlink ... - einfo " /usr/X11R6/$(get_libdir) is a symlink, continuing..." - - # for amd64 at least, lib64 symlinked to lib in <=6.8.0-r4 (except -r2), - # so the migration doesn't work properly with just the above. - # (#78074) DO NOT use '-d' because it's true on symlinks to dirs too. - if [ ! -L ${ROOT}usr/X11R6/lib ]; then - einfo " /usr/X11R6/lib is a directory, migrating..." - # Move everything - mv -f \ - ${ROOT}usr/X11R6/lib/* \ - ${ROOT}usr/X11R6/lib/.* \ - ${ROOT}usr/lib - # Remove any floating .keep files so we can run rmdir - find ${ROOT}usr/X11R6/lib -name '\.keep' -exec rm -f {} \; - # Get rid of the directory - rmdir ${ROOT}usr/X11R6/lib - # Put a symlink in its place - ln -s $(get_libdir) ${ROOT}usr/X11R6/lib - # Make _sure_ we don't get a circular symlink, even though - # we do the symlink again later on - rm ${ROOT}usr/X11R6/$(get_libdir) - ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) - else - einfo " /usr/X11R6/lib isn't a directory, not migrating" - fi - 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() { - for G_FONTDIR in ${G_FONTDIRS}; do - # 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 - - # 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 -f {} \; - fi - done - - # No longer used by xorg-x11 - if [ -d ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/truetype ]; then - rm -rf ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/truetype - fi -} - -remove_font_dirs() { - if [ -d ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/${G_FONTDIR} ]; then - # local directory is for sysadmin-added fonts, so save it - # Note: if we did this in src_install(), we would bring fonts from - # the build machine to the install machine rather than just moving - # fonts on the install machine. - if [ "${G_FONTDIR}" = "local" ]; then - mv ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/${G_FONTDIR} \ - ${ROOT}/usr/share/fonts/ - else - rm -rf ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/${G_FONTDIR} - fi - 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/X11R6/bin/mkfontdir -n \ - -e ${ROOT}/usr/share/fonts/encodings \ - -e ${ROOT}/usr/share/fonts/encodings/large \ - -- ${ROOT}/usr/share/fonts/encodings - - eend 0 - - if [ -x ${ROOT}/usr/X11R6/bin/ttmkfdir ]; then - ebegin "Creating fonts.scale files..." - local x - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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 - LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ - ${ROOT}/usr/X11R6/bin/ttmkfdir -x 2 \ - -e ${ROOT}/usr/share/fonts/encodings/encodings.dir \ - -o ${x}/fonts.scale -d ${x} - # 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/X11R6/bin/mkfontscale \ - -a ${ROOT}/usr/share/fonts/encodings/encodings.dir \ - -- ${x} - fi - done - eend 0 - else - eerror "ttmkfdir not found. Unable to prepare TrueType fonts for use." - fi - - ebegin "Generating fonts.dir files..." - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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/X11R6/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/* -type d -maxdepth 1); 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/X11R6/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 - if [ "$(${ROOT}/usr/sbin/opengl-update --get-implementation)" = "xfree" ]; then - ${ROOT}/usr/sbin/opengl-update ${PN} - else - ${ROOT}/usr/sbin/opengl-update --use-old ${PN} - fi -} - -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:root ${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 set" - einfo "them in /usr/local/share/cursors/${PN} 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/X11R6/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/X11R6/bin/Xorg ]; then - ln -snf ../X11R6/bin ${ROOT}/usr/bin/X11 - ln -snf ../X11R6/include/X11 ${ROOT}/usr/include/X11 - ln -snf ../X11R6/include/DPS ${ROOT}/usr/include/DPS - if use opengl; then - ln -snf ../X11R6/include/GL ${ROOT}/usr/include/GL - fi - fi -} diff --git a/x11-base/xorg-x11/xorg-x11-6.8.1.902.ebuild b/x11-base/xorg-x11/xorg-x11-6.8.1.902.ebuild deleted file mode 100644 index 44475f59ac92..000000000000 --- a/x11-base/xorg-x11/xorg-x11-6.8.1.902.ebuild +++ /dev/null @@ -1,1621 +0,0 @@ -# Copyright 1999-2005 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.1.902.ebuild,v 1.23 2005/01/25 21:05:12 spyderous Exp $ - -# Set TDFX_RISKY to "yes" to get 16-bit, 1024x768 or higher on low-memory -# voodoo3 cards. - -# Removing any unnecessary fonts: find /usr/share/fonts/misc/ -name '*.pcf.gz' \ -# -not -name '*6x13*' -not -name 'cursor.pcf.gz' -exec rm {} \; - -# 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 -# 24 January 2005 <spyderous@gentoo.org> -# TARGET: 6.8.1.902-r1 -# 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 -# Move /usr/X11R6/include to /usr/include/X11 -# Move /usr/X11R6/bin to /usr/bin -# Clean up migration function -# - generalize to take arguments like: -# `migrate /usr/X11R6/lib /usr/lib` so we can use for bin, include -# - loop through lib* instead of repetition -# - consider alternate to 'mv', which dies when dirs exist in both -# - cpio, rsync, tar suggested -# - cpio dereferences symlinks, tar wastes time -# Fix direction of lib -> libdir symlink -# Functionalize ebuild more cleanly -- only call subfunctions in primary -# ebuild functions, no direct code - -inherit eutils flag-o-matic toolchain-funcs x11 linux-info - - -# 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 hardened - insecure-drivers ipv6 minimal mmx nls opengl pam sdk sse static - truetype-fonts type1-fonts uclibc xprint xv" -# IUSE_INPUT_DEVICES="synaptics wacom" - -FILES_VER="0.3" -PATCH_VER="0.1.2" -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/~cyfred/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/X11R6.8.2/${P}.tar.bz2" -# http://freedesktop.org/~xorg/X11R${PV}/src/X11R${PV}-src1.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src2.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src3.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src4.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src5.tar.gz -# doc? ( -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src6.tar.gz -# http://freedesktop.org/~xorg/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="~x86 ~ppc ~mips ~ppc64 ~amd64 ~sparc" - -DEPEND=">=sys-libs/ncurses-5.1 - >=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-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - >=sys-apps/sed-4 - sys-apps/util-linux - dev-lang/perl - media-libs/libpng - !virtual/xft - !virtual/x11" -# x11-libs/xft -- blocked because of interference with xorg's - -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.4 - >=media-libs/fontconfig-2.1-r1 - opengl? ( >=x11-base/opengl-update-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - media-libs/libpng - >=sys-libs/ncurses-5.1 - !virtual/xft - !virtual/x11" - -PDEPEND="x86? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - input_devices_synaptics? ( x11-misc/synaptics ) - input_devices_wacom? ( x11-misc/linuxwacom ) - ) - alpha? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - ) - !uclibc? ( x11-terms/xterm )" - -PROVIDE="virtual/x11 - opengl? virtual/opengl - 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 USE flag combinations - check_use_combos - - # 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 [ -z "${MULTILIB_ABIS}" ]; then - use amd64 && get_libdir_override lib64 - # lib32 isnt a supported configuration (yet?) - [ "$(get_libdir)" == "lib32" ] && get_libdir_override lib - 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 -} - -src_unpack() { - - # Unpack source and patches - ebegin "Unpacking source" - unpack ${P}.tar.bz2 -# unpack X11R${PV}-src{1,2,3,4,5}.tar.gz - eend 0 - -# if use doc; then -# ebegin "Unpacking documentation" -# unpack X11R${PV}-src{6,7}.tar.gz -# 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 - unpack eurofonts-X11.tar.bz2 > /dev/null - 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 - - patch_setup - - # Bulk patching - based on patch name - # Will create excluded stuff once it's needed - cd ${WORKDIR} - EPATCH_SUFFIX="patch" \ - epatch ${PATCHDIR} - cd ${S} - - host_def_setup - - # 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() { - - # 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="" \ - || die "debug make World failed" - else - FAST=1 emake World WORLDOPTS="" || die "make World failed" - fi - - if use nls; then - emake -C ${S}/nls || die "nls build failed" - fi - -} - -src_install() { - - unset MAKE_OPTS - - install_everything - - backward_compat_setup - - 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 - - # Some critical directories - if ! use minimal; then - keepdir /var/lib/xdm - dosym ../../../var/lib/xdm /etc/X11/xdm/authdir - fi - - # .la files for libtool support - insinto /usr/$(get_libdir) - # (#67729) Needs to be lib, not $(get_libdir) - doins ${FILES_DIR}/lib/*.la - - # Backwards compat, FHS, etc. - dosym ../../usr/X11R6/bin/Xorg /etc/X11/X - - # Fix perms - if ! use minimal; then - fperms 755 /usr/$(get_libdir)/X11/xkb/geometry/sgi /usr/X11R6/bin/dga - fi - - compose_files_setup - - if use font-server; then - encode_xfsft_files - fi - - if use nls; then - setup_koi8_fonts - fi - - etc_files_install - - # We move libGLU to /usr/lib now - if ! use opengl; then - dosym libGLU.so.1.3 /usr/$(get_libdir)/libMesaGLU.so - fi - - if use opengl; then - setup_dynamic_libgl - fi - - # 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 - - strip_execs - - if ! use minimal; then - install_extra_cursors - fi - - # Get rid of all unnecessary fonts (saves ~5.5 MB) - if use minimal; then - find ${D}/usr/share/fonts/misc/ -name '*.pcf.gz' \ - -not -name '*6x13*' -not -name 'cursor.pcf.gz' -exec rm {} \; - fi - - # Remove xterm app-defaults, since we don't install xterm -# rm ${D}/etc/X11/app-defaults/{UXTerm,XTerm,XTerm-color} - - # For Battoussai's gatos stuffs: - if use sdk; then - insinto /usr/$(get_libdir)/Server/include - doins ${S}/extras/drm/shared/drm.h - fi - - # If we want xprint, save the init script before deleting /etc/rc.d/ - # Requested on #68316 - if use xprint; then - setup_xprint_init - 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 - - setup_config_files - - # Woohoo, another 772K - if use minimal; then - rm -rf ${D}/usr/share/doc - fi -} - -pkg_preinst() { - # Do this before anything else, so we do all the rest inside the symlink - migrate_usr_x11r6_lib - - update_config_files - - for G_FONTDIR in ${G_FONTDIRS}; do - # 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 - - # 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 -f {} \; - fi - done - - # No longer used by xorg-x11 - if [ -d ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/truetype ]; then - rm -rf ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/truetype - 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 - clean_dynamic_libgl -} - -pkg_postinst() { - - local x="" - - env-update - - if [ "${ROOT}" = "/" ]; then - umask 022 - - font_setup - - if use opengl; then - switch_opengl_implem - fi - fi - - remove_old_compose_files - - # These need to be owned by root and the correct permissions - # (bug #8281) - for x in ${ROOT}/tmp/.{ICE,X11}-unix; do - if [ ! -d ${x} ]; then - mkdir -p ${x} - fi - - chown root:root ${x} - chmod 1777 ${x} - done - - print_info -} - -pkg_postrm() { - - # Fix problematic links - if [ -x ${ROOT}/usr/X11R6/bin/Xorg ]; then - ln -snf ../X11R6/bin ${ROOT}/usr/bin/X11 - ln -snf ../X11R6/include/X11 ${ROOT}/usr/include/X11 - ln -snf ../X11R6/include/DPS ${ROOT}/usr/include/DPS - if use opengl; then - ln -snf ../X11R6/include/GL ${ROOT}/usr/include/GL - fi - fi -} - -############### -# 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 use hardened && ! use dlloader; then - einfo "Softening gcc for sparc" - ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-pie -fno-PIE" - append-flags "-fno-pie -fno-PIE" - 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 && best_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 - - 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 -} - -################ -# src_unpack() # -################ - -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 Linux (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} - # Saving this for a later revision - # echo "#define BinDir /usr/bin" >> ${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} - 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 - #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 - - # 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 - - if ( [ -e "${ROOT}/usr/src/linux" ] \ - && ! kernel_is "2" "2" ) \ - || [ "$(uname -r | cut -d. -f1,2)" != "2.2" ]; then - echo "#define HasLinuxInput YES" >> ${HOSTCONF} - 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 - if use dlloader; then - einfo "Setting DoLoadableServer/MakeDllModules to YES." - echo "#define DoLoadableServer YES" >> ${HOSTCONF} - echo "#define MakeDllModules YES" >> ${HOSTCONF} - if use hardened; then - echo "#define HardenedGccSpecs YES" >> ${HOSTCONF} - fi - fi - fi - - use_build debug XFree86Devel - use_build debug BuildDebug - use_build debug DebuggableLibraries - - if ! use debug; then - echo "#define ExtraXInputDrivers acecad" >> ${HOSTCONF} - - # 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 && [ "$(best_version x11-base/xorg-x11)" ] - if [ "$(best_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 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 - fi - - 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 alpha; then - echo "#define XF86CardDrivers mga nv tga s3virge sis rendition \ - i740 tdfx cirrus tseng fbdev \ - ati vga v4l glint" >> ${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 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 use 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 - 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 BuildLinuxDocText - 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 - echo "#define BuildClients NO" >> ${HOSTCONF} - echo "#define BuildLBX 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} - - # Don't want to add to defaults for other archs, set above - if use x86; then - # If you want more drivers built with minimal, file a bug - # -Donnie Berkholz <spyderous@gentoo.org> - # 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} - fi - fi - - # Ajax is the man for getting this going for us - echo "#define ProPoliceSupport YES" >> ${HOSTCONF} - - # Make xprint optional - use_build xprint BuildXprint - # 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. - if [ ! "${PROFILE_ARCH}" = "xbox" ]; then - patch_exclude 9990 - 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 - einfo "Done excluding patches" -} - -################# -# src_install() # -################# - -install_everything() { - 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 DESTDIR=${D} \ - || make CDEBUGFLAGS="${CDEBUGFLAGS} -mno-mmx" \ - CXXDEBUGFLAGS="${CXXDEBUGFLAGS} -mno-mmx" \ - install DESTDIR=${D} || die "install failed" - else - make install DESTDIR=${D} || die "install failed" - fi - - if use sdk; then - einfo "Installing X.org X11 SDK..." - make install.sdk DESTDIR=${D} || die "sdk install failed" - fi - - if ! use minimal; then - einfo "Installing man pages..." - make install.man DESTDIR=${D} || die "man page install failed" - einfo "Compressing man pages..." - prepman /usr - fi - - if use nls; then - cd ${S}/nls - make DESTDIR=${D} install || die "nls install failed" - fi -} - -backward_compat_setup() { - # Backwards compatibility for /usr/share move - G_FONTDIRS="Speedo TTF Type1 encodings local misc util" - if use cjk; then - G_FONTDIRS="${G_FONTDIRS} CID" - fi - if use bitmap-fonts; then - G_FONTDIRS="${G_FONTDIRS} 75dpi 100dpi" - fi - - dodir /usr/$(get_libdir)/X11/fonts/ - for G_FONTDIR in ${G_FONTDIRS}; do - dosym ../../../share/fonts/${G_FONTDIR} /usr/$(get_libdir)/X11/fonts/${G_FONTDIR} - done - - if ! use minimal; then - dosym ../share/man /usr/X11R6/man - fi - # Have the top-level libdir symlink made first, so real dirs don't get created - dosym ../$(get_libdir) /usr/X11R6/$(get_libdir) - dosym ../../../share/doc/${PF} /usr/X11R6/$(get_libdir)/X11/doc -# dosym ../share/bin /usr/X11R6/bin - -} - -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 -} - -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 "Euro Support..." - LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${D}/usr/$(get_libdir)" \ - ${D}/usr/X11R6/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/X11R6/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/X11R6/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 ../X11R6/bin /usr/bin/X11 - dosym ../X11R6/include/X11 /usr/include/X11 - dosym ../X11R6/include/DPS /usr/include/DPS - dosym ../X11R6/include/GL /usr/include/GL - dosym ../../usr/$(get_libdir)/X11/xkb /etc/X11/xkb -} - -compose_files_setup() { - # 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 -a ${WORKDIR}/usr/share/fonts/encodings/* \ - ${D}/usr/share/fonts/encodings - - for x in ${D}/usr/share/fonts/encodings/{.,large}/*.enc; do - [ -f "${x}" ] && gzip -9 -f ${x} \ - || eerror "gzipping ${x} failed" - done - eend 0 -} - -setup_koi8_fonts() { - ebegin "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 -a ${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 ${FILES_DIR}/Xsetup_0 - 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 -} - -setup_dynamic_libgl() { - # 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/X11R6/include/GL/{gl.h,glx.h,glxtokens.h,glext.h}; do - if [ -f ${x} -o -L ${x} ]; then - mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/include - fi - done - # Since we added glext.h and don't have new opengl-update yet, do this - # Avoids circular opengl-update/xorg-x11 dependency - dosym ../../../$(get_libdir)/opengl/${PN}/include/glext.h /usr/X11R6/include/GL/ - eend 0 -} - -strip_execs() { - if use debug || has nostrip ${FEATURES}; then - ewarn "Debug build turned on by USE=debug" - 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/* -} - -setup_xprint_init() { - # RH-style init script, we provide a wrapper - exeinto /usr/lib/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/lib/misc/xprint get_xpserverlist:g" ${D}/etc/profile.d/xprint* -} - -setup_config_files() { - - # 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() # -################# - -migrate_usr_x11r6_lib() { - # We need a symlink /usr/X11R6/libdir -> /usr/libdir so all the packages - # whose files we move don't lose track of them. As such, we need - # _absolutely nothing_ in /usr/X11R6/libdir so we can make such a symlink. - # Donnie Berkholz <spyderous@gentoo.org> 20 October 2004 - - einfo "Migrating from /usr/X11R6/$(get_libdir) to /usr/$(get_libdir)..." - # Get rid of "standard" symlink from <6.8.0-r2 - # We can't overwrite symlink with directory w/ $(mv -f) - [ -L ${ROOT}usr/$(get_libdir)/X11 ] \ - && rm ${ROOT}usr/$(get_libdir)/X11 - - # If it's not a symlink (in other words, it should be a directory) - if [ ! -L ${ROOT}usr/X11R6/$(get_libdir) ]; then - einfo " /usr/X11R6/$(get_libdir) isn't a symlink, migrating..." - # Move everything - mv -f \ - ${ROOT}usr/X11R6/$(get_libdir)/* \ - ${ROOT}usr/X11R6/$(get_libdir)/.* \ - ${ROOT}usr/$(get_libdir) - # Remove any floating .keep files so we can run rmdir - find ${ROOT}usr/X11R6/$(get_libdir) -name '\.keep' -exec rm -f {} \; - # Get rid of the directory - rmdir ${ROOT}usr/X11R6/$(get_libdir) - # Put a symlink in its place - ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) - else - # If ${ROOT}usr/X11R6/$(get_libdir) is a symlink ... - einfo " /usr/X11R6/$(get_libdir) is a symlink, continuing..." - - # for amd64 at least, lib64 symlinked to lib in <=6.8.0-r4 (except -r2), - # so the migration doesn't work properly with just the above. - # (#78074) DO NOT use '-d' because it's true on symlinks to dirs too. - if [ ! -L ${ROOT}usr/X11R6/lib ]; then - einfo " /usr/X11R6/lib is a directory, migrating..." - # Move everything - mv -f \ - ${ROOT}usr/X11R6/lib/* \ - ${ROOT}usr/X11R6/lib/.* \ - ${ROOT}usr/lib - # Remove any floating .keep files so we can run rmdir - find ${ROOT}usr/X11R6/lib -name '\.keep' -exec rm -f {} \; - # Get rid of the directory - rmdir ${ROOT}usr/X11R6/lib - # Put a symlink in its place - ln -s $(get_libdir) ${ROOT}usr/X11R6/lib - # Make _sure_ we don't get a circular symlink, even though - # we do the symlink again later on - rm ${ROOT}usr/X11R6/$(get_libdir) - ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) - else - einfo " /usr/X11R6/lib isn't a directory, not migrating" - fi - 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 -} - -remove_font_dirs() { - if [ -d ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/${G_FONTDIR} ]; then - # local directory is for sysadmin-added fonts, so save it - # Note: if we did this in src_install(), we would bring fonts from - # the build machine to the install machine rather than just moving - # fonts on the install machine. - if [ "${G_FONTDIR}" = "local" ]; then - mv ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/${G_FONTDIR} \ - ${ROOT}/usr/share/fonts/ - else - rm -rf ${ROOT}/usr/X11R6/$(get_libdir)/X11/fonts/${G_FONTDIR} - fi - 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 -} - -clean_dynamic_libgl() { - # 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() { - # 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/X11R6/bin/mkfontdir -n \ - -e ${ROOT}/usr/share/fonts/encodings \ - -e ${ROOT}/usr/share/fonts/encodings/large \ - -- ${ROOT}/usr/share/fonts/encodings - - eend 0 - - if [ -x ${ROOT}/usr/X11R6/bin/ttmkfdir ]; then - ebegin "Creating fonts.scale files..." - local x - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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 - LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ - ${ROOT}/usr/X11R6/bin/ttmkfdir -x 2 \ - -e ${ROOT}/usr/share/fonts/encodings/encodings.dir \ - -o ${x}/fonts.scale -d ${x} - # 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/X11R6/bin/mkfontscale \ - -a ${ROOT}/usr/share/fonts/encodings/encodings.dir \ - -- ${x} - fi - done - eend 0 - else - eerror "ttmkfdir not found. Unable to prepare TrueType fonts for use." - fi - - ebegin "Generating fonts.dir files..." - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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/X11R6/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/* -type d -maxdepth 1); 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/X11R6/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 - if [ "$(${ROOT}/usr/sbin/opengl-update --get-implementation)" = "xfree" ]; then - ${ROOT}/usr/sbin/opengl-update ${PN} - else - ${ROOT}/usr/sbin/opengl-update --use-old ${PN} - fi -} - -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 -} - -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 set" - einfo "them in /usr/local/share/cursors/${PN} 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/X11R6/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 -} diff --git a/x11-base/xorg-x11/xorg-x11-6.8.1.903.ebuild b/x11-base/xorg-x11/xorg-x11-6.8.1.903.ebuild deleted file mode 100644 index 438323474adb..000000000000 --- a/x11-base/xorg-x11/xorg-x11-6.8.1.903.ebuild +++ /dev/null @@ -1,1934 +0,0 @@ -# Copyright 1999-2005 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.1.903.ebuild,v 1.6 2005/02/05 08:57:25 spyderous Exp $ - -# Set TDFX_RISKY to "yes" to get 16-bit, 1024x768 or higher on low-memory -# voodoo3 cards. - -# What to use for migration from /usr/X11R6 to /usr -- mv, rsync or tar. -# By default it uses 'rsync'. -#MIGRATE_METHOD="rsync" - -# 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 -# 24 January 2005 <spyderous@gentoo.org> -# TARGET: 6.8.1.903 -# 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 -# Move /usr/X11R6/include to /usr/include/X11 -# - find imake define for this -# Move /usr/X11R6/bin to /usr/bin -# Clean up migration function -# - generalize to take arguments like: -# `migrate /usr/X11R6/lib /usr/lib` so we can use for bin, include -# - loop through lib* instead of repetition -# - consider alternate to 'mv', which dies when dirs exist in both -# - cpio, rsync, tar suggested -# - cpio dereferences symlinks, tar wastes time -# Fix direction of lib -> libdir symlink -# Functionalize ebuild more cleanly -- only call subfunctions in primary -# ebuild functions, no direct code, no functions of more than 60 lines -# 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 - - -# 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 hardened - insecure-drivers ipv6 minimal mmx nls opengl pam sdk sse 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/~cyfred/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/X11R6.8.2/${P}.tar.bz2" -# http://freedesktop.org/~xorg/X11R${PV}/src/X11R${PV}-src1.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src2.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src3.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src4.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src5.tar.gz -# doc? ( -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src6.tar.gz -# http://freedesktop.org/~xorg/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="-* ~ppc64" - -DEPEND=">=sys-libs/ncurses-5.1 - >=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-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - >=sys-apps/sed-4 - sys-apps/util-linux - dev-lang/perl - media-libs/libpng - !<=app-emulation/emul-linux-x86-xlibs-1.2-r3 - !virtual/xft - !virtual/x11" -# x11-libs/xft -- blocked because of interference with xorg's - -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.4 - >=media-libs/fontconfig-2.1-r1 - opengl? ( >=x11-base/opengl-update-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - media-libs/libpng - >=sys-libs/ncurses-5.1 - !<=app-emulation/emul-linux-x86-xlibs-1.2-r3 - !virtual/xft - !virtual/x11" - -PDEPEND="x86? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - input_devices_synaptics? ( x11-misc/synaptics ) - input_devices_wacom? ( x11-misc/linuxwacom ) - ) - alpha? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - ) - !uclibc? ( x11-terms/xterm )" - -PROVIDE="virtual/x11 - opengl? virtual/opengl - 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" - ${MIGRATE_METHOD:+einfo Migration method is ${MIGRATE_METHOD}.} - - # 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 -} - -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 - - # We move libGLU to /usr/lib now - if use opengl; then - dosym libGLU.so.1.3 /usr/$(get_libdir)/libMesaGLU.so - fi - - if use opengl; then - dynamic_libgl_install - fi - - 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 - - # 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 use hardened && ! use dlloader; then - einfo "Softening gcc for sparc" - ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-pie -fno-PIE" - append-flags "-fno-pie -fno-PIE" - 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 && best_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 - - 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 [ -z "${MULTILIB_ABIS}" ]; then - use amd64 && get_libdir_override lib64 - # lib32 isnt a supported configuration (yet?) - [ "$(get_libdir)" == "lib32" ] && get_libdir_override lib - fi -} - -################ -# src_unpack() # -################ - -unpack_all() { - # Unpack source and patches - ebegin "Unpacking ${PV} source" - unpack ${P}.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 - unpack eurofonts-X11.tar.bz2 > /dev/null - 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} -} - -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 Linux (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} - 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 - #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 - - # 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 - - if ( [ -e "${ROOT}/usr/src/linux" ] \ - && ! kernel_is "2" "2" ) \ - || [ "$(uname -r | cut -d. -f1,2)" != "2.2" ]; then - echo "#define HasLinuxInput YES" >> ${HOSTCONF} - 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 - if use dlloader; then - einfo "Setting DoLoadableServer/MakeDllModules to YES." - echo "#define DoLoadableServer YES" >> ${HOSTCONF} - echo "#define MakeDllModules YES" >> ${HOSTCONF} - if use hardened; then - echo "#define HardenedGccSpecs YES" >> ${HOSTCONF} - fi - fi - fi - - use_build debug XFree86Devel - use_build debug BuildDebug - use_build debug DebuggableLibraries - - if ! use debug; then - echo "#define ExtraXInputDrivers acecad" >> ${HOSTCONF} - - # 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 && [ "$(best_version x11-base/xorg-x11)" ] - if [ "$(best_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 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 - fi - - 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 alpha; then - echo "#define XF86CardDrivers mga nv tga s3virge sis rendition \ - i740 tdfx cirrus tseng fbdev \ - ati vga v4l glint" >> ${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 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 use 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 - 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 BuildLinuxDocText - 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 - echo "#define BuildClients NO" >> ${HOSTCONF} - echo "#define BuildLBX 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} - - # Don't want to add to defaults for other archs, set above - if use x86; then - # If you want more drivers built with minimal, file a bug - # -Donnie Berkholz <spyderous@gentoo.org> - # 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} - fi - fi - - # Ajax is the man for getting this going for us - echo "#define ProPoliceSupport YES" >> ${HOSTCONF} - - # Make xprint optional - use_build xprint BuildXprint - # 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. - if [ ! "${PROFILE_ARCH}" = "xbox" ]; then - patch_exclude 9990 - 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 - 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="" \ - || die "debug make World failed" - else - FAST=1 emake World WORLDOPTS="" || die "make World failed" - fi - - if use nls; then - emake -C ${S}/nls || 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 DESTDIR=${D} \ - || make CDEBUGFLAGS="${CDEBUGFLAGS} -mno-mmx" \ - CXXDEBUGFLAGS="${CXXDEBUGFLAGS} -mno-mmx" \ - install DESTDIR=${D} || die "install failed" - else - make install DESTDIR=${D} || die "install failed" - fi - - if use sdk; then - einfo "Installing X.org X11 SDK..." - make install.sdk DESTDIR=${D} || die "sdk install failed" - fi - - if ! use minimal; then - einfo "Installing man pages..." - make install.man DESTDIR=${D} || die "man page install failed" - einfo "Compressing man pages..." - prepman /usr - fi - - if use nls; then - cd ${S}/nls - make DESTDIR=${D} install || die "nls install failed" - fi -} - -backward_compat_install() { - # Backwards compatibility for /usr/share move - dosym ../../share/fonts /usr/$(get_libdir)/X11/fonts - -# dodir /usr/X11R6 - dosym ../share/man /usr/X11R6/man - - # 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 - -# dodir /usr/X11R6/$(get_libdir)/X11 - 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 "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 ../X11R6/include/X11 /usr/include/X11 -# dosym ../X11R6/include/DPS /usr/include/DPS - 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 -} - -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 -a ${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 "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 -a ${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 ${FILES_DIR}/Xsetup_0 - 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}; do - if [ -f ${x} -o -L ${x} ]; then - mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/include - fi - done - # Since we added glext.h and don't have new opengl-update yet, do this - # Avoids circular opengl-update/xorg-x11 dependency - dosym ../../../$(get_libdir)/opengl/${PN}/include/glext.h /usr/include/GL/ - 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" - 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/lib/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/lib/misc/xprint get_xpserverlist:g" ${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() { - MIGRATE_METHOD="${MIGRATE_METHOD:-rsync}" - - einfo "Migrating from ${1} to ${2}..." - einfo "Migration method is ${MIGRATE_METHOD}." - - # 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 - case "${MIGRATE_METHOD}" in - mv) - mv -f \ - ${ROOT}${1}/* \ - ${ROOT}${1}/.* \ - ${ROOT}${2} > ${T}/migrate-${1//\//-}.log 2>&1 - - check_migrate_return - # Don't do remove_migrated_files here because this isn't a - # copy - ;; - rsync) - 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} - ;; - tar) - # Clearly we can't redirect stdout for the first half, - # because that's where the tar file is being sent. - tar \ - -C ${ROOT}${1} \ - --create \ - --verbose \ - . 2> ${T}/migrate-${1//\//-}.log \ - | - tar \ - -C ${ROOT}${2} \ - --extract \ - --verbose \ - --preserve-permissions \ - --atime-preserve \ - --same-owner >> ${T}/migrate-${1//\//-}.log 2>&1 - # Doesn't work properly - # --keep-newer-files - - check_migrate_return - remove_migrated_files ${1} - ;; - *) - die "MIGRATE_METHOD unspecified. Set it to mv, rsync or tar." - ;; - esac - -# # Move everything -# if [ "${MIGRATE_METHOD}" = "mv" ]; then -# mv -f \ -# ${ROOT}${1}/* \ -# ${ROOT}${1}/.* \ -# ${ROOT}${2} > ${T}/migrate-${1//\//-}.log 2>&1 -# -# check_migrate_return -# # Don't do remove_migrated_files here because this isn't a copy -# -# elif [ "${MIGRATE_METHOD}" = "rsync" ]; then -# 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} -# -# elif [ "${MIGRATE_METHOD}" = "tar" ]; then -# # Clearly we can't redirect stdout for the first half, because -# # that's where the tar file is being sent. -# tar \ -# -C ${ROOT}${1} \ -# --create \ -# --verbose \ -# . 2> ${T}/migrate-${1//\//-}.log \ -# | -# tar \ -# -C ${ROOT}${2} \ -# --extract \ -# --verbose \ -# --preserve-permissions \ -# --atime-preserve \ -# --same-owner >> ${T}/migrate-${1//\//-}.log 2>&1 -# # Doesn't work properly -# # --keep-newer-files -# -# check_migrate_return -# remove_migrated_files ${1} -# -# else -# die "MIGRATE_METHOD unspecified. Set it to mv, rsync or tar." -# fi - - 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 "${MIGRATE_METHOD} successful!" - else - die "${MIGRATE_METHOD} failed. Exit code: ${MIGRATE_RETURN}." - 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 -} - -#migrate_usr_x11r6_lib() { -# # We need a symlink /usr/X11R6/libdir -> /usr/libdir so all the packages -# # whose files we move don't lose track of them. As such, we need -# # _absolutely nothing_ in /usr/X11R6/libdir so we can make such a symlink. -# # Donnie Berkholz <spyderous@gentoo.org> 20 October 2004 -# -# einfo "Migrating from /usr/X11R6/$(get_libdir) to /usr/$(get_libdir)..." -# # Get rid of "standard" symlink from <6.8.0-r2 -# # We can't overwrite symlink with directory w/ $(mv -f) -# [ -L ${ROOT}usr/$(get_libdir)/X11 ] \ -# && rm ${ROOT}usr/$(get_libdir)/X11 -# -# # If it's not a symlink (in other words, it should be a directory) -# if [ ! -L ${ROOT}usr/X11R6/$(get_libdir) ]; then -# einfo " /usr/X11R6/$(get_libdir) isn't a symlink, migrating..." -# # Move everything -# mv -f \ -# ${ROOT}usr/X11R6/$(get_libdir)/* \ -# ${ROOT}usr/X11R6/$(get_libdir)/.* \ -# ${ROOT}usr/$(get_libdir) -# # Remove any floating .keep files so we can run rmdir -# find ${ROOT}usr/X11R6/$(get_libdir) -name '\.keep' -exec rm -f {} \; -# # Get rid of the directory -# rmdir ${ROOT}usr/X11R6/$(get_libdir) -# # Put a symlink in its place -# ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) -# else -# # If ${ROOT}usr/X11R6/$(get_libdir) is a symlink ... -# einfo " /usr/X11R6/$(get_libdir) is a symlink, continuing..." -# -# # for amd64 at least, lib64 symlinked to lib in <=6.8.0-r4 (except -r2), -# # so the migration doesn't work properly with just the above. -# # (#78074) DO NOT use '-d' because it's true on symlinks to dirs too. -# if [ ! -L ${ROOT}usr/X11R6/lib ]; then -# einfo " /usr/X11R6/lib is a directory, migrating..." -# # Move everything -# mv -f \ -# ${ROOT}usr/X11R6/lib/* \ -# ${ROOT}usr/X11R6/lib/.* \ -# ${ROOT}usr/lib -# # Remove any floating .keep files so we can run rmdir -# find ${ROOT}usr/X11R6/lib -name '\.keep' -exec rm -f {} \; -# # Get rid of the directory -# rmdir ${ROOT}usr/X11R6/lib -# # Put a symlink in its place -# ln -s $(get_libdir) ${ROOT}usr/X11R6/lib -# # Make _sure_ we don't get a circular symlink, even though -# # we do the symlink again later on -# rm ${ROOT}usr/X11R6/$(get_libdir) -# ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) -# else -# einfo " /usr/X11R6/lib isn't a directory, not migrating" -# fi -# 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 - - if [ -x ${ROOT}/usr/bin/ttmkfdir ]; then - ebegin "Creating fonts.scale files..." - local x - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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 - 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} - # 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 - else - eerror "ttmkfdir not found. Unable to prepare TrueType fonts for use." - fi - - ebegin "Generating fonts.dir files..." - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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/* -type d -maxdepth 1); 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 - if [ "$(${ROOT}/usr/sbin/opengl-update --get-implementation)" = "xfree" ]; then - ${ROOT}/usr/sbin/opengl-update ${PN} - else - ${ROOT}/usr/sbin/opengl-update --use-old ${PN} - fi -} - -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:root ${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 set" - einfo "them in /usr/local/share/cursors/${PN} 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 - ln -snf ../include ${ROOT}/usr/X11R6/include -# ln -snf ../X11R6/include/X11 ${ROOT}/usr/include/X11 -# ln -snf ../X11R6/include/DPS ${ROOT}/usr/include/DPS - fi -} diff --git a/x11-base/xorg-x11/xorg-x11-6.8.1.904.ebuild b/x11-base/xorg-x11/xorg-x11-6.8.1.904.ebuild deleted file mode 100644 index f43896b9d97f..000000000000 --- a/x11-base/xorg-x11/xorg-x11-6.8.1.904.ebuild +++ /dev/null @@ -1,1963 +0,0 @@ -# Copyright 1999-2005 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.1.904.ebuild,v 1.17 2005/02/11 01:00:38 eradicator Exp $ - -# Set TDFX_RISKY to "yes" to get 16-bit, 1024x768 or higher on low-memory -# voodoo3 cards. - -# What to use for migration from /usr/X11R6 to /usr -- mv, rsync or tar. -# By default it uses 'rsync'. -#MIGRATE_METHOD="rsync" - -# 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 -# 24 January 2005 <spyderous@gentoo.org> -# TARGET: 6.8.1.903 -# 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 -# Move /usr/X11R6/include to /usr/include/X11 -# - find imake define for this -# Move /usr/X11R6/bin to /usr/bin -# Clean up migration function -# - generalize to take arguments like: -# `migrate /usr/X11R6/lib /usr/lib` so we can use for bin, include -# - loop through lib* instead of repetition -# - consider alternate to 'mv', which dies when dirs exist in both -# - cpio, rsync, tar suggested -# - cpio dereferences symlinks, tar wastes time -# Fix direction of lib -> libdir symlink -# Functionalize ebuild more cleanly -- only call subfunctions in primary -# ebuild functions, no direct code, no functions of more than 60 lines -# 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 hardened - insecure-drivers ipv6 minimal mmx nls opengl pam sdk sse static - truetype-fonts type1-fonts uclibc xprint xv" -# IUSE_INPUT_DEVICES="synaptics wacom" - -FILES_VER="0.2" -PATCH_VER="0.1.3" -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/~cyfred/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/X11R6.8.2/${P}.tar.bz2" -# http://freedesktop.org/~xorg/X11R${PV}/src/X11R${PV}-src1.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src2.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src3.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src4.tar.gz -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src5.tar.gz -# doc? ( -# http://freedesktop.org/~xorg/X11R${PV}/src//X11R${PV}-src6.tar.gz -# http://freedesktop.org/~xorg/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="~amd64 ~arm ~hppa ~ia64 ~mips ~ppc64 ~sparc ~x86 ~ppc" - -DEPEND=">=sys-libs/ncurses-5.1 - >=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-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - >=sys-apps/sed-4 - sys-apps/util-linux - dev-lang/perl - media-libs/libpng - !<=app-emulation/emul-linux-x86-xlibs-1.2-r3 - !virtual/xft - !virtual/x11" -# x11-libs/xft -- blocked because of interference with xorg's - -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.4 - >=media-libs/fontconfig-2.1-r1 - opengl? ( >=x11-base/opengl-update-1.99 ) - >=x11-misc/ttmkfdir-3.0.9-r2 - media-libs/libpng - >=sys-libs/ncurses-5.1 - !<=app-emulation/emul-linux-x86-xlibs-1.2-r3 - !virtual/xft - !virtual/x11" - -PDEPEND="x86? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - input_devices_synaptics? ( x11-misc/synaptics ) - input_devices_wacom? ( x11-misc/linuxwacom ) - ) - alpha? ( - 3dfx? ( >=media-libs/glide-v3-3.10 ) - ) - !uclibc? ( x11-terms/xterm )" - -PROVIDE="virtual/x11 - opengl? virtual/opengl - 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" - ${MIGRATE_METHOD:+einfo Migration method is ${MIGRATE_METHOD}.} - - # 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 -} - -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 - - 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 - - # 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 use hardened && ! use dlloader; then - einfo "Softening gcc for sparc" - ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-pie -fno-PIE" - append-flags "-fno-pie -fno-PIE" - 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 && best_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 - - 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 - # lib32 isnt a supported configuration (yet?) - [ "$(get_libdir)" == "lib32" ] && get_libdir_override lib - fi -} - -################ -# src_unpack() # -################ - -unpack_all() { - # Unpack source and patches - ebegin "Unpacking ${PV} source" - unpack ${P}.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 - unpack eurofonts-X11.tar.bz2 > /dev/null - 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} -} - -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 Linux (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} - 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 - #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 - - # 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 - - if ( [ -e "${ROOT}/usr/src/linux" ] \ - && ! kernel_is "2" "2" ) \ - || [ "$(uname -r | cut -d. -f1,2)" != "2.2" ]; then - echo "#define HasLinuxInput YES" >> ${HOSTCONF} - 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 - if use dlloader; then - einfo "Setting DoLoadableServer/MakeDllModules to YES." - echo "#define DoLoadableServer YES" >> ${HOSTCONF} - echo "#define MakeDllModules YES" >> ${HOSTCONF} - if use hardened; then - echo "#define HardenedGccSpecs YES" >> ${HOSTCONF} - fi - fi - fi - - use_build debug XFree86Devel - use_build debug BuildDebug - use_build debug DebuggableLibraries - - if ! use debug; then - echo "#define ExtraXInputDrivers acecad" >> ${HOSTCONF} - - # 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 && [ "$(best_version x11-base/xorg-x11)" ] - if [ "$(best_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 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 - fi - - 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 alpha; then - echo "#define XF86CardDrivers mga nv tga s3virge sis rendition \ - i740 tdfx cirrus tseng fbdev \ - ati vga v4l glint" >> ${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 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 use 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 - 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 BuildLinuxDocText - 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} - - # Don't want to add to defaults for other archs, set above - if use x86; then - # If you want more drivers built with minimal, file a bug - # -Donnie Berkholz <spyderous@gentoo.org> - # 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} - fi - fi - - # Ajax is the man for getting this going for us - echo "#define ProPoliceSupport YES" >> ${HOSTCONF} - - # Make xprint optional - use_build xprint BuildXprint - # 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. - if [ ! "${PROFILE_ARCH}" = "xbox" ]; then - patch_exclude 9990 - 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 - 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="" \ - || die "debug make World failed" - else - FAST=1 emake World WORLDOPTS="" || die "make World failed" - fi - - if use nls; then - emake -C ${S}/nls || 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 DESTDIR=${D} \ - || make CDEBUGFLAGS="${CDEBUGFLAGS} -mno-mmx" \ - CXXDEBUGFLAGS="${CXXDEBUGFLAGS} -mno-mmx" \ - install DESTDIR=${D} || die "install failed" - else - make install DESTDIR=${D} || die "install failed" - fi - - if use sdk; then - einfo "Installing X.org X11 SDK..." - make install.sdk DESTDIR=${D} || die "sdk install failed" - fi - - if ! use minimal; then - einfo "Installing man pages..." - make install.man DESTDIR=${D} || die "man page install failed" - einfo "Compressing man pages..." - prepman /usr - fi - - if use nls; then - cd ${S}/nls - make DESTDIR=${D} install || die "nls install failed" - fi -} - -backward_compat_install() { - # Backwards compatibility for /usr/share move - dosym ../../share/fonts /usr/$(get_libdir)/X11/fonts - -# dodir /usr/X11R6 -# dosym ../share/man /usr/X11R6/man - - # 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 - -# dodir /usr/X11R6/$(get_libdir)/X11 - 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 "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 ../X11R6/include/X11 /usr/include/X11 -# dosym ../X11R6/include/DPS /usr/include/DPS - 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 "$(find ${D} -name *.la)" -} - -fix_libtool_libdir_paths() { - local dirpath - for archive in ${*} ; do - dirpath=$(dirname ${archive} | sed -e "s:^${D}::") - 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 -a ${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 "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 -a ${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 ${FILES_DIR}/Xsetup_0 - 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}; do - if [ -f ${x} -o -L ${x} ]; then - mv -f ${x} ${D}/usr/$(get_libdir)/opengl/${PN}/include - fi - done - # Since we added glext.h and don't have new opengl-update yet, do this - # Avoids circular opengl-update/xorg-x11 dependency - dosym ../../../$(get_libdir)/opengl/${PN}/include/glext.h /usr/include/GL/ - 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" - 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/lib/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/lib/misc/xprint get_xpserverlist:g" ${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() { - MIGRATE_METHOD="${MIGRATE_METHOD:-rsync}" - - einfo "Migrating from ${1} to ${2}..." - einfo "Migration method is ${MIGRATE_METHOD}." - - # 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 - case "${MIGRATE_METHOD}" in - mv) - mv -f \ - ${ROOT}${1}/* \ - ${ROOT}${1}/.* \ - ${ROOT}${2} > ${T}/migrate-${1//\//-}.log 2>&1 - - check_migrate_return - # Don't do remove_migrated_files here because this isn't a - # copy - ;; - rsync) - 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} - ;; - tar) - # Clearly we can't redirect stdout for the first half, - # because that's where the tar file is being sent. - tar \ - -C ${ROOT}${1} \ - --create \ - --verbose \ - . 2> ${T}/migrate-${1//\//-}.log \ - | - tar \ - -C ${ROOT}${2} \ - --extract \ - --verbose \ - --preserve-permissions \ - --atime-preserve \ - --same-owner >> ${T}/migrate-${1//\//-}.log 2>&1 - # Doesn't work properly - # --keep-newer-files - - check_migrate_return - remove_migrated_files ${1} - ;; - *) - die "MIGRATE_METHOD unspecified. Set it to mv, rsync or tar." - ;; - esac - -# # Move everything -# if [ "${MIGRATE_METHOD}" = "mv" ]; then -# mv -f \ -# ${ROOT}${1}/* \ -# ${ROOT}${1}/.* \ -# ${ROOT}${2} > ${T}/migrate-${1//\//-}.log 2>&1 -# -# check_migrate_return -# # Don't do remove_migrated_files here because this isn't a copy -# -# elif [ "${MIGRATE_METHOD}" = "rsync" ]; then -# 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} -# -# elif [ "${MIGRATE_METHOD}" = "tar" ]; then -# # Clearly we can't redirect stdout for the first half, because -# # that's where the tar file is being sent. -# tar \ -# -C ${ROOT}${1} \ -# --create \ -# --verbose \ -# . 2> ${T}/migrate-${1//\//-}.log \ -# | -# tar \ -# -C ${ROOT}${2} \ -# --extract \ -# --verbose \ -# --preserve-permissions \ -# --atime-preserve \ -# --same-owner >> ${T}/migrate-${1//\//-}.log 2>&1 -# # Doesn't work properly -# # --keep-newer-files -# -# check_migrate_return -# remove_migrated_files ${1} -# -# else -# die "MIGRATE_METHOD unspecified. Set it to mv, rsync or tar." -# fi - - 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 "${MIGRATE_METHOD} successful!" - else - die "${MIGRATE_METHOD} failed. Exit code: ${MIGRATE_RETURN}." - 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 -} - -#migrate_usr_x11r6_lib() { -# # We need a symlink /usr/X11R6/libdir -> /usr/libdir so all the packages -# # whose files we move don't lose track of them. As such, we need -# # _absolutely nothing_ in /usr/X11R6/libdir so we can make such a symlink. -# # Donnie Berkholz <spyderous@gentoo.org> 20 October 2004 -# -# einfo "Migrating from /usr/X11R6/$(get_libdir) to /usr/$(get_libdir)..." -# # Get rid of "standard" symlink from <6.8.0-r2 -# # We can't overwrite symlink with directory w/ $(mv -f) -# [ -L ${ROOT}usr/$(get_libdir)/X11 ] \ -# && rm ${ROOT}usr/$(get_libdir)/X11 -# -# # If it's not a symlink (in other words, it should be a directory) -# if [ ! -L ${ROOT}usr/X11R6/$(get_libdir) ]; then -# einfo " /usr/X11R6/$(get_libdir) isn't a symlink, migrating..." -# # Move everything -# mv -f \ -# ${ROOT}usr/X11R6/$(get_libdir)/* \ -# ${ROOT}usr/X11R6/$(get_libdir)/.* \ -# ${ROOT}usr/$(get_libdir) -# # Remove any floating .keep files so we can run rmdir -# find ${ROOT}usr/X11R6/$(get_libdir) -name '\.keep' -exec rm -f {} \; -# # Get rid of the directory -# rmdir ${ROOT}usr/X11R6/$(get_libdir) -# # Put a symlink in its place -# ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) -# else -# # If ${ROOT}usr/X11R6/$(get_libdir) is a symlink ... -# einfo " /usr/X11R6/$(get_libdir) is a symlink, continuing..." -# -# # for amd64 at least, lib64 symlinked to lib in <=6.8.0-r4 (except -r2), -# # so the migration doesn't work properly with just the above. -# # (#78074) DO NOT use '-d' because it's true on symlinks to dirs too. -# if [ ! -L ${ROOT}usr/X11R6/lib ]; then -# einfo " /usr/X11R6/lib is a directory, migrating..." -# # Move everything -# mv -f \ -# ${ROOT}usr/X11R6/lib/* \ -# ${ROOT}usr/X11R6/lib/.* \ -# ${ROOT}usr/lib -# # Remove any floating .keep files so we can run rmdir -# find ${ROOT}usr/X11R6/lib -name '\.keep' -exec rm -f {} \; -# # Get rid of the directory -# rmdir ${ROOT}usr/X11R6/lib -# # Put a symlink in its place -# ln -s $(get_libdir) ${ROOT}usr/X11R6/lib -# # Make _sure_ we don't get a circular symlink, even though -# # we do the symlink again later on -# rm ${ROOT}usr/X11R6/$(get_libdir) -# ln -s ../$(get_libdir) ${ROOT}usr/X11R6/$(get_libdir) -# else -# einfo " /usr/X11R6/lib isn't a directory, not migrating" -# fi -# 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 - - if [ -x ${ROOT}/usr/bin/ttmkfdir ]; then - ebegin "Creating fonts.scale files..." - local x - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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 - 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} - # 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 - else - eerror "ttmkfdir not found. Unable to prepare TrueType fonts for use." - fi - - ebegin "Generating fonts.dir files..." - for x in $(find ${ROOT}/usr/share/fonts/* -type d -maxdepth 1); 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/* -type d -maxdepth 1); 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 - if [ "$(${ROOT}/usr/sbin/opengl-update --get-implementation)" = "xfree" ]; then - ${ROOT}/usr/sbin/opengl-update ${PN} - else - ${ROOT}/usr/sbin/opengl-update --use-old ${PN} - fi -} - -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:root ${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 set" - einfo "them in /usr/local/share/cursors/${PN} 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 -# ln -snf ../include ${ROOT}/usr/X11R6/include -# ln -snf ../X11R6/include/X11 ${ROOT}/usr/include/X11 -# ln -snf ../X11R6/include/DPS ${ROOT}/usr/include/DPS - fi -} |