public inbox for gentoo-user@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-user] util-linux failed to patch while emergeing
@ 2011-02-13  5:58 meino.cramer
  2011-02-14 17:11 ` [gentoo-user] " walt
  0 siblings, 1 reply; 2+ messages in thread
From: meino.cramer @ 2011-02-13  5:58 UTC (permalink / raw
  To: Gentoo

Hi,

this morning I got this while emergeing util-linux:

    >>> Emerging (1 of 1) sys-apps/util-linux-2.19
    * util-linux-2.19.tar.bz2 RMD160 SHA1 SHA256 size ;-) ...              [ ok ]
    * util-linux-ng-2.18-20100706.diff.bz2 RMD160 SHA1 SHA256 size ;-) ... [ ok ]
    * Package:    sys-apps/util-linux-2.19
    * Repository: gentoo
    * Maintainer: base-system@gentoo.org
    * USE:  amd64 cramfs crypt elibc_glibc kernel_linux loop-aes multilib nls perl userland_GNU
    >>> Unpacking source...
    >>> Unpacking util-linux-2.19.tar.bz2 to /var/tmp/portage/sys-apps/util-linux-2.19/work
    >>> Unpacking util-linux-ng-2.18-20100706.diff.bz2 to /var/tmp/portage/sys-apps/util-linux-2.19/work
    >>> Source unpacked in /var/tmp/portage/sys-apps/util-linux-2.19/work
    >>> Preparing source in /var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-2.19 ...
    * Applying util-linux-ng-2.18-20100706.diff ...

    * Failed Patch: util-linux-ng-2.18-20100706.diff !
    *  ( /var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-ng-2.18-20100706.diff )
    *
    * Include in your bugreport the contents of:
    *
    *   /var/tmp/portage/sys-apps/util-linux-2.19/temp/util-linux-ng-2.18-20100706.diff.out

    * ERROR: sys-apps/util-linux-2.19 failed:
    *   Failed Patch: util-linux-ng-2.18-20100706.diff!
    *
    * Call stack:
    *     ebuild.sh, line   56:  Called src_prepare
    *   environment, line 3097:  Called epatch '/var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-ng-2.18-20100706.diff'
    *   environment, line 1690:  Called die
    * The specific snippet of code:
    *               die "Failed Patch: ${patchname}!";
    *
    * If you need support, post the output of 'emerge --info =sys-apps/util-linux-2.19',
    * the complete build log and the output of 'emerge -pqv =sys-apps/util-linux-2.19'.
    * The complete build log is located at '/var/tmp/portage/sys-apps/util-linux-2.19/temp/build.log'.
    * The ebuild environment file is located at '/var/tmp/portage/sys-apps/util-linux-2.19/temp/environment'.
    * S: '/var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-2.19'


emerge --info =sys-apps/util-linux-2.19:

    zsh: sys-apps/util-linux-2.19 not found


emerge -pqv =sys-apps/util-linux-2.19

    zsh: sys-apps/util-linux-2.19 not found

/var/tmp/portage/sys-apps/util-linux-2.19/temp/build.log:

    * Package:    sys-apps/util-linux-2.19
    * Repository: gentoo
    * Maintainer: base-system@gentoo.org
    * USE:  amd64 cramfs crypt elibc_glibc kernel_linux loop-aes multilib nls perl userland_GNU
    >>> Unpacking source...
    >>> Unpacking util-linux-2.19.tar.bz2 to /var/tmp/portage/sys-apps/util-linux-2.19/work
    >>> Unpacking util-linux-ng-2.18-20100706.diff.bz2 to /var/tmp/portage/sys-apps/util-linux-2.19/work
    >>> Source unpacked in /var/tmp/portage/sys-apps/util-linux-2.19/work
    >>> Preparing source in /var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-2.19 ...
    * Applying util-linux-ng-2.18-20100706.diff ...

    * Failed Patch: util-linux-ng-2.18-20100706.diff !
    *  ( /var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-ng-2.18-20100706.diff )
    * 
    * Include in your bugreport the contents of:
    * 
    *   /var/tmp/portage/sys-apps/util-linux-2.19/temp/util-linux-ng-2.18-20100706.diff.out

    * ERROR: sys-apps/util-linux-2.19 failed:
    *   Failed Patch: util-linux-ng-2.18-20100706.diff!
    * 
    * Call stack:
    *     ebuild.sh, line   56:  Called src_prepare
    *   environment, line 3097:  Called epatch '/var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-ng-2.18-20100706.diff'
    *   environment, line 1690:  Called die
    * The specific snippet of code:
    *               die "Failed Patch: ${patchname}!";
    * 
    * If you need support, post the output of 'emerge --info =sys-apps/util-linux-2.19',
    * the complete build log and the output of 'emerge -pqv =sys-apps/util-linux-2.19'.
    * The complete build log is located at '/var/tmp/portage/sys-apps/util-linux-2.19/temp/build.log'.
    * The ebuild environment file is located at '/var/tmp/portage/sys-apps/util-linux-2.19/temp/environment'.
    * S: '/var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-2.19'


 /var/tmp/portage/sys-apps/util-linux-2.19/temp/environment


    declare -x ABI="amd64"
    declare -x ALSA_CARDS=""
    declare -x ALSA_PCM_PLUGINS="adpcm alaw asym copy dmix dshare dsnoop empty extplug file hooks iec958 ioplug ladspa lfloat linear meter mmap_emul mulaw multi null plug rate route share shm softvol"
    declare -x ANT_HOME="/usr/share/ant"
    declare -x APACHE2_MODULES="actions alias auth_basic authn_alias authn_anon authn_dbm authn_default authn_file authz_dbm authz_default authz_groupfile authz_host authz_owner authz_user autoindex cache cgi cgid dav dav_fs dav_lock deflate dir disk_cache env expires ext_filter file_cache filter headers include info log_config logio mem_cache mime mime_magic negotiation rewrite setenvif speling status unique_id userdir usertrack vhost_alias"
    declare -x ARCH="amd64"
    declare -x ASFLAGS_x86="--32"
    declare -x AXIOM="/usr/axiom/mnt/linux"
    declare -x CBUILD="x86_64-pc-linux-gnu"
    declare -x CDEFINE_amd64="__x86_64__"
    declare -x CDEFINE_default="__unix__"
    declare -x CDEFINE_x86="__i386__"
    declare -x CFLAGS="-march=native -O2 -pipe -msse3"
    declare -x CFLAGS_default=""
    declare -x CFLAGS_x86="-m32"
    declare -x CHOST="x86_64-pc-linux-gnu"
    declare -x CHOST_amd64="x86_64-pc-linux-gnu"
    declare -x CHOST_default="x86_64-pc-linux-gnu"
    declare -x CHOST_x86="i686-pc-linux-gnu"
    declare -x COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog"
    declare -x CROSSCOMPILE_OPTS=""
    declare -x CTARGET_default="x86_64-pc-linux-gnu"
    declare -x CXXFLAGS="-march=native -O2 -pipe -msse3"
    declare -x DEFAULT_ABI="amd64"
    declare -x DEFINED_PHASES=" configure install prepare"
    declare -- DEPEND="!sys-process/schedutils
        !sys-apps/setarch
        >=sys-libs/ncurses-5.2-r2
        !<sys-libs/e2fsprogs-libs-1.41.8
        !<sys-fs/e2fsprogs-1.41.8
        cramfs? ( sys-libs/zlib )
        perl? ( dev-lang/perl )
        selinux? ( sys-libs/libselinux )
        slang? ( sys-libs/slang )
        nls? ( sys-devel/gettext )
        virtual/os-headers "
    declare -- DESCRIPTION="Various useful Linux utilities"
    declare -x DESTTREE="/usr"
    declare -x DIFMT="SvFUaPTM"
    declare -x DIROPTIONS="-m0755"
    declare -x EAPI="2"
    declare -- EGIT_REPO_URI="git://git.kernel.org/pub/scm/utils/util-linux/util-linux.git"
    declare -x ELIBC="glibc"
    declare -- ELT_PATCH_DIR="/usr/portage/eclass/ELT-patches"
    declare -- EPATCH_EXCLUDE=""
    declare -- EPATCH_FORCE="no"
    declare -- EPATCH_MULTI_MSG="Applying various patches (bugfixes/updates) ..."
    declare -- EPATCH_OPTS="-g0 -E --no-backup-if-mismatch"
    declare -- EPATCH_SINGLE_MSG=""
    declare -- EPATCH_SOURCE="/var/tmp/portage/sys-apps/util-linux-2.19/work/patch"
    declare -- EPATCH_SUFFIX="patch.bz2"
    declare -x EXEOPTIONS="-m0755"
    declare -x FETCHCOMMAND_SSH="bash -c \"x=\\\${2#ssh://} ; host=\\\${x%%/*} ; port=\\\${host##*:} ; host=\\\${host%:*} ; [[ \\\${host} = \\\${port} ]] && port=22 ; exec rsync --rsh=\\\"ssh -p\\\${port}\\\" -avP \\\"\\\${host}:/\\\${x#*/}\\\" \\\"\\\$1\\\"\" rsync \"\${DISTDIR}/\${FILE}\" \"\${URI}\""
    declare -x FLTK_DOCDIR="/usr/share/doc/fltk-2.0_pre6970/html"
    declare -x FRACTDIR="/usr/share/xfractint"
    declare -x GCC_SPECS=""
    declare -x GDK_USE_XFT="1"
    declare -x GNOME_LIBCONFIG_PATH="/usr/lib"
    declare -x GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock itrax mtk3301 nmea ntrip navcom oceanserver oldstyle oncore rtcm104v2 rtcm104v3 sirf superstar2 timing tsip tripmate tnt ubx"
    declare -x G_BROKEN_FILENAMES=""
    declare -x HELPDIR="/usr/local/lib/zsh/help"
    declare -x HISTSIZE="30000"
    declare -- HOMEPAGE="http://www.kernel.org/pub/linux/utils/util-linux/"
    declare -x INHERITED="toolchain-funcs portability flag-o-matic multilib libtool eutils"
    declare -x INPUT_DEVICES="evdev"
    declare -x INSDESTTREE=""
    declare -x INSOPTIONS="-m0644"
    declare -- IUSE="+cramfs crypt loop-aes nls old-linux perl selinux slang uclibc unicode "
    declare -x KERNEL="linux"
    declare -x KERNEL_ABI="amd64"
    declare -x KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86"
    declare -x KFORTH_DIR="/usr/share/kForth"
    declare -x KV="2.6.37"
    declare -x LADSPA_PATH="/usr/lib64/ladspa"
    declare -x LANG="C"
    declare -x LANGUAGE="C"
    declare -x LCD_DEVICES=""
    declare -x LC_ALL="C"
    declare -x LC_COLLATE="C"
    declare -x LC_CTYPE="C"
    declare -x LDFLAGS="-Wl,-O1 -Wl,--as-needed"
    declare -x LDFLAGS_default=""
    declare -x LDFLAGS_x86="-m elf_i386"
    declare -x LIBDIR_amd64="lib64"
    declare -x LIBDIR_amd64_fbsd="lib64"
    declare -x LIBDIR_default="lib"
    declare -x LIBDIR_ppc="lib32"
    declare -x LIBDIR_ppc64="lib64"
    declare -x LIBDIR_sparc32="lib32"
    declare -x LIBDIR_sparc64="lib64"
    declare -x LIBDIR_x86="lib32"
    declare -x LIBDIR_x86_fbsd="lib32"
    declare -x LIBOPTIONS="-m0644"
    declare -x LICENSE="GPL-2"
    declare -x MAIL="/var/spool/mail/root"
    declare -x MAKEOPTS="-j 1"
    declare -x MC_COLOR_TABLE="base_color=normal=green,black:normal=green,black:menuhot=red,cyan:menuhotsel=red,cyan:directory=cyan,black:executable=green,black:link=red,black:device=green,black:special=green,black:core=green,black:hidden=green,black:temp=green,black:doc=green,black:archive=green,black:source=green,black:media=green,black:graph=green,black:database=green,black:marked=black,yellow:stalelink=black,red:editnormal=green,black"
    declare -x MULTILIB_ABIS="amd64 x86"
    declare -x MULTILIB_STRICT_DENY="64-bit.*shared object"
    declare -x MULTILIB_STRICT_DIRS="/lib32 /lib /usr/lib32 /usr/lib /usr/kde/*/lib32 /usr/kde/*/lib /usr/qt/*/lib32 /usr/qt/*/lib /usr/X11R6/lib32 /usr/X11R6/lib"
    declare -x MULTILIB_STRICT_EXEMPT="(perl5|gcc|gcc-lib|binutils|eclipse-3|debug|portage)"
    declare -- MY_P="util-linux-2.19"
    declare -- MY_PV="2.19"
    declare -x NETBEANS="apisupport cnd groovy gsf harness ide identity j2ee java mobility nb php profiler soa visualweb webcommon websvccommon xml"
    declare -x OPENGL_PROFILE="nvidia"
    declare -x PATH="/usr/lib64/portage/bin/ebuild-helpers:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/opt/bin:/usr/x86_64-pc-linux-gnu/gcc-bin/4.4.4"
    declare -- PDEPEND=" "
    declare -x PERLIO="stdio"
    declare -x PHP_TARGETS="php5-3"
    declare -x PILOTPORT="/dev/tts/0"
    declare -x PKGHOME="/root/NetModule/nmpackages"
    declare -x PKG_CONFIG_PATH="/usr/lib/pkgconfig:/usr/local/lib/pkgconfig"
    declare -x PORTAGE_COMPRESS_EXCLUDE_SUFFIXES="css gif htm[l]? jp[e]?g js pdf png"
    declare -a PORTAGE_DOCOMPRESS='([0]="/usr/share/doc" [1]="/usr/share/info" [2]="/usr/share/man")'
    declare -a PORTAGE_DOCOMPRESS_SKIP='([0]="/usr/share/doc/util-linux-2.19/html")'
    declare -x PRELINK_PATH_MASK="/usr/lib64/klibc:/usr/lib64/libfreebl3.so:/usr/lib64/libnssdbm3.so:/usr/lib64/libsoftokn3.so"
    declare -x PROFILE_ONLY_VARIABLES="ARCH ELIBC KERNEL USERLAND"
    declare -x PROPERTIES=""
    declare -x PROVIDE=""
    declare -x PYTHONDOCS="/usr/share/doc/python-docs-2.6.5/html/library"
    declare -x PYTHONDOCS_2_6="/usr/share/doc/python-docs-2.6.5/html/library"
    declare -x PYTHONDOCS_3_1="/usr/share/doc/python-docs-3.1.2/html/library"
    declare -x PYTHONDONTWRITEBYTECODE="1"
    declare -x PYTHONPATH="/usr/local/lib64/python2.6/site-packages"
    declare -x RDEPEND="!sys-process/schedutils
        !sys-apps/setarch
        >=sys-libs/ncurses-5.2-r2
        !<sys-libs/e2fsprogs-libs-1.41.8
        !<sys-fs/e2fsprogs-1.41.8
        cramfs? ( sys-libs/zlib )
        perl? ( dev-lang/perl )
        selinux? ( sys-libs/libselinux )
        slang? ( sys-libs/slang ) "
    declare -- REQUIRED_USE=" "
    declare -x RESTRICT=""
    declare -x RESUMECOMMAND_SSH="bash -c \"x=\\\${2#ssh://} ; host=\\\${x%%/*} ; port=\\\${host##*:} ; host=\\\${host%:*} ; [[ \\\${host} = \\\${port} ]] && port=22 ; exec rsync --rsh=\\\"ssh -p\\\${port}\\\" -avP \\\"\\\${host}:/\\\${x#*/}\\\" \\\"\\\$1\\\"\" rsync \"\${DISTDIR}/\${FILE}\" \"\${URI}\""
    declare -x RUBYOPT="-rauto_gem"
    declare -x RUBY_TARGETS=""
    declare -x S="/var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-2.19"
    declare -x SANDBOX_DEBUG="0"
    declare -x SANDBOX_DENY=""
    declare -x SANDBOX_PID="8701"
    declare -x SANDBOX_PREDICT="/var/tmp/portage/sys-apps/util-linux-2.19/homedir:/dev/crypto:/var/cache/fontconfig"
    declare -x SANDBOX_READ="/:/dev/stdin:/var/tmp"
    declare -x SANDBOX_VERBOSE="1"
    declare -x SANDBOX_WRITE=":/dev/console:/dev/fd:/dev/full:/dev/null:/dev/pts/:/dev/pty:/dev/shm:/dev/stderr:/dev/stdout:/dev/tts:/dev/tty:/dev/vc/:/dev/zero:/proc/self/fd:/tmp/:/usr/lib/cf:/usr/lib/conftest:/usr/lib32/cf:/usr/lib32/conftest:/usr/lib64/cf:/usr/lib64/conftest:/usr/tmp/cf:/usr/tmp/conftest:/var/tmp:/var/tmp/:/var/tmp/portage/sys-apps/util-linux-2.19/homedir/.bash_history"
    declare -x SGML_CATALOG_FILES="/etc/sgml/sgml-docbook-4.0.cat:/etc/sgml/sgml-lite.cat:/etc/sgml/sgml-docbook-4.1.cat:/etc/sgml/xml-docbook-4.4.cat:/etc/sgml/xml-docbook-4.3.cat:/etc/sgml/sgml-docbook-3.0.cat:/etc/sgml/xml-docbook-4.2.cat:/etc/sgml/xml-docbook-4.5.cat:/etc/sgml/sgml-docbook.cat:/etc/sgml/sgml-ent.cat:/etc/sgml/openjade-1.3.2.cat:/etc/sgml/sgml-docbook-3.1.cat"
    declare -x SLOT="0"
    declare -x SRCDIR="/home/mccramer/xfractint"
    declare -- SRC_URI="mirror://kernel/linux/utils/util-linux/v2.19/util-linux-2.19.tar.bz2
            loop-aes? ( http://loop-aes.sourceforge.net/updates/util-linux-ng-2.18-20100706.diff.bz2 )"
    declare -x STAGE1_USE="multilib nptl nptlonly unicode"
    declare -x SUDO_COMMAND="/bin/zsh"
    declare -x SUDO_GID="100"
    declare -x SUDO_UID="1001"
    declare -x SUDO_USER="mccramer"
    declare -x SYMLINK_LIB="yes"
    declare -x TEXDOCVIEW_dvi="kgh %s"
    declare -x TEXDOCVIEW_html="dillo %s"
    declare -x TEXDOCVIEW_pdf="kgh %s"
    declare -x TEXDOCVIEW_ps="kghostview %s"
    declare -x USE="amd64 cramfs crypt elibc_glibc kernel_linux loop-aes multilib nls perl userland_GNU"
    declare -x USERLAND="GNU"
    declare -x USERNAME="root"
    declare -x VIDEO_CARDS=""
    declare -x XDG_CONFIG_DIRS="/etc/xdg"
    declare -x XDG_DATA_DIRS="/root/.local/share:/usr/local/share/:/usr/share/"
    declare -x XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipset ipp2p iface geoip fuzzy condition tee tarpit sysrq steal rawnat logmark ipmark dhcpmac delude chaos account"
    declare -x XZ_OPT="--memory=max"
    declare -- _="PKG_INSTALL_MASK"
    declare -x _E_DOCDESTTREE_=""
    declare -x _E_EXEDESTTREE_=""
    declare -- ___ECLASS_RECUR_MULTILIB="yes"
    declare -- ___ECLASS_RECUR_TOOLCHAIN_FUNCS="yes"
    declare -x zshloader=":/root/.zshenv:/root/.zshrc"
    ELT_libtool_version () 
    { 
        ( unset VERSION;
        eval $(grep -e '^[[:space:]]*VERSION=' "$1");
        echo "${VERSION:-0}" )
    }
    ELT_try_and_apply_patch () 
    { 
        local ret=0;
        local file=$1;
        local patch=$2;
        if patch -p0 --dry-run "${file}" "${patch}" &>"${T}/elibtool.log"; then
            einfo "  Applying $(basename "$(dirname "${patch}")")-${patch##*/}.patch ...";
            patch -p0 -g0 --no-backup-if-mismatch "${file}" "${patch}" &>"${T}/elibtool.log";
            ret=$?;
            export ELT_APPLIED_PATCHES="${ELT_APPLIED_PATCHES} ${patch##*/}";
        else
            ret=1;
        fi;
        return "${ret}"
    }
    ELT_walk_patches () 
    { 
        local patch;
        local ret=1;
        local file=$1;
        local patch_set=$2;
        local patch_dir="${ELT_PATCH_DIR}/${patch_set}";
        local rem_int_dep=$3;
        [[ -z ${patch_set} ]] && return 1;
        [[ ! -d ${patch_dir} ]] && return 1;
        pushd "${ELT_PATCH_DIR}" > /dev/null;
        for patch in $(find "${patch_set}" -maxdepth 1 -type f | LC_ALL=C sort -r);
        do
            if [[ -n ${rem_int_dep} ]]; then
                local tmp="${T}/$$.rem_int_deps.patch";
                sed -e "s|@REM_INT_DEP@|${rem_int_dep}|g" "${patch}" > "${tmp}";
                patch=${tmp};
            fi;
            if ELT_try_and_apply_patch "${file}" "${patch}"; then
                ret=0;
                break;
            fi;
        done;
        popd > /dev/null;
        return ${ret}
    }
    VER_major () 
    { 
        [[ -z $1 ]] && return 1;
        local VER=$@;
        echo "${VER%%[^[:digit:]]*}"
    }
    VER_micro () 
    { 
        [[ -z $1 ]] && return 1;
        local VER=$@;
        VER=${VER#*.*.};
        echo "${VER%%[^[:digit:]]*}"
    }
    VER_minor () 
    { 
        [[ -z $1 ]] && return 1;
        local VER=$@;
        VER=${VER#*.};
        echo "${VER%%[^[:digit:]]*}"
    }
    VER_to_int () 
    { 
        [[ -z $1 ]] && return 1;
        local VER_MAJOR=$(VER_major "$1");
        local VER_MINOR=$(VER_minor "$1");
        local VER_MICRO=$(VER_micro "$1");
        local VER_int=$(( VER_MAJOR * 65536 + VER_MINOR * 256 + VER_MICRO ));
        if [[ ${VER_int} -ge 65536 ]]; then
            echo "${VER_int}";
            return 0;
        fi;
        echo 1;
        return 1
    }
    _cdrom_locate_file_on_cd () 
    { 
        local mline="";
        local showedmsg=0 showjolietmsg=0;
        while [[ -z ${CDROM_ROOT} ]]; do
            local i=0;
            local -a cdset=(${*//:/ });
            if [[ -n ${CDROM_SET} ]]; then
                cdset=(${cdset[${CDROM_SET}]});
            fi;
            while [[ -n ${cdset[${i}]} ]]; do
                local dir=$(dirname ${cdset[${i}]});
                local file=$(basename ${cdset[${i}]});
                local point= node= fs= foo=;
                while read point node fs foo; do
                    [[ " cd9660 iso9660 udf " != *" ${fs} "* ]] && ! [[ ${fs} == "subfs" && ",${opts}," == *",fs=cdfss,"* ]] && continue;
                    point=${point//\040/ };
                    [[ ! -d ${point}/${dir} ]] && continue;
                    [[ -z $(find "${point}/${dir}" -maxdepth 1 -iname "${file}") ]] && continue;
                    export CDROM_ROOT=${point};
                    export CDROM_SET=${i};
                    export CDROM_MATCH=${cdset[${i}]};
                    return;
                done <<< "$(get_mounts)";
                ((++i));
            done;
            echo;
            if [[ ${showedmsg} -eq 0 ]]; then
                if [[ ${CDROM_TOTAL_CDS} -eq 1 ]]; then
                    if [[ -z ${CDROM_NAME} ]]; then
                        einfo "Please insert+mount the cdrom for ${PN} now !";
                    else
                        einfo "Please insert+mount the ${CDROM_NAME} cdrom now !";
                    fi;
                else
                    if [[ -z ${CDROM_NAME_1} ]]; then
                        einfo "Please insert+mount cd #${CDROM_CURRENT_CD} for ${PN} now !";
                    else
                        local var="CDROM_NAME_${CDROM_CURRENT_CD}";
                        einfo "Please insert+mount the ${!var} cdrom now !";
                    fi;
                fi;
                showedmsg=1;
            fi;
            einfo "Press return to scan for the cd again";
            einfo "or hit CTRL+C to abort the emerge.";
            echo;
            if [[ ${showjolietmsg} -eq 0 ]]; then
                showjolietmsg=1;
            else
                ewarn "If you are having trouble with the detection";
                ewarn "of your CD, it is possible that you do not have";
                ewarn "Joliet support enabled in your kernel.  Please";
                ewarn "check that CONFIG_JOLIET is enabled in your kernel.";
                ebeep 5;
            fi;
            read || die "something is screwed with your system";
        done
    }
    _filter-hardened () 
    { 
        local f;
        for f in "$@";
        do
            case "${f}" in 
                -fPIC | -fpic | -fPIE | -fpie | -Wl,pie | -pie)
                    gcc-specs-pie || continue;
                    is-flagq -nopie || append-flags -nopie
                ;;
                -fstack-protector)
                    gcc-specs-ssp || continue;
                    is-flagq -fno-stack-protector || append-flags $(test-flags -fno-stack-protector)
                ;;
                -fstack-protector-all)
                    gcc-specs-ssp-to-all || continue;
                    is-flagq -fno-stack-protector-all || append-flags $(test-flags -fno-stack-protector-all)
                ;;
                -fno-strict-overflow)
                    gcc-specs-nostrict || continue;
                    is-flagq -fstrict-overflow || append-flags $(test-flags -fstrict-overflow)
                ;;
            esac;
        done
    }
    _filter-var () 
    { 
        local f x VAR VAL;
        declare -a new;
        VAR=$1;
        shift;
        eval VAL=\${${VAR}};
        for f in ${VAL};
        do
            for x in "$@";
            do
                [[ ${f} == ${x} ]] && continue 2;
            done;
            eval new\[\${\#new\[@]}]=\${f};
        done;
        eval export ${VAR}=\${new\[*]}
    }
    _gcc-install-dir () 
    { 
        echo "$(LC_ALL=C $(tc-getCC) -print-search-dirs 2> /dev/null |		awk '$1=="install:" {print $2}')"
    }
    _gcc-specs-directive_raw () 
    { 
        local cc=$(tc-getCC);
        local specfiles=$(LC_ALL=C ${cc} -v 2>&1 | awk '$1=="Reading" {print $NF}');
        ${cc} -dumpspecs 2> /dev/null | cat - ${specfiles} | awk -v directive=$1 'BEGIN	{ pspec=""; spec=""; outside=1 }
    $1=="*"directive":"  { pspec=spec; spec=""; outside=0; next }
        outside || NF==0 || ( substr($1,1,1)=="*" && substr($1,length($1),1)==":" ) { outside=1; next }
        spec=="" && substr($0,1,1)=="+" { spec=pspec " " substr($0,2); next }
        { spec=spec $0 }
    END	{ print spec }';
        return 0
    }
    _gcc-specs-exists () 
    { 
        [[ -f $(_gcc-install-dir)/$1 ]]
    }
    _gcc_fullversion () 
    { 
        local ver="$1";
        shift;
        set -- `$(tc-getCPP "$@") -E -P - <<<"__GNUC__ __GNUC_MINOR__ __GNUC_PATCHLEVEL__"`;
        eval echo "$ver"
    }
    _is_flagq () 
    { 
        local x;
        for x in ${!1};
        do
            [[ ${x} == $2 ]] && return 0;
        done;
        return 1
    }
    _unpack_tar () 
    { 
        if [ "${y}" == "tar" ]; then
            $1 -c -- "$srcdir$x" | tar xof -;
            assert_sigpipe_ok "$myfail";
        else
            $1 -c -- "${srcdir}${x}" > ${x%.*} || die "$myfail";
        fi
    }
    append-cflags () 
    { 
        [[ -z $* ]] && return 0;
        export CFLAGS="${CFLAGS} $*";
        return 0
    }
    append-cppflags () 
    { 
        [[ -z $* ]] && return 0;
        export CPPFLAGS="${CPPFLAGS} $*";
        return 0
    }
    append-cxxflags () 
    { 
        [[ -z $* ]] && return 0;
        export CXXFLAGS="${CXXFLAGS} $*";
        return 0
    }
    append-fflags () 
    { 
        [[ -z $* ]] && return 0;
        export FFLAGS="${FFLAGS} $*";
        export FCFLAGS="${FCFLAGS} $*";
        return 0
    }
    append-flags () 
    { 
        [[ -z $* ]] && return 0;
        append-cflags "$@";
        append-cxxflags "$@";
        append-fflags "$@";
        return 0
    }
    append-ldflags () 
    { 
        [[ -z $* ]] && return 0;
        local flag;
        for flag in "$@";
        do
            [[ ${flag} == -l* ]] && ewarn "Appending a library link instruction (${flag}); libraries to link to should not be passed through LDFLAGS";
        done;
        export LDFLAGS="${LDFLAGS} $*";
        return 0
    }
    append-lfs-flags () 
    { 
        [[ -n $@ ]] && die "append-lfs-flags takes no arguments";
        append-cppflags -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE
    }
    append-libs () 
    { 
        [[ -z $* ]] && return 0;
        local flag;
        for flag in "$@";
        do
            [[ ${flag} == -l* ]] && flag=${flag#-l};
            export LIBS="${LIBS} -l${flag}";
        done;
        return 0
    }
    built_with_use () 
    { 
        local hidden="no";
        if [[ $1 == "--hidden" ]]; then
            hidden="yes";
            shift;
        fi;
        local missing_action="die";
        if [[ $1 == "--missing" ]]; then
            missing_action=$2;
            shift;
            shift;
            case ${missing_action} in 
                true | false | die)

                ;;
                *)
                    die "unknown action '${missing_action}'"
                ;;
            esac;
        fi;
        local opt=$1;
        [[ ${opt:0:1} = "-" ]] && shift || opt="-a";
        local PKG=$(best_version $1);
        [[ -z ${PKG} ]] && die "Unable to resolve $1 to an installed package";
        shift;
        local USEFILE=${ROOT}/var/db/pkg/${PKG}/USE;
        local IUSEFILE=${ROOT}/var/db/pkg/${PKG}/IUSE;
        if [[ ! -e ${USEFILE} ]] || [[ ! -e ${IUSEFILE} && ${hidden} == "no" ]]; then
            case ${missing_action} in 
                true)
                    return 0
                ;;
                false)
                    return 1
                ;;
                die)
                    die "Unable to determine what USE flags $PKG was built with"
                ;;
            esac;
        fi;
        if [[ ${hidden} == "no" ]]; then
            local IUSE_BUILT=($(<"${IUSEFILE}"));
            local expand;
            for expand in $(echo ${USE_EXPAND} | tr '[:upper:]' '[:lower:]');
            do
                if [[ $1 == ${expand}_* ]]; then
                    expand="";
                    break;
                fi;
            done;
            if [[ -n ${expand} ]]; then
                if ! has $1 ${IUSE_BUILT[@]#[-+]}; then
                    case ${missing_action} in 
                        true)
                            return 0
                        ;;
                        false)
                            return 1
                        ;;
                        die)
                            die "$PKG does not actually support the $1 USE flag!"
                        ;;
                    esac;
                fi;
            fi;
        fi;
        local USE_BUILT=$(<${USEFILE});
        while [[ $# -gt 0 ]]; do
            if [[ ${opt} = "-o" ]]; then
                has $1 ${USE_BUILT} && return 0;
            else
                has $1 ${USE_BUILT} || return 1;
            fi;
            shift;
        done;
        [[ ${opt} = "-a" ]]
    }
    cdrom_get_cds () 
    { 
        local cdcnt=0;
        local f=;
        for f in "$@";
        do
            ((++cdcnt));
            export CDROM_CHECK_${cdcnt}="$f";
        done;
        export CDROM_TOTAL_CDS=${cdcnt};
        export CDROM_CURRENT_CD=1;
        if [[ -n ${CD_ROOT}${CD_ROOT_1} ]]; then
            local var=;
            cdcnt=0;
            while [[ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ]]; do
                ((++cdcnt));
                var="CD_ROOT_${cdcnt}";
                [[ -z ${!var} ]] && var="CD_ROOT";
                if [[ -z ${!var} ]]; then
                    eerror "You must either use just the CD_ROOT";
                    eerror "or specify ALL the CD_ROOT_X variables.";
                    eerror "In this case, you will need ${CDROM_TOTAL_CDS} CD_ROOT_X variables.";
                    die "could not locate CD_ROOT_${cdcnt}";
                fi;
            done;
            export CDROM_ROOT=${CD_ROOT_1:-${CD_ROOT}};
            einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}";
            export CDROM_SET=-1;
            for f in ${CDROM_CHECK_1//:/ };
            do
                ((++CDROM_SET));
                [[ -e ${CDROM_ROOT}/${f} ]] && break;
            done;
            export CDROM_MATCH=${f};
            return;
        fi;
        if [[ ${CDROM_TOTAL_CDS} -eq 1 ]]; then
            einfo "This ebuild will need the ${CDROM_NAME:-cdrom for ${PN}}";
            echo;
            einfo "If you do not have the CD, but have the data files";
            einfo "mounted somewhere on your filesystem, just export";
            einfo "the variable CD_ROOT so that it points to the";
            einfo "directory containing the files.";
            echo;
            einfo "For example:";
            einfo "export CD_ROOT=/mnt/cdrom";
            echo;
        else
            if [[ -n ${CDROM_NAME_SET} ]]; then
                cdcnt=0;
                while [[ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ]]; do
                    ((++cdcnt));
                    export CDROM_NAME_${cdcnt}="${CDROM_NAME_SET[$((${cdcnt}-1))]}";
                done;
            fi;
            einfo "This package will need access to ${CDROM_TOTAL_CDS} cds.";
            cdcnt=0;
            while [[ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ]]; do
                ((++cdcnt));
                var="CDROM_NAME_${cdcnt}";
                [[ ! -z ${!var} ]] && einfo " CD ${cdcnt}: ${!var}";
            done;
            echo;
            einfo "If you do not have the CDs, but have the data files";
            einfo "mounted somewhere on your filesystem, just export";
            einfo "the following variables so they point to the right place:";
            einfon "";
            cdcnt=0;
            while [[ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ]]; do
                ((++cdcnt));
                echo -n " CD_ROOT_${cdcnt}";
            done;
            echo;
            einfo "Or, if you have all the files in the same place, or";
            einfo "you only have one cdrom, you can export CD_ROOT";
            einfo "and that place will be used as the same data source";
            einfo "for all the CDs.";
            echo;
            einfo "For example:";
            einfo "export CD_ROOT_1=/mnt/cdrom";
            echo;
        fi;
        export CDROM_SET="";
        export CDROM_CURRENT_CD=0;
        cdrom_load_next_cd
    }
    cdrom_load_next_cd () 
    { 
        local var;
        ((++CDROM_CURRENT_CD));
        unset CDROM_ROOT;
        var=CD_ROOT_${CDROM_CURRENT_CD};
        [[ -z ${!var} ]] && var="CD_ROOT";
        if [[ -z ${!var} ]]; then
            var="CDROM_CHECK_${CDROM_CURRENT_CD}";
            _cdrom_locate_file_on_cd ${!var};
        else
            export CDROM_ROOT=${!var};
        fi;
        einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
    }
    check_license () 
    { 
        local lic=$1;
        if [ -z "${lic}" ]; then
            lic="${PORTDIR}/licenses/${LICENSE}";
        else
            if [ -e "${PORTDIR}/licenses/${lic}" ]; then
                lic="${PORTDIR}/licenses/${lic}";
            else
                if [ -e "${PWD}/${lic}" ]; then
                    lic="${PWD}/${lic}";
                else
                    if [ -e "${lic}" ]; then
                        lic="${lic}";
                    fi;
                fi;
            fi;
        fi;
        local l="`basename ${lic}`";
        local alic;
        eshopts_push -o noglob;
        for alic in ${ACCEPT_LICENSE};
        do
            if [[ ${alic} == ${l} ]]; then
                eshopts_pop;
                return 0;
            fi;
        done;
        eshopts_pop;
        [ ! -f "${lic}" ] && die "Could not find requested license ${lic}";
        local licmsg=$(emktemp);
        cat > ${licmsg}  <<-EOF
    **********************************************************
    The following license outlines the terms of use of this
    package.  You MUST accept this license for installation to
    continue.  When you are done viewing, hit 'q'.	If you
    CTRL+C out of this, the install will not run!
    **********************************************************

    EOF

        cat ${lic} >> ${licmsg};
        ${PAGER:-less} ${licmsg} || die "Could not execute pager (${PAGER}) to accept ${lic}";
        einfon "Do you accept the terms of this license (${l})? [yes/no] ";
        read alic;
        case ${alic} in 
            yes | Yes | y | Y)
                return 0
            ;;
            *)
                echo;
                echo;
                echo;
                eerror "You MUST accept the license to continue!  Exiting!";
                die "Failed to accept license"
            ;;
        esac
    }
    create_ml_includes () 
    { 
        local dest=$1;
        shift;
        local basedirs=$(create_ml_includes-listdirs "$@");
        create_ml_includes-makedestdirs ${dest} ${basedirs};
        local file;
        for file in $(create_ml_includes-allfiles ${basedirs});
        do
            ( echo "/* Autogenerated by create_ml_includes() in multilib.eclass */";
            local dir;
            for dir in ${basedirs};
            do
                if [[ -f ${D}/${dir}/${file} ]]; then
                    echo "";
                    local sym=$(create_ml_includes-sym_for_dir ${dir} "$@");
                    if [[ ${sym/=} != "${sym}" ]]; then
                        echo "#if ${sym}";
                    else
                        if [[ ${sym::1} == "!" ]]; then
                            echo "#ifndef ${sym:1}";
                        else
                            echo "#ifdef ${sym}";
                        fi;
                    fi;
                    echo "# include <$(create_ml_includes-absolute ${dir}/${file})>";
                    echo "#endif /* ${sym} */";
                fi;
            done ) > "${D}/${dest}/${file}";
        done
    }
    create_ml_includes-absolute () 
    { 
        local dst="$(create_ml_includes-tidy_path $1)";
        dst=(${dst//\// });
        local i;
        for ((i=0; i<${#dst[*]}; i++))
        do
            [ "${dst[i]}" == "include" ] && break;
        done;
        local strip_upto=$i;
        for ((i=strip_upto+1; i<${#dst[*]}-1; i++))
        do
            echo -n ${dst[i]}/;
        done;
        echo -n ${dst[i]}
    }
    create_ml_includes-allfiles () 
    { 
        [[ -z ${ED} ]] && local ED=${D};
        local basedir file;
        for basedir in "$@";
        do
            for file in $(find "${ED}"/${basedir} -type f);
            do
                echo ${file/${ED}\/${basedir}\//};
            done;
        done | sort | uniq
    }
    create_ml_includes-listdirs () 
    { 
        local dirs;
        local data;
        for data in "$@";
        do
            dirs="${dirs} ${data/*:/}";
        done;
        echo ${dirs:1}
    }
    create_ml_includes-makedestdirs () 
    { 
        local dest=$1;
        shift;
        local basedirs=$@;
        [[ -z ${ED} ]] && local ED=${D};
        dodir ${dest};
        local basedir;
        for basedir in ${basedirs};
        do
            local dir;
            for dir in $(find "${ED}"/${basedir} -type d);
            do
                dodir ${dest}/${dir/${ED}\/${basedir}/};
            done;
        done
    }
    create_ml_includes-sym_for_dir () 
    { 
        local dir=$1;
        shift;
        local data;
        for data in "$@";
        do
            if [[ ${data} == *:${dir} ]]; then
                echo ${data/:*/};
                return 0;
            fi;
        done;
        echo "Shouldn't be here -- create_ml_includes-sym_for_dir $1 $@";
        exit 1
    }
    create_ml_includes-tidy_path () 
    { 
        local removed=$1;
        if [ -n "${removed}" ]; then
            while [ "${removed}" != "${removed/\/\//\/}" ]; do
                removed=${removed/\/\//\/};
            done;
            while [ "${removed}" != "${removed//\/.\//\/}" ]; do
                removed=${removed//\/.\//\/};
            done;
            [ "${removed##*/}" = "." ] && removed=${removed%/*};
            while [ "${removed}" != "${removed//\/..\/}" ]; do
                local p1="${removed%%\/..\/*}";
                local p2="${removed#*\/..\/}";
                removed="${p1%\/*}/${p2}";
            done;
            [ "${removed##*/}" = ".." ] && removed=${removed%/*/*};
            [ "${removed##*/}" = "" ] && removed=${removed%/*};
            echo ${removed};
        fi
    }
    darwintoolize () 
    { 
        die "Use elibtoolize"
    }
    dlopen_lib () 
    { 
        case "${CHOST}" in 
            *-linux-gnu* | *-linux-uclibc | *-interix*)
                echo "-ldl"
            ;;
        esac
    }
    doicon () 
    { 
        ( local i j ret;
        insinto /usr/share/pixmaps;
        for i in "$@";
        do
            if [[ -f ${i} ]]; then
                doins "${i}";
                ((ret+=$?));
            else
                if [[ -d ${i} ]]; then
                    for j in "${i}"/*.png;
                    do
                        doins "${j}";
                        ((ret+=$?));
                    done;
                else
                    ((++ret));
                fi;
            fi;
        done;
        exit ${ret} )
    }
    domenu () 
    { 
        ( local i j ret=0;
        insinto /usr/share/applications;
        for i in "$@";
        do
            if [[ -f ${i} ]]; then
                doins "${i}";
                ((ret+=$?));
            else
                if [[ -d ${i} ]]; then
                    for j in "${i}"/*.desktop;
                    do
                        doins "${j}";
                        ((ret+=$?));
                    done;
                else
                    ((++ret));
                fi;
            fi;
        done;
        exit ${ret} )
    }
    dyn_pretend () 
    { 
        ebuild_phase_with_hooks pkg_pretend
    }
    ebeep () 
    { 
        local n;
        if [[ -z ${EBEEP_IGNORE} ]]; then
            for ((n=1 ; n <= ${1:-5} ; n++))
            do
                echo -ne "\a";
                sleep 0.1 &>/dev/null;
                sleep 0,1 &>/dev/null;
                echo -ne "\a";
                sleep 1;
            done;
        fi
    }
    ecvs_clean () 
    { 
        [[ -z $* ]] && set -- .;
        find "$@" -type d -name 'CVS' -prune -print0 | xargs -0 rm -rf;
        find "$@" -type f -name '.cvs*' -print0 | xargs -0 rm -rf
    }
    edos2unix () 
    { 
        echo "$@" | xargs sed -i 's/\r$//'
    }
    egetent () 
    { 
        case ${CHOST} in 
            *-darwin[678])
                case "$2" in 
                    *[!0-9]*)
                        nidump $1 . | awk -F":" "{ if (\$1 ~ /^$2$/) {print \$0;exit;} }"
                    ;;
                    *)
                        nidump $1 . | awk -F":" "{ if (\$3 == $2) {print \$0;exit;} }"
                    ;;
                esac
            ;;
            *-darwin*)
                local mytype=$1;
                [[ "passwd" == $mytype ]] && mytype="Users";
                [[ "group" == $mytype ]] && mytype="Groups";
                case "$2" in 
                    *[!0-9]*)
                        dscl . -read /$mytype/$2 2> /dev/null | grep RecordName
                    ;;
                    *)
                        local mykey="UniqueID";
                        [[ $mytype == "Groups" ]] && mykey="PrimaryGroupID";
                        dscl . -search /$mytype $mykey $2 2> /dev/null
                    ;;
                esac
            ;;
            *-freebsd* | *-dragonfly*)
                local opts action="user";
                [[ $1 == "passwd" ]] || action="group";
                if [[ $2 == [[:digit:]]* ]]; then
                    [[ ${action} == "user" ]] && opts="-u" || opts="-g";
                fi;
                pw show ${action} ${opts} "$2" -q
            ;;
            *-netbsd* | *-openbsd*)
                grep "$2:\*:" /etc/$1
            ;;
            *)
                type -p nscd &>/dev/null && nscd -i "$1";
                getent "$1" "$2"
            ;;
        esac
    }
    egethome () 
    { 
        ent=$(egetent passwd $1);
        case ${CHOST} in 
            *-darwin* | *-freebsd* | *-dragonfly*)
                echo ${ent} | cut -d: -f9
            ;;
            *)
                echo ${ent} | cut -d: -f6
            ;;
        esac
    }
    egetshell () 
    { 
        ent=$(egetent passwd "$1");
        case ${CHOST} in 
            *-darwin* | *-freebsd* | *-dragonfly*)
                echo ${ent} | cut -d: -f10
            ;;
            *)
                echo ${ent} cut -d: -f7
            ;;
        esac
    }
    elibtoolize () 
    { 
        local x;
        local do_portage="no";
        local do_reversedeps="no";
        local do_only_patches="no";
        local do_uclibc="yes";
        local deptoremove=;
        local do_shallow="no";
        local elt_patches="install-sh ltmain portage relink max_cmd_len sed test tmp cross as-needed";
        for x in "$@";
        do
            case ${x} in 
                --portage)
                    do_portage="yes"
                ;;
                --reverse-deps)
                    do_reversedeps="yes";
                    elt_patches+=" fix-relink"
                ;;
                --patch-only)
                    do_only_patches="yes"
                ;;
                --remove-internal-dep=*)
                    deptoremove=${x#--remove-internal-dep=};
                    [[ -n ${deptoremove} ]] && elt_patches+=" rem-int-dep"
                ;;
                --shallow)
                    do_shallow="yes"
                ;;
                --no-uclibc)
                    do_uclibc="no"
                ;;
                *)
                    eerror "Invalid elibtoolize option: ${x}";
                    die "elibtoolize called with ${x} ??"
                ;;
            esac;
        done;
        [[ ${do_uclibc} == "yes" ]] && elt_patches+=" uclibc-conf uclibc-ltconf";
        case ${CHOST} in 
            *-aix*)
                elt_patches+=" hardcode aixrtl aix-noundef"
            ;;
            *-darwin*)
                elt_patches+=" darwin-ltconf darwin-ltmain darwin-conf"
            ;;
            *-freebsd*)
                elt_patches+=" fbsd-conf fbsd-ltconf"
            ;;
            *-hpux*)
                elt_patches+=" hpux-conf deplibs hc-flag-ld hardcode hardcode-relink relink-prog no-lc"
            ;;
            *-irix*)
                elt_patches+=" irix-ltmain"
            ;;
            *-mint*)
                elt_patches+=" mint-conf"
            ;;
        esac;
        set --;
        if [[ ${do_shallow} == "yes" ]]; then
            [[ -f ${S}/ltmain.sh ]] && set -- "${S}";
        else
            set -- $(find "${S}" -name ltmain.sh -printf '%h ');
        fi;
        local d p;
        for d in "$@";
        do
            export ELT_APPLIED_PATCHES=;
            [[ -f ${d}/.elibtoolized ]] && continue;
            einfo "Running elibtoolize in: ${d#${WORKDIR}/}/";
            for p in ${elt_patches};
            do
                local ret=0;
                case ${p} in 
                    portage)
                        if ! grep -qs 'We do not want portage' "${d}/ltmain.sh"; then
                            ELT_walk_patches "${d}/ltmain.sh" "${p}";
                            ret=$?;
                        fi
                    ;;
                    rem-int-dep)
                        ELT_walk_patches "${d}/ltmain.sh" "${p}" "${deptoremove}";
                        ret=$?
                    ;;
                    fix-relink)
                        if grep -qs 'inst_prefix_dir' "${d}/ltmain.sh"; then
                            ELT_walk_patches "${d}/ltmain.sh" "${p}";
                            ret=$?;
                        fi
                    ;;
                    max_cmd_len)
                        if grep -qs 'max_cmd_len' "${d}/ltmain.sh"; then
                            ELT_walk_patches "${d}/ltmain.sh" "${p}";
                            ret=$?;
                        fi
                    ;;
                    as-needed)
                        ELT_walk_patches "${d}/ltmain.sh" "${p}";
                        ret=$?
                    ;;
                    uclibc-conf)
                        if grep -qs 'Transform linux' "${d}/configure"; then
                            ELT_walk_patches "${d}/configure" "${p}";
                            ret=$?;
                        else
                            if [[ ! -e ${d}/configure ]] && grep -qs 'Transform linux' "${d}/../configure"; then
                                ELT_walk_patches "${d}/../configure" "${p}";
                                ret=$?;
                            fi;
                        fi
                    ;;
                    uclibc-ltconf)
                        if [[ -s ${d}/ltconfig ]]; then
                            ELT_walk_patches "${d}/ltconfig" "${p}";
                            ret=$?;
                        fi
                    ;;
                    fbsd-conf)
                        if grep -qs 'version_type=freebsd-' "${d}/configure"; then
                            ELT_walk_patches "${d}/configure" "${p}";
                            ret=$?;
                        else
                            if [[ ! -e ${d}/configure ]] && grep -qs 'version_type=freebsd-' "${d}/../configure"; then
                                ELT_walk_patches "${d}/../configure" "${p}";
                                ret=$?;
                            fi;
                        fi
                    ;;
                    fbsd-ltconf)
                        if [[ -s ${d}/ltconfig ]]; then
                            ELT_walk_patches "${d}/ltconfig" "${p}";
                            ret=$?;
                        fi
                    ;;
                    darwin-conf)
                        if grep -qs '&& echo \.so ||' "${d}/configure"; then
                            ELT_walk_patches "${d}/configure" "${p}";
                            ret=$?;
                        else
                            if [[ ! -e ${d}/configure ]] && grep -qs '&& echo \.so ||' "${d}/../configure"; then
                                ELT_walk_patches "${d}/../configure" "${p}";
                                ret=$?;
                            fi;
                        fi
                    ;;
                    darwin-ltconf)
                        if [[ -s ${d}/ltconfig ]]; then
                            ELT_walk_patches "${d}/ltconfig" "${p}";
                            ret=$?;
                        fi
                    ;;
                    darwin-ltmain)
                        if [[ -e ${d}/ltmain.sh ]] && ! grep -qs 'verstring="-compatibility_version' "${d}/ltmain.sh"; then
                            ELT_walk_patches "${d}/ltmain.sh" "${p}";
                            ret=$?;
                        fi
                    ;;
                    aixrtl | hpux-conf)
                        ret=1;
                        local subret=0;
                        while [[ $subret -eq 0 ]]; do
                            subret=1;
                            if [[ -e ${d}/configure ]]; then
                                ELT_walk_patches "${d}/configure" "${p}";
                                subret=$?;
                            else
                                if [[ ! -e ${d}/configure && -e ${d}/../configure ]]; then
                                    ELT_walk_patches "${d}/../configure" "${p}";
                                    subret=$?;
                                fi;
                            fi;
                            if [[ $subret -eq 0 ]]; then
                                ret=0;
                            fi;
                        done
                    ;;
                    mint-conf)
                        ret=1;
                        local subret=1;
                        if [[ -e ${d}/configure ]]; then
                            ELT_walk_patches "${d}/configure" "${p}";
                            subret=$?;
                        else
                            if [[ ! -e ${d}/configure && -e ${d}/../configure ]]; then
                                ELT_walk_patches "${d}/../configure" "${p}";
                                subret=$?;
                            fi;
                        fi;
                        if [[ $subret -eq 0 ]]; then
                            ret=0;
                        fi
                    ;;
                    install-sh)
                        ELT_walk_patches "${d}/install-sh" "${p}";
                        ret=$?
                    ;;
                    cross)
                        if tc-is-cross-compiler; then
                            ELT_walk_patches "${d}/ltmain.sh" "${p}";
                            ret=$?;
                        fi
                    ;;
                    *)
                        ELT_walk_patches "${d}/ltmain.sh" "${p}";
                        ret=$?
                    ;;
                esac;
                if [[ ${ret} -ne 0 ]]; then
                    case ${p} in 
                        relink)
                            local version=$(ELT_libtool_version "${d}/ltmain.sh");
                            if ! grep -qs 'inst_prefix_dir' "${d}/ltmain.sh" && [[ $(VER_to_int "${version}") -ge $(VER_to_int "1.4.0") ]]; then
                                ewarn "  Could not apply relink.patch!";
                            fi
                        ;;
                        portage)
                            if [[ ${do_portage} == "yes" ]]; then
                                if ! grep -qs 'We do not want portage' "${d}/ltmain.sh"; then
                                    echo;
                                    eerror "Portage patch requested, but failed to apply!";
                                    eerror "Please file a bug report to add a proper patch.";
                                    die "Portage patch requested, but failed to apply!";
                                fi;
                            else
                                if grep -qs 'We do not want portage' "${d}/ltmain.sh"; then
                                    :;
                                else
                                    local version=$(ELT_libtool_version "${d}"/ltmain.sh);
                                    echo;
                                    eerror "Portage patch failed to apply (ltmain.sh version ${version})!";
                                    eerror "Please file a bug report to add a proper patch.";
                                    die "Portage patch failed to apply!";
                                fi;
                                ELT_APPLIED_PATCHES="portage";
                            fi
                        ;;
                        uclibc-*)
                            [[ ${CHOST} == *-uclibc ]] && ewarn "  uClibc patch set '${p}' failed to apply!"
                        ;;
                        fbsd-*)
                            if [[ ${CHOST} == *-freebsd* ]]; then
                                if [[ -z $(grep 'Handle Gentoo/FreeBSD as it was Linux' 								"${d}/configure" "${d}/../configure" 2>/dev/null) ]]; then
                                    eerror "  FreeBSD patch set '${p}' failed to apply!";
                                    die "FreeBSD patch set '${p}' failed to apply!";
                                fi;
                            fi
                        ;;
                        darwin-*)
                            [[ ${CHOST} == *"-darwin"* ]] && ewarn "  Darwin patch set '${p}' failed to apply!"
                        ;;
                    esac;
                fi;
            done;
            if [[ -z ${ELT_APPLIED_PATCHES} ]]; then
                if [[ ${do_portage} == "no" && ${do_reversedeps} == "no" && ${do_only_patches} == "no" && ${deptoremove} == "" ]]; then
                    ewarn "Cannot apply any patches, please file a bug about this";
                    die;
                fi;
            fi;
            rm -f "${d}/libtool";
            > "${d}/.elibtoolized";
        done
    }
    emktemp () 
    { 
        local exe="touch";
        [[ $1 == -d ]] && exe="mkdir" && shift;
        local topdir=$1;
        if [[ -z ${topdir} ]]; then
            [[ -z ${T} ]] && topdir="/tmp" || topdir=${T};
        fi;
        if ! type -P mktemp > /dev/null; then
            local tmp=/;
            while [[ -e ${tmp} ]]; do
                tmp=${topdir}/tmp.${RANDOM}.${RANDOM}.${RANDOM};
            done;
            ${exe} "${tmp}" || ${exe} -p "${tmp}";
            echo "${tmp}";
        else
            if [[ ${exe} == "touch" ]]; then
                TMPDIR="${topdir}" mktemp -t tmp.XXXXXXXXXX;
            else
                TMPDIR="${topdir}" mktemp -dt tmp.XXXXXXXXXX;
            fi;
        fi
    }
    enewgroup () 
    { 
        case ${EBUILD_PHASE} in 
            unpack | compile | test | install)
                eerror "'enewgroup()' called from '${EBUILD_PHASE}()' which is not a pkg_* function.";
                eerror "Package fails at QA and at life.  Please file a bug.";
                die "Bad package!  enewgroup is only for use in pkg_* functions!"
            ;;
        esac;
        local egroup="$1";
        shift;
        if [ -z "${egroup}" ]; then
            eerror "No group specified !";
            die "Cannot call enewgroup without a group";
        fi;
        if [[ -n $(egetent group "${egroup}") ]]; then
            return 0;
        fi;
        einfo "Adding group '${egroup}' to your system ...";
        local opts=;
        local egid="$1";
        shift;
        if [ ! -z "${egid}" ]; then
            if [ "${egid}" -gt 0 ]; then
                if [ -z "`egetent group ${egid}`" ]; then
                    if [[ "${CHOST}" == *-darwin* ]]; then
                        opts="${opts} ${egid}";
                    else
                        opts="${opts} -g ${egid}";
                    fi;
                else
                    egid="next available; requested gid taken";
                fi;
            else
                eerror "Groupid given but is not greater than 0 !";
                die "${egid} is not a valid GID";
            fi;
        else
            egid="next available";
        fi;
        einfo " - Groupid: ${egid}";
        local eextra="$@";
        opts="${opts} ${eextra}";
        local oldsandbox="${SANDBOX_ON}";
        export SANDBOX_ON="0";
        case ${CHOST} in 
            *-darwin*)
                if [ ! -z "${eextra}" ]; then
                    einfo "Extra options are not supported on Darwin/OS X yet";
                    einfo "Please report the ebuild along with the info below";
                    einfo "eextra: ${eextra}";
                    die "Required function missing";
                fi;
                case ${egid} in 
                    *[!0-9]*)
                        for ((egid = 101; egid <= 999; egid++))
                        do
                            [[ -z $(egetent group ${egid}) ]] && break;
                        done
                    ;;
                esac;
                dscl . create /groups/${egroup} gid ${egid};
                dscl . create /groups/${egroup} passwd '*'
            ;;
            *-freebsd* | *-dragonfly*)
                case ${egid} in 
                    *[!0-9]*)
                        for ((egid = 101; egid <= 999; egid++))
                        do
                            [[ -z $(egetent group ${egid}) ]] && break;
                        done
                    ;;
                esac;
                pw groupadd ${egroup} -g ${egid} || die "enewgroup failed"
            ;;
            *-netbsd*)
                case ${egid} in 
                    *[!0-9]*)
                        for ((egid = 101; egid <= 999; egid++))
                        do
                            [[ -z $(egetent group ${egid}) ]] && break;
                        done
                    ;;
                esac;
                groupadd -g ${egid} ${egroup} || die "enewgroup failed"
            ;;
            *)
                groupadd -r ${opts} ${egroup} || die "enewgroup failed"
            ;;
        esac;
        export SANDBOX_ON="${oldsandbox}"
    }
    enewuser () 
    { 
        case ${EBUILD_PHASE} in 
            unpack | compile | test | install)
                eerror "'enewuser()' called from '${EBUILD_PHASE}()' which is not a pkg_* function.";
                eerror "Package fails at QA and at life.  Please file a bug.";
                die "Bad package!  enewuser is only for use in pkg_* functions!"
            ;;
        esac;
        local euser=$1;
        shift;
        if [[ -z ${euser} ]]; then
            eerror "No username specified !";
            die "Cannot call enewuser without a username";
        fi;
        if [[ -n $(egetent passwd "${euser}") ]]; then
            return 0;
        fi;
        einfo "Adding user '${euser}' to your system ...";
        local opts=;
        local euid=$1;
        shift;
        if [[ -n ${euid} && ${euid} != -1 ]]; then
            if [[ ${euid} -gt 0 ]]; then
                if [[ -n $(egetent passwd ${euid}) ]]; then
                    euid="next";
                fi;
            else
                eerror "Userid given but is not greater than 0 !";
                die "${euid} is not a valid UID";
            fi;
        else
            euid="next";
        fi;
        if [[ ${euid} == "next" ]]; then
            for ((euid = 101; euid <= 999; euid++))
            do
                [[ -z $(egetent passwd ${euid}) ]] && break;
            done;
        fi;
        opts="${opts} -u ${euid}";
        einfo " - Userid: ${euid}";
        local eshell=$1;
        shift;
        if [[ ! -z ${eshell} ]] && [[ ${eshell} != "-1" ]]; then
            if [[ ! -e ${ROOT}${eshell} ]]; then
                eerror "A shell was specified but it does not exist !";
                die "${eshell} does not exist in ${ROOT}";
            fi;
            if [[ ${eshell} == */false || ${eshell} == */nologin ]]; then
                eerror "Do not specify ${eshell} yourself, use -1";
                die "Pass '-1' as the shell parameter";
            fi;
        else
            for shell in /sbin/nologin /usr/sbin/nologin /bin/false /usr/bin/false /dev/null;
            do
                [[ -x ${ROOT}${shell} ]] && break;
            done;
            if [[ ${shell} == "/dev/null" ]]; then
                eerror "Unable to identify the shell to use, proceeding with userland default.";
                case ${USERLAND} in 
                    GNU)
                        shell="/bin/false"
                    ;;
                    BSD)
                        shell="/sbin/nologin"
                    ;;
                    Darwin)
                        shell="/usr/sbin/nologin"
                    ;;
                    *)
                        die "Unable to identify the default shell for userland ${USERLAND}"
                    ;;
                esac;
            fi;
            eshell=${shell};
        fi;
        einfo " - Shell: ${eshell}";
        opts="${opts} -s ${eshell}";
        local ehome=$1;
        shift;
        if [[ -z ${ehome} ]] || [[ ${ehome} == "-1" ]]; then
            ehome="/dev/null";
        fi;
        einfo " - Home: ${ehome}";
        opts="${opts} -d ${ehome}";
        local egroups=$1;
        shift;
        if [[ ! -z ${egroups} ]]; then
            local oldifs=${IFS};
            local defgroup="" exgroups="";
            export IFS=",";
            for g in ${egroups};
            do
                export IFS=${oldifs};
                if [[ -z $(egetent group "${g}") ]]; then
                    eerror "You must add group ${g} to the system first";
                    die "${g} is not a valid GID";
                fi;
                if [[ -z ${defgroup} ]]; then
                    defgroup=${g};
                else
                    exgroups="${exgroups},${g}";
                fi;
                export IFS=",";
            done;
            export IFS=${oldifs};
            opts="${opts} -g ${defgroup}";
            if [[ ! -z ${exgroups} ]]; then
                opts="${opts} -G ${exgroups:1}";
            fi;
        else
            egroups="(none)";
        fi;
        einfo " - Groups: ${egroups}";
        local oldsandbox=${SANDBOX_ON};
        export SANDBOX_ON="0";
        case ${CHOST} in 
            *-darwin*)
                if [[ -z $@ ]]; then
                    dscl . create /users/${euser} uid ${euid};
                    dscl . create /users/${euser} shell ${eshell};
                    dscl . create /users/${euser} home ${ehome};
                    dscl . create /users/${euser} realname "added by portage for ${PN}";
                    local oldifs=${IFS};
                    export IFS=",";
                    for g in ${egroups};
                    do
                        dscl . merge /groups/${g} users ${euser};
                    done;
                    export IFS=${oldifs};
                else
                    einfo "Extra options are not supported on Darwin yet";
                    einfo "Please report the ebuild along with the info below";
                    einfo "eextra: $@";
                    die "Required function missing";
                fi
            ;;
            *-freebsd* | *-dragonfly*)
                if [[ -z $@ ]]; then
                    pw useradd ${euser} ${opts} -c "added by portage for ${PN}" die "enewuser failed";
                else
                    einfo " - Extra: $@";
                    pw useradd ${euser} ${opts} "$@" || die "enewuser failed";
                fi
            ;;
            *-netbsd*)
                if [[ -z $@ ]]; then
                    useradd ${opts} ${euser} || die "enewuser failed";
                else
                    einfo " - Extra: $@";
                    useradd ${opts} ${euser} "$@" || die "enewuser failed";
                fi
            ;;
            *-openbsd*)
                if [[ -z $@ ]]; then
                    useradd -u ${euid} -s ${eshell} -d ${ehome} -c "Added by portage for ${PN}" -g ${egroups} ${euser} || die "enewuser failed";
                else
                    einfo " - Extra: $@";
                    useradd -u ${euid} -s ${eshell} -d ${ehome} -c "Added by portage for ${PN}" -g ${egroups} ${euser} "$@" || die "enewuser failed";
                fi
            ;;
            *)
                if [[ -z $@ ]]; then
                    useradd -r ${opts} -c "added by portage for ${PN}" ${euser} || die "enewuser failed";
                else
                    einfo " - Extra: $@";
                    useradd -r ${opts} "$@" ${euser} || die "enewuser failed";
                fi
            ;;
        esac;
        if [[ ! -e ${ROOT}/${ehome} ]]; then
            einfo " - Creating ${ehome} in ${ROOT}";
            mkdir -p "${ROOT}/${ehome}";
            chown ${euser} "${ROOT}/${ehome}";
            chmod 755 "${ROOT}/${ehome}";
        fi;
        export SANDBOX_ON=${oldsandbox}
    }
    epatch () 
    { 
        function _epatch_draw_line () 
        { 
            [[ -z $1 ]] && set "$(printf "%65s" '')";
            echo "${1//?/=}"
        };
        unset P4CONFIG P4PORT P4USER;
        if [[ $# -gt 1 ]]; then
            local m;
            for m in "$@";
            do
                epatch "${m}";
            done;
            return 0;
        fi;
        local SINGLE_PATCH="no";
        [[ $# -eq 0 ]] && set -- "${EPATCH_SOURCE}";
        if [[ -f $1 ]]; then
            SINGLE_PATCH="yes";
            set -- "$1";
            local EPATCH_SUFFIX=$1;
        else
            if [[ -d $1 ]]; then
                set -- "$1"/*${EPATCH_SUFFIX:+."${EPATCH_SUFFIX}"};
            else
                [[ $# -ne 0 ]] && EPATCH_SOURCE=$1;
                echo;
                eerror "Cannot find \$EPATCH_SOURCE!  Value for \$EPATCH_SOURCE is:";
                eerror;
                eerror "  ${EPATCH_SOURCE}";
                eerror "  ( ${EPATCH_SOURCE##*/} )";
                echo;
                die "Cannot find \$EPATCH_SOURCE!";
            fi;
        fi;
        local PIPE_CMD;
        case ${EPATCH_SUFFIX##*\.} in 
            xz)
                PIPE_CMD="xz -dc"
            ;;
            lzma)
                PIPE_CMD="lzma -dc"
            ;;
            bz2)
                PIPE_CMD="bzip2 -dc"
            ;;
            gz | Z | z)
                PIPE_CMD="gzip -dc"
            ;;
            ZIP | zip)
                PIPE_CMD="unzip -p"
            ;;
            *)

            ;;
        esac;
        [[ ${SINGLE_PATCH} == "no" ]] && einfo "${EPATCH_MULTI_MSG}";
        local x;
        for x in "$@";
        do
            [[ ! -f ${x} ]] && continue;
            local patchname=${x##*/};
            local a=${patchname#*_};
            a=${a%%_*};
            if ! [[ ${SINGLE_PATCH} == "yes" || ${EPATCH_FORCE} == "yes" || ${a} == all || ${a} == ${ARCH} ]]; then
                continue;
            fi;
            if [[ -n ${EPATCH_EXCLUDE} ]]; then
                eshopts_push -o noglob;
                local ex;
                for ex in ${EPATCH_EXCLUDE};
                do
                    if [[ ${patchname} == ${ex} ]]; then
                        eshopts_pop;
                        continue 2;
                    fi;
                done;
                eshopts_pop;
            fi;
            if [[ ${SINGLE_PATCH} == "yes" ]]; then
                if [[ -n ${EPATCH_SINGLE_MSG} ]]; then
                    einfo "${EPATCH_SINGLE_MSG}";
                else
                    einfo "Applying ${patchname} ...";
                fi;
            else
                einfo "  ${patchname} ...";
            fi;
            local STDERR_TARGET="${T}/${patchname}.out";
            if [[ -e ${STDERR_TARGET} ]]; then
                STDERR_TARGET="${T}/${patchname}-$$.out";
            fi;
            printf "***** %s *****\n\n" "${patchname}" > "${STDERR_TARGET}";
            local count=0;
            local PATCH_TARGET;
            if [[ -n ${PIPE_CMD} ]]; then
                PATCH_TARGET="${T}/$$.patch";
                echo "PIPE_COMMAND:  ${PIPE_CMD} ${x} > ${PATCH_TARGET}" >> "${STDERR_TARGET}";
                if ! ( ${PIPE_CMD} "${x}" > "${PATCH_TARGET}" ) >> "${STDERR_TARGET}" 2>&1; then
                    echo;
                    eerror "Could not extract patch!";
                    count=5;
                    break;
                fi;
            else
                PATCH_TARGET=${x};
            fi;
            local abs_paths=$(egrep -n '^[-+]{3} /' "${PATCH_TARGET}" | awk '$2 != "/dev/null" { print }');
            if [[ -n ${abs_paths} ]]; then
                count=1;
                printf "NOTE: skipping -p0 due to absolute paths in patch:\n%s\n" "${abs_paths}" >> "${STDERR_TARGET}";
            fi;
            local rel_paths=$(egrep -n '^[-+]{3} [^	]*[.][.]/' "${PATCH_TARGET}");
            if [[ -n ${rel_paths} ]]; then
                eqawarn "QA Notice: Your patch uses relative paths '../'.";
                eqawarn " In the future this will cause a failure.";
                eqawarn "${rel_paths}";
            fi;
            while [[ ${count} -lt 5 ]]; do
                ( _epatch_draw_line "***** ${patchname} *****";
                echo;
                echo "PATCH COMMAND:  patch -p${count} ${EPATCH_OPTS} < '${PATCH_TARGET}'";
                echo;
                _epatch_draw_line "***** ${patchname} *****" ) >> "${STDERR_TARGET}";
                if ( patch -p${count} ${EPATCH_OPTS} --dry-run -f < "${PATCH_TARGET}" ) >> "${STDERR_TARGET}" 2>&1; then
                    ( _epatch_draw_line "***** ${patchname} *****";
                    echo;
                    echo "ACTUALLY APPLYING ${patchname} ...";
                    echo;
                    _epatch_draw_line "***** ${patchname} *****";
                    patch -p${count} ${EPATCH_OPTS} < "${PATCH_TARGET}" 2>&1 ) >> "${STDERR_TARGET}";
                    if [ $? -ne 0 ]; then
                        echo;
                        eerror "A dry-run of patch command succeeded, but actually";
                        eerror "applying the patch failed!";
                        count=5;
                    fi;
                    break;
                fi;
                : $(( count++ ));
            done;
            if [[ -n ${PIPE_CMD} ]]; then
                rm -f "${PATCH_TARGET}";
            fi;
            if [[ ${count} -ge 5 ]]; then
                echo;
                eerror "Failed Patch: ${patchname} !";
                eerror " ( ${PATCH_TARGET} )";
                eerror;
                eerror "Include in your bugreport the contents of:";
                eerror;
                eerror "  ${STDERR_TARGET}";
                echo;
                die "Failed Patch: ${patchname}!";
            fi;
            rm -f "${STDERR_TARGET}";
            eend 0;
        done;
        [[ ${SINGLE_PATCH} == "no" ]] && einfo "Done with patching";
        :
    }
    epatch_user () 
    { 
        [[ $# -ne 0 ]] && die "epatch_user takes no options";
        local EPATCH_SOURCE check base=${PORTAGE_CONFIGROOT%/}/etc/portage/patches;
        for check in {${CATEGORY}/${PF},${CATEGORY}/${P},${CATEGORY}/${PN}};
        do
            EPATCH_SOURCE=${base}/${CTARGET}/${check};
            [[ -r ${EPATCH_SOURCE} ]] || EPATCH_SOURCE=${base}/${CHOST}/${check};
            [[ -r ${EPATCH_SOURCE} ]] || EPATCH_SOURCE=${base}/${check};
            if [[ -d ${EPATCH_SOURCE} ]]; then
                EPATCH_SOURCE=${EPATCH_SOURCE} EPATCH_SUFFIX="patch" EPATCH_FORCE="yes" EPATCH_MULTI_MSG="Applying user patches from ${EPATCH_SOURCE} ..." epatch;
                return 0;
            fi;
        done;
        return 1
    }
    epause () 
    { 
        [[ -z ${EPAUSE_IGNORE} ]] && sleep ${1:-5}
    }
    epunt_cxx () 
    { 
        local dir=$1;
        [[ -z ${dir} ]] && dir=${S};
        ebegin "Removing useless C++ checks";
        local f;
        find "${dir}" -name configure | while read f; do
            patch --no-backup-if-mismatch -p0 "${f}" "${PORTDIR}/eclass/ELT-patches/nocxx/nocxx.patch" > /dev/null;
        done;
        eend 0
    }
    eshopts_pop () 
    { 
        [[ $# -ne 0 ]] && die "eshopts_pop takes no arguments";
        local i=$(( ${#__ESHOPTS_SAVE__[@]} - 1 ));
        [[ ${i} -eq -1 ]] && die "eshopts_{push,pop}: unbalanced pair";
        local s=${__ESHOPTS_SAVE__[$i]};
        unset __ESHOPTS_SAVE__[$i];
        if [[ ${s} == "shopt -"* ]]; then
            eval "${s}" || die "eshopts_pop: sanity: invalid shopt options: ${s}";
        else
            set +$- || die "eshopts_pop: sanity: invalid shell settings: $-";
            set -${s} || die "eshopts_pop: sanity: unable to restore saved shell settings: ${s}";
        fi
    }
    eshopts_push () 
    { 
        local i=${#__ESHOPTS_SAVE__[@]};
        if [[ $1 == -[su] ]]; then
            __ESHOPTS_SAVE__[$i]=$(shopt -p);
            [[ $# -eq 0 ]] && return 0;
            shopt "$@" || die "eshopts_push: bad options to shopt: $*";
        else
            __ESHOPTS_SAVE__[$i]=$-;
            [[ $# -eq 0 ]] && return 0;
            set "$@" || die "eshopts_push: bad options to set: $*";
        fi
    }
    esvn_clean () 
    { 
        [[ -z $* ]] && set -- .;
        find "$@" -type d -name '.svn' -prune -print0 | xargs -0 rm -rf
    }
    filter-flags () 
    { 
        _filter-hardened "$@";
        _filter-var CFLAGS "$@";
        _filter-var CPPFLAGS "$@";
        _filter-var CXXFLAGS "$@";
        _filter-var FFLAGS "$@";
        _filter-var FCFLAGS "$@";
        return 0
    }
    filter-ldflags () 
    { 
        _filter-var LDFLAGS "$@";
        return 0
    }
    filter-lfs-flags () 
    { 
        [[ -n $@ ]] && die "filter-lfs-flags takes no arguments";
        filter-flags -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE
    }
    filter-mfpmath () 
    { 
        local orig_mfpmath new_math prune_math;
        orig_mfpmath=$(get-flag -mfpmath);
        new_math=$(get-flag mfpmath);
        new_math=" ${new_math//,/ } ";
        prune_math="";
        for prune_math in "$@";
        do
            new_math=${new_math/ ${prune_math} / };
        done;
        new_math=$(echo ${new_math});
        new_math=${new_math// /,};
        if [[ -z ${new_math} ]]; then
            filter-flags ${orig_mfpmath};
        else
            replace-flags ${orig_mfpmath} -mfpmath=${new_math};
        fi;
        return 0
    }
    find_unpackable_file () 
    { 
        local src=$1;
        if [[ -z ${src} ]]; then
            src=${DISTDIR}/${A};
        else
            if [[ -e ${DISTDIR}/${src} ]]; then
                src=${DISTDIR}/${src};
            else
                if [[ -e ${PWD}/${src} ]]; then
                    src=${PWD}/${src};
                else
                    if [[ -e ${src} ]]; then
                        src=${src};
                    fi;
                fi;
            fi;
        fi;
        [[ ! -e ${src} ]] && return 1;
        echo "${src}"
    }
    gcc-fullversion () 
    { 
        _gcc_fullversion '$1.$2.$3' "$@"
    }
    gcc-major-version () 
    { 
        _gcc_fullversion '$1' "$@"
    }
    gcc-micro-version () 
    { 
        _gcc_fullversion '$3' "$@"
    }
    gcc-minor-version () 
    { 
        _gcc_fullversion '$2' "$@"
    }
    gcc-specs-directive () 
    { 
        local directive subdname subdirective;
        directive="$(_gcc-specs-directive_raw $1)";
        while [[ ${directive} == *%\(*\)* ]]; do
            subdname=${directive/*%\(};
            subdname=${subdname/\)*};
            subdirective="$(_gcc-specs-directive_raw ${subdname})";
            directive="${directive//\%(${subdname})/${subdirective}}";
        done;
        echo "${directive}";
        return 0
    }
    gcc-specs-nostrict () 
    { 
        local directive;
        directive=$(gcc-specs-directive cc1);
        return $([[ "${directive/\{!fstrict-overflow:}" != "${directive}" ]])
    }
    gcc-specs-now () 
    { 
        local directive;
        directive=$(gcc-specs-directive link_command);
        return $([[ "${directive/\{!nonow:}" != "${directive}" ]])
    }
    gcc-specs-pie () 
    { 
        local directive;
        directive=$(gcc-specs-directive cc1);
        return $([[ "${directive/\{!nopie:}" != "${directive}" ]])
    }
    gcc-specs-relro () 
    { 
        local directive;
        directive=$(gcc-specs-directive link_command);
        return $([[ "${directive/\{!norelro:}" != "${directive}" ]])
    }
    gcc-specs-ssp () 
    { 
        local directive;
        directive=$(gcc-specs-directive cc1);
        return $([[ "${directive/\{!fno-stack-protector:}" != "${directive}" ]])
    }
    gcc-specs-ssp-to-all () 
    { 
        local directive;
        directive=$(gcc-specs-directive cc1);
        return $([[ "${directive/\{!fno-stack-protector-all:}" != "${directive}" ]])
    }
    gcc-version () 
    { 
        _gcc_fullversion '$1.$2' "$@"
    }
    gen_usr_ldscript () 
    { 
        local lib libdir=$(get_libdir) output_format="" auto=false suffix=$(get_libname);
        [[ -z ${ED+set} ]] && local ED=${D%/}${EPREFIX}/;
        tc-is-static-only && return;
        dodir /usr/${libdir};
        if [[ $1 == "-a" ]]; then
            auto=true;
            shift;
            dodir /${libdir};
        fi;
        output_format=$($(tc-getCC) ${CFLAGS} ${LDFLAGS} -Wl,--verbose 2>&1 | sed -n 's/^OUTPUT_FORMAT("\([^"]*\)",.*/\1/p');
        [[ -n ${output_format} ]] && output_format="OUTPUT_FORMAT ( ${output_format} )";
        for lib in "$@";
        do
            local tlib;
            if ${auto}; then
                lib="lib${lib}${suffix}";
            else
                [[ -r ${ED}/${libdir}/${lib} ]] || continue;
            fi;
            case ${CTARGET:-${CHOST}} in 
                *-darwin*)
                    if ${auto}; then
                        tlib=$(scanmacho -qF'%S#F' "${ED}"/usr/${libdir}/${lib});
                    else
                        tlib=$(scanmacho -qF'%S#F' "${ED}"/${libdir}/${lib});
                    fi;
                    [[ -z ${tlib} ]] && die "unable to read install_name from ${lib}";
                    tlib=${tlib##*/};
                    if ${auto}; then
                        mv "${ED}"/usr/${libdir}/${lib%${suffix}}.*${suffix#.} "${ED}"/${libdir}/ || die;
                        if [[ ${tlib} != ${lib%${suffix}}.*${suffix#.} ]]; then
                            mv "${ED}"/usr/${libdir}/${tlib%${suffix}}.*${suffix#.} "${ED}"/${libdir}/ || die;
                        fi;
                        rm -f "${ED}"/${libdir}/${lib};
                    fi;
                    if [[ ! -w "${ED}/${libdir}/${tlib}" ]]; then
                        chmod u+w "${ED}${libdir}/${tlib}";
                        local nowrite=yes;
                    fi;
                    install_name_tool -id "${EPREFIX}"/${libdir}/${tlib} "${ED}"/${libdir}/${tlib} || die "install_name_tool failed";
                    [[ -n ${nowrite} ]] && chmod u-w "${ED}${libdir}/${tlib}";
                    pushd "${ED}/usr/${libdir}" > /dev/null;
                    ln -snf "../../${libdir}/${tlib}" "${lib}";
                    popd > /dev/null
                ;;
                *-aix* | *-irix* | *64*-hpux* | *-interix* | *-winnt*)
                    if ${auto}; then
                        mv "${ED}"/usr/${libdir}/${lib}* "${ED}"/${libdir}/ || die;
                        tlib=$(readlink "${ED}"/${libdir}/${lib});
                        tlib=${tlib##*/};
                        if [[ -z ${tlib} ]]; then
                            tlib=${lib};
                        else
                            rm -f "${ED}"/${libdir}/${lib};
                        fi;
                    else
                        tlib=${lib};
                    fi;
                    pushd "${ED}/usr/${libdir}" > /dev/null;
                    ln -snf "../../${libdir}/${tlib}" "${lib}";
                    popd > /dev/null
                ;;
                hppa*-hpux*)
                    if ${auto}; then
                        tlib=$(chatr "${ED}"/usr/${libdir}/${lib} | sed -n '/internal name:/{n;s/^ *//;p;q}');
                        [[ -z ${tlib} ]] && tlib=${lib};
                        tlib=${tlib##*/};
                        mv "${ED}"/usr/${libdir}/${lib}* "${ED}"/${libdir}/ || die;
                        if [[ ${tlib} != ${lib}* ]]; then
                            mv "${ED}"/usr/${libdir}/${tlib}* "${ED}"/${libdir}/ || die;
                        fi;
                        [[ ${tlib} != ${lib} ]] && rm -f "${ED}"/${libdir}/${lib};
                    else
                        tlib=$(chatr "${ED}"/${libdir}/${lib} | sed -n '/internal name:/{n;s/^ *//;p;q}');
                        [[ -z ${tlib} ]] && tlib=${lib};
                        tlib=${tlib##*/};
                    fi;
                    pushd "${ED}"/usr/${libdir} > /dev/null;
                    ln -snf "../../${libdir}/${tlib}" "${lib}";
                    [[ ${tlib} != ${lib} ]] && ln -snf "../../${libdir}/${tlib}" "${tlib}";
                    popd > /dev/null
                ;;
                *)
                    if ${auto}; then
                        tlib=$(scanelf -qF'%S#F' "${ED}"/usr/${libdir}/${lib});
                        [[ -z ${tlib} ]] && die "unable to read SONAME from ${lib}";
                        mv "${ED}"/usr/${libdir}/${lib}* "${ED}"/${libdir}/ || die;
                        if [[ ${tlib} != ${lib}* ]]; then
                            mv "${ED}"/usr/${libdir}/${tlib}* "${ED}"/${libdir}/ || die;
                        fi;
                        rm -f "${ED}"/${libdir}/${lib};
                    else
                        tlib=${lib};
                    fi;
                    cat > "${ED}/usr/${libdir}/${lib}"  <<-END_LDSCRIPT
    /* GNU ld script
    Since Gentoo has critical dynamic libraries in /lib, and the static versions
    in /usr/lib, we need to have a "fake" dynamic lib in /usr/lib, otherwise we
    run into linking problems.  This "fake" dynamic lib is a linker script that
    redirects the linker to the real lib.  And yes, this works in the cross-
    compiling scenario as the sysroot-ed linker will prepend the real path.

    See bug http://bugs.gentoo.org/4411 for more info.
    */
    ${output_format}
    GROUP ( ${EPREFIX}/${libdir}/${tlib} )
    END_LDSCRIPT

                ;;
            esac
            fperms a+x "/usr/${libdir}/${lib}" || die "could not change perms on ${lib}";
        done
    }
    get-flag () 
    { 
        local f findflag="$1";
        for f in ${CFLAGS} ${CXXFLAGS} ${FFLAGS} ${FCFLAGS};
        do
            if [ "${f/${findflag}}" != "${f}" ]; then
                printf "%s\n" "${f/-${findflag}=}";
                return 0;
            fi;
        done;
        return 1
    }
    get_abi_ASFLAGS () 
    { 
        get_abi_var ASFLAGS "$@"
    }
    get_abi_CDEFINE () 
    { 
        get_abi_var CDEFINE "$@"
    }
    get_abi_CFLAGS () 
    { 
        get_abi_var CFLAGS "$@"
    }
    get_abi_CHOST () 
    { 
        get_abi_var CHOST "$@"
    }
    get_abi_CTARGET () 
    { 
        get_abi_var CTARGET "$@"
    }
    get_abi_FAKE_TARGETS () 
    { 
        get_abi_var FAKE_TARGETS "$@"
    }
    get_abi_LDFLAGS () 
    { 
        get_abi_var LDFLAGS "$@"
    }
    get_abi_LIBDIR () 
    { 
        get_abi_var LIBDIR "$@"
    }
    get_abi_var () 
    { 
        local flag=$1;
        local abi;
        if [ $# -gt 1 ]; then
            abi=${2};
        else
            if [ -n "${ABI}" ]; then
                abi=${ABI};
            else
                if [ -n "${DEFAULT_ABI}" ]; then
                    abi=${DEFAULT_ABI};
                else
                    abi="default";
                fi;
            fi;
        fi;
        local var="${flag}_${abi}";
        echo ${!var}
    }
    get_all_abis () 
    { 
        local order="";
        if [[ -z ${MULTILIB_ABIS} ]]; then
            echo "default";
            return 0;
        fi;
        for x in ${MULTILIB_ABIS};
        do
            if [[ ${x} != ${DEFAULT_ABI} ]]; then
                order="${order:+${order} }${x}";
            fi;
        done;
        order="${order:+${order} }${DEFAULT_ABI}";
        echo ${order};
        return 0
    }
    get_all_libdirs () 
    { 
        local libdirs="lib";
        local abi;
        local dir;
        for abi in ${MULTILIB_ABIS};
        do
            [ "$(get_abi_LIBDIR ${abi})" != "lib" ] && libdirs="${libdirs} $(get_abi_LIBDIR ${abi})";
        done;
        echo "${libdirs}"
    }
    get_bmake () 
    { 
        if [[ ${USERLAND} == *BSD ]]; then
            echo make;
        else
            if [[ ${USERLAND} == "Darwin" ]]; then
                echo bsdmake;
            else
                echo pmake;
            fi;
        fi
    }
    get_install_abis () 
    { 
        local order="";
        if [[ -z ${MULTILIB_ABIS} ]]; then
            echo "default";
            return 0;
        fi;
        if [[ ${EMULTILIB_PKG} == "true" ]]; then
            for x in ${MULTILIB_ABIS};
            do
                if [[ ${x} != "${DEFAULT_ABI}" ]]; then
                    hasq ${x} ${ABI_DENY} || ordera="${ordera} ${x}";
                fi;
            done;
            hasq ${DEFAULT_ABI} ${ABI_DENY} || order="${ordera} ${DEFAULT_ABI}";
            if [[ -n ${ABI_ALLOW} ]]; then
                local ordera="";
                for x in ${order};
                do
                    if hasq ${x} ${ABI_ALLOW}; then
                        ordera="${ordera} ${x}";
                    fi;
                done;
                order=${ordera};
            fi;
        else
            order=${DEFAULT_ABI};
        fi;
        if [[ -z ${order} ]]; then
            die "The ABI list is empty.  Are you using a proper multilib profile?  Perhaps your USE flags or MULTILIB_ABIS are too restrictive for this package.";
        fi;
        echo ${order};
        return 0
    }
    get_libdir () 
    { 
        local CONF_LIBDIR;
        if [ -n "${CONF_LIBDIR_OVERRIDE}" ]; then
            echo ${CONF_LIBDIR_OVERRIDE};
        else
            get_abi_LIBDIR;
        fi
    }
    get_libdir_override () 
    { 
        if has_multilib_profile; then
            eerror "get_libdir_override called, but it shouldn't be needed with the new multilib approach.  Please file a bug at http://bugs.gentoo.org and assign it to eradicator@gentoo.org";
            exit 1;
        fi;
        CONF_LIBDIR="$1";
        CONF_LIBDIR_OVERRIDE="$1";
        LIBDIR_default="$1"
    }
    get_libname () 
    { 
        local libname;
        local ver=$1;
        case ${CHOST} in 
            *-cygwin | mingw* | *-mingw*)
                libname="dll"
            ;;
            *-darwin*)
                libname="dylib"
            ;;
            *-mint*)
                libname="irrelevant"
            ;;
            hppa*-hpux*)
                libname="sl"
            ;;
            *)
                libname="so"
            ;;
        esac;
        if [[ -z $* ]]; then
            echo ".${libname}";
        else
            for ver in "$@";
            do
                case ${CHOST} in 
                    *-darwin*)
                        echo ".${ver}.${libname}"
                    ;;
                    *-mint*)
                        echo ".${libname}"
                    ;;
                    *)
                        echo ".${libname}.${ver}"
                    ;;
                esac;
            done;
        fi
    }
    get_ml_incdir () 
    { 
        local dir=/usr/include;
        if [[ $# -gt 0 ]]; then
            incdir=$1;
            shift;
        fi;
        if [[ -z "${MULTILIB_ABIS}" ]]; then
            echo ${incdir};
            return 0;
        fi;
        local abi=${ABI-${DEFAULT_ABI}};
        if [[ $# -gt 0 ]]; then
            abi=$1;
            shift;
        fi;
        if [[ -d "${dir}/gentoo-multilib/${abi}" ]]; then
            echo ${dir}/gentoo-multilib/${abi};
        else
            echo ${dir};
        fi
    }
    get_modname () 
    { 
        local modname;
        local ver=$1;
        case ${CHOST} in 
            *-darwin*)
                modname="bundle"
            ;;
            *)
                modname="so"
            ;;
        esac;
        echo ".${modname}"
    }
    get_mounts () 
    { 
        local point= node= fs= opts= foo=;
        if [[ $(uname -s) == "Linux" ]]; then
            while read node point fs opts foo; do
                echo "${point} ${node} ${fs} ${opts}";
            done < /proc/mounts;
            return;
        fi;
        local IFS='	';
        LC_ALL=C mount -p | while read node point fs foo; do
            opts=${fs#* };
            fs=${fs%% *};
            echo "${point// /\040} ${node// /\040} ${fs%% *} ${opts// /\040}";
        done
    }
    get_multilibdir () 
    { 
        if has_multilib_profile; then
            eerror "get_multilibdir called, but it shouldn't be needed with the new multilib approach.  Please file a bug at http://bugs.gentoo.org and assign it to eradicator@gentoo.org";
            exit 1;
        fi;
        echo ${CONF_MULTILIBDIR:=lib32}
    }
    has_hardened () 
    { 
        ewarn "has_hardened: deprecated, please use gcc-specs-{relro,now}()!" 1>&2;
        test_version_info Hardened && return 0;
        [[ -f ${GCC_SPECS} && ${GCC_SPECS} != ${GCC_SPECS/hardened/} ]]
    }
    has_m32 () 
    { 
        [ "$(tc-arch)" = "amd64" ] && has_multilib_profile && return 0;
        local temp=$(emktemp);
        echo "int main() { return(0); }" > "${temp}".c;
        MY_CC=$(tc-getCC);
        ${MY_CC/ .*/} -m32 -o "$(emktemp)" "${temp}".c > /dev/null 2>&1;
        local ret=$?;
        rm -f "${temp}".c;
        [[ ${ret} != 1 ]] && return 0;
        return 1
    }
    has_m64 () 
    { 
        local temp="$(emktemp)";
        echo "int main() { return(0); }" > "${temp}".c;
        MY_CC=$(tc-getCC);
        ${MY_CC/ .*/} -m64 -o "$(emktemp)" "${temp}".c > /dev/null 2>&1;
        local ret=$?;
        rm -f "${temp}".c;
        [[ ${ret} != 1 ]] && return 0;
        return 1
    }
    has_multilib_profile () 
    { 
        [ -n "${MULTILIB_ABIS}" -a "${MULTILIB_ABIS}" != "${MULTILIB_ABIS/ /}" ]
    }
    has_pic () 
    { 
        ewarn "has_pic: deprecated, please use gcc-specs-pie()!" 1>&2;
        [[ ${CFLAGS/-fPIC} != ${CFLAGS} || ${CFLAGS/-fpic} != ${CFLAGS} ]] || gcc-specs-pie
    }
    has_pie () 
    { 
        ewarn "has_pie: deprecated, please use gcc-specs-pie()!" 1>&2;
        [[ ${CFLAGS/-fPIE} != ${CFLAGS} || ${CFLAGS/-fpie} != ${CFLAGS} ]] || gcc-specs-pie
    }
    has_ssp () 
    { 
        ewarn "has_ssp: deprecated, please use gcc-specs-ssp()!" 1>&2;
        [[ ${CFLAGS/-fstack-protector} != ${CFLAGS} || -n $(echo | $(tc-getCC) ${CFLAGS} -E -dM - | grep __SSP__) ]] || gcc-specs-ssp
    }
    has_ssp_all () 
    { 
        ewarn "has_ssp_all: deprecated, please use gcc-specs-ssp()!" 1>&2;
        [[ ${CFLAGS/-fstack-protector-all} != ${CFLAGS} || -n $(echo | $(tc-getCC) ${CFLAGS} -E -dM - | grep __SSP_ALL__) ]] || gcc-specs-ssp-to-all
    }
    helpers_die () 
    { 
        case "${EAPI:-0}" in 
            0 | 1 | 2 | 3)
                echo -e "$@" 1>&2
            ;;
            *)
                die "$@"
            ;;
        esac
    }
    is-flag () 
    { 
        is-flagq "$@" && echo true
    }
    is-flagq () 
    { 
        [[ -n $2 ]] && die "Usage: is-flag <flag>";
        _is_flagq CFLAGS $1 || _is_flagq CXXFLAGS $1 || _is_flagq FFLAGS $1 || _is_flagq FCFLAGS $1
    }
    is-ldflag () 
    { 
        is-ldflagq "$@" && echo true
    }
    is-ldflagq () 
    { 
        [[ -n $2 ]] && die "Usage: is-ldflag <flag>";
        _is_flagq LDFLAGS $1
    }
    is-login-disabled () 
    { 
        shell=$(egetshell "$1");
        case ${shell} in 
            /bin/false | /usr/bin/false | /sbin/nologin | /usr/sbin/nologin)
                return 0
            ;;
            *)
                return 1
            ;;
        esac
    }
    is_final_abi () 
    { 
        has_multilib_profile || return 0;
        local ALL_ABIS=$(get_install_abis);
        local LAST_ABI=${ALL_ABIS/* /};
        [[ ${LAST_ABI} == ${ABI} ]]
    }
    lfs_fallocate_test () 
    { 
        cat > "${T}"/fallocate.c  <<-EOF
#define _GNU_SOURCE
#include <fcntl.h>
    main() { return fallocate(0, 0, 0, 0); }
    EOF

        append-lfs-flags
        $(tc-getCC) ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} "${T}"/fallocate.c -o /dev/null > /dev/null 2>&1 || export ac_cv_func_fallocate=no;
        rm -f "${T}"/fallocate.c
    }
    make_desktop_entry () 
    { 
        [[ -z $1 ]] && die "make_desktop_entry: You must specify the executable";
        local exec=${1};
        local name=${2:-${PN}};
        local icon=${3:-${PN}};
        local type=${4};
        local fields=${5};
        if [[ -z ${type} ]]; then
            local catmaj=${CATEGORY%%-*};
            local catmin=${CATEGORY##*-};
            case ${catmaj} in 
                app)
                    case ${catmin} in 
                        accessibility)
                            type=Accessibility
                        ;;
                        admin)
                            type=System
                        ;;
                        antivirus)
                            type=System
                        ;;
                        arch)
                            type=Archiving
                        ;;
                        backup)
                            type=Archiving
                        ;;
                        cdr)
                            type=DiscBurning
                        ;;
                        dicts)
                            type=Dictionary
                        ;;
                        doc)
                            type=Documentation
                        ;;
                        editors)
                            type=TextEditor
                        ;;
                        emacs)
                            type=TextEditor
                        ;;
                        emulation)
                            type=Emulator
                        ;;
                        laptop)
                            type=HardwareSettings
                        ;;
                        office)
                            type=Office
                        ;;
                        pda)
                            type=PDA
                        ;;
                        vim)
                            type=TextEditor
                        ;;
                        xemacs)
                            type=TextEditor
                        ;;
                    esac
                ;;
                dev)
                    type="Development"
                ;;
                games)
                    case ${catmin} in 
                        action | fps)
                            type=ActionGame
                        ;;
                        arcade)
                            type=ArcadeGame
                        ;;
                        board)
                            type=BoardGame
                        ;;
                        emulation)
                            type=Emulator
                        ;;
                        kids)
                            type=KidsGame
                        ;;
                        puzzle)
                            type=LogicGame
                        ;;
                        roguelike)
                            type=RolePlaying
                        ;;
                        rpg)
                            type=RolePlaying
                        ;;
                        simulation)
                            type=Simulation
                        ;;
                        sports)
                            type=SportsGame
                        ;;
                        strategy)
                            type=StrategyGame
                        ;;
                    esac;
                    type="Game;${type}"
                ;;
                gnome)
                    type="Gnome;GTK"
                ;;
                kde)
                    type="KDE;Qt"
                ;;
                mail)
                    type="Network;Email"
                ;;
                media)
                    case ${catmin} in 
                        gfx)
                            type=Graphics
                        ;;
                        *)
                            case ${catmin} in 
                                radio)
                                    type=Tuner
                                ;;
                                sound)
                                    type=Audio
                                ;;
                                tv)
                                    type=TV
                                ;;
                                video)
                                    type=Video
                                ;;
                            esac;
                            type="AudioVideo;${type}"
                        ;;
                    esac
                ;;
                net)
                    case ${catmin} in 
                        dialup)
                            type=Dialup
                        ;;
                        ftp)
                            type=FileTransfer
                        ;;
                        im)
                            type=InstantMessaging
                        ;;
                        irc)
                            type=IRCClient
                        ;;
                        mail)
                            type=Email
                        ;;
                        news)
                            type=News
                        ;;
                        nntp)
                            type=News
                        ;;
                        p2p)
                            type=FileTransfer
                        ;;
                        voip)
                            type=Telephony
                        ;;
                    esac;
                    type="Network;${type}"
                ;;
                sci)
                    case ${catmin} in 
                        astro*)
                            type=Astronomy
                        ;;
                        bio*)
                            type=Biology
                        ;;
                        calc*)
                            type=Calculator
                        ;;
                        chem*)
                            type=Chemistry
                        ;;
                        elec*)
                            type=Electronics
                        ;;
                        geo*)
                            type=Geology
                        ;;
                        math*)
                            type=Math
                        ;;
                        physics)
                            type=Physics
                        ;;
                        visual*)
                            type=DataVisualization
                        ;;
                    esac;
                    type="Education;Science;${type}"
                ;;
                sys)
                    type="System"
                ;;
                www)
                    case ${catmin} in 
                        client)
                            type=WebBrowser
                        ;;
                    esac;
                    type="Network;${type}"
                ;;
                *)
                    type=
                ;;
            esac;
        fi;
        if [ "${SLOT}" == "0" ]; then
            local desktop_name="${PN}";
        else
            local desktop_name="${PN}-${SLOT}";
        fi;
        local desktop="${T}/$(echo ${exec} | sed 's:[[:space:]/:]:_:g')-${desktop_name}.desktop";
        type=${type%;}${type:+;};
        eshopts_push -s extglob;
        if [[ -n ${icon} && ${icon} != /* ]] && [[ ${icon} == *.xpm || ${icon} == *.png || ${icon} == *.svg ]]; then
            ewarn "As described in the Icon Theme Specification, icon file extensions are not";
            ewarn "allowed in .desktop files if the value is not an absolute path.";
            icon=${icon%.@(xpm|png|svg)};
        fi;
        eshopts_pop;
        cat > "${desktop}"  <<-EOF
    [Desktop Entry]
    Name=${name}
    Type=Application
    Comment=${DESCRIPTION}
    Exec=${exec}
    TryExec=${exec%% *}
    Icon=${icon}
    Categories=${type}
    EOF

        if [[ ${fields:-=} != *=* ]]; then
            ewarn "make_desktop_entry: update your 5th arg to read Path=${fields}";
            fields="Path=${fields}";
        fi;
        [[ -n ${fields} ]] && printf '%b\n' "${fields}" >> "${desktop}";
        ( insinto /usr/share/applications;
        doins "${desktop}" ) || die "installing desktop file failed"
    }
    make_session_desktop () 
    { 
        [[ -z $1 ]] && eerror "$0: You must specify the title" && return 1;
        [[ -z $2 ]] && eerror "$0: You must specify the command" && return 1;
        local title=$1;
        local command=$2;
        local desktop=${T}/${wm:-${PN}}.desktop;
        shift 2;
        cat > "${desktop}"  <<-EOF
    [Desktop Entry]
    Name=${title}
    Comment=This session logs you into ${title}
    Exec=${command} $*
    TryExec=${command}
    Type=XSession
    EOF

        ( insinto /usr/share/xsessions;
        doins "${desktop}" )
    }
    make_wrapper () 
    { 
        local wrapper=$1 bin=$2 chdir=$3 libdir=$4 path=$5;
        local tmpwrapper=$(emktemp);
        cat > "${tmpwrapper}"  <<EOF
#!/bin/sh
    cd "${chdir:-.}"
    if [ -n "${libdir}" ] ; then
        if [ "\${LD_LIBRARY_PATH+set}" = "set" ] ; then
            export LD_LIBRARY_PATH="\${LD_LIBRARY_PATH}:${libdir}"
        else
            export LD_LIBRARY_PATH="${libdir}"
        fi
    fi
    exec ${bin} "\$@"
    EOF

        chmod go+rx "${tmpwrapper}";
        if [[ -n ${path} ]]; then
            ( exeinto "${path}";
            newexe "${tmpwrapper}" "${wrapper}" ) || die;
        else
            newbin "${tmpwrapper}" "${wrapper}" || die;
        fi
    }
    multilib_env () 
    { 
        local CTARGET=${1:-${CTARGET}};
        case ${CTARGET} in 
            x86_64*)
                export CFLAGS_x86=${CFLAGS_x86--m32};
                export CHOST_x86=${CTARGET/x86_64/i686};
                export CTARGET_x86=${CHOST_x86};
                export CDEFINE_x86="__i386__";
                export LIBDIR_x86="lib";
                export CFLAGS_amd64=${CFLAGS_amd64--m64};
                export CHOST_amd64=${CTARGET};
                export CTARGET_amd64=${CHOST_amd64};
                export CDEFINE_amd64="__x86_64__";
                export LIBDIR_amd64="lib64";
                export MULTILIB_ABIS="amd64 x86";
                export DEFAULT_ABI="amd64"
            ;;
            mips64*)
                export CFLAGS_o32=${CFLAGS_o32--mabi=32};
                export CHOST_o32=${CTARGET/mips64/mips};
                export CTARGET_o32=${CHOST_o32};
                export CDEFINE_o32="_MIPS_SIM == _ABIO32";
                export LIBDIR_o32="lib";
                export CFLAGS_n32=${CFLAGS_n32--mabi=n32};
                export CHOST_n32=${CTARGET};
                export CTARGET_n32=${CHOST_n32};
                export CDEFINE_n32="_MIPS_SIM == _ABIN32";
                export LIBDIR_n32="lib32";
                export CFLAGS_n64=${CFLAGS_n64--mabi=64};
                export CHOST_n64=${CTARGET};
                export CTARGET_n64=${CHOST_n64};
                export CDEFINE_n64="_MIPS_SIM == _ABI64";
                export LIBDIR_n64="lib64";
                export MULTILIB_ABIS="n64 n32 o32";
                export DEFAULT_ABI="n32"
            ;;
            powerpc64*)
                export CFLAGS_ppc=${CFLAGS_ppc--m32};
                export CHOST_ppc=${CTARGET/powerpc64/powerpc};
                export CTARGET_ppc=${CHOST_ppc};
                export CDEFINE_ppc="!__powerpc64__";
                export LIBDIR_ppc="lib";
                export CFLAGS_ppc64=${CFLAGS_ppc64--m64};
                export CHOST_ppc64=${CTARGET};
                export CTARGET_ppc64=${CHOST_ppc64};
                export CDEFINE_ppc64="__powerpc64__";
                export LIBDIR_ppc64="lib64";
                export MULTILIB_ABIS="ppc64 ppc";
                export DEFAULT_ABI="ppc64"
            ;;
            s390x*)
                export CFLAGS_s390=${CFLAGS_s390--m31};
                export CHOST_s390=${CTARGET/s390x/s390};
                export CTARGET_s390=${CHOST_s390};
                export CDEFINE_s390="!__s390x__";
                export LIBDIR_s390="lib";
                export CFLAGS_s390x=${CFLAGS_s390x--m64};
                export CHOST_s390x=${CTARGET};
                export CTARGET_s390x=${CHOST_s390x};
                export CDEFINE_s390x="__s390x__";
                export LIBDIR_s390x="lib64";
                export MULTILIB_ABIS="s390x s390";
                export DEFAULT_ABI="s390x"
            ;;
            sparc*)
                export CFLAGS_sparc32=${CFLAGS_sparc32};
                export CHOST_sparc32=${CTARGET/sparc64/sparc};
                export CTARGET_sparc32=${CHOST_sparc32};
                export CDEFINE_sparc32="!__arch64__";
                export LIBDIR_sparc32="lib";
                export CFLAGS_sparc64=${CFLAGS_sparc64--m64};
                export CHOST_sparc64=${CTARGET};
                export CTARGET_sparc64=${CHOST_sparc64};
                export CDEFINE_sparc64="__arch64__";
                export LIBDIR_sparc64="lib64";
                export MULTILIB_ABIS="${MULTILIB_ABIS-sparc64 sparc32}";
                export DEFAULT_ABI="${DEFAULT_ABI-sparc64}"
            ;;
            *)
                export MULTILIB_ABIS="default";
                export DEFAULT_ABI="default"
            ;;
        esac
    }
    multilib_toolchain_setup () 
    { 
        local v vv;
        export ABI=$1;
        if [[ ${ABI} != ${DEFAULT_ABI} ]]; then
            if [[ ${DEFAULT_ABI_SAVED} != "true" ]]; then
                for v in CHOST CBUILD AS CC CXX LD;
                do
                    export __abi_saved_${v}="${!v}";
                done;
                export DEFAULT_ABI_SAVED="true";
            fi;
            export CHOST=$(get_abi_CHOST ${DEFAULT_ABI});
            export AS="$(tc-getAS) $(get_abi_ASFLAGS)";
            export CC="$(tc-getCC) $(get_abi_CFLAGS)";
            export CXX="$(tc-getCXX) $(get_abi_CFLAGS)";
            export LD="$(tc-getLD) $(get_abi_LDFLAGS)";
            export CHOST=$(get_abi_CHOST $1);
            export CBUILD=$(get_abi_CHOST $1);
        else
            if [[ ${DEFAULT_ABI_SAVED} == "true" ]]; then
                for v in CHOST CBUILD AS CC CXX LD;
                do
                    vv="__abi_saved_${v}";
                    export ${v}="${!vv}";
                done;
            fi;
        fi
    }
    newicon () 
    { 
        ( insinto /usr/share/pixmaps;
        newins "$@" )
    }
    newmenu () 
    { 
        ( insinto /usr/share/applications;
        newins "$@" )
    }
    no-as-needed () 
    { 
        case $($(tc-getLD) -v 2>&1 </dev/null) in 
            *GNU*)
                echo "-Wl,--no-as-needed"
            ;;
        esac
    }
    nonfatal () 
    { 
        if has "${EAPI:-0}" 0 1 2 3 3_pre2; then
            die "$FUNCNAME() not supported in this EAPI";
        fi;
        if [[ $# -lt 1 ]]; then
            die "$FUNCNAME(): Missing argument";
        fi;
        PORTAGE_NONFATAL=1 "$@"
    }
    number_abis () 
    { 
        get_install_abis | wc -w
    }
    path_exists () 
    { 
        local opt=$1;
        [[ ${opt} == -[ao] ]] && shift || opt="-a";
        [[ $# -eq 0 ]] && return 1;
        local p r=0;
        for p in "$@";
        do
            [[ -e ${p} ]];
            : $(( r += $? ));
        done;
        case ${opt} in 
            -a)
                return $(( r != 0 ))
            ;;
            -o)
                return $(( r == $# ))
            ;;
        esac
    }
    pkg_nofetch () 
    { 
        _eapi0_pkg_nofetch "$@"
    }
    post_src_install () 
    { 
        lafilefixer "${D}"
    }
    prep_ml_includes () 
    { 
        if [[ $(number_abis) -gt 1 ]]; then
            local dir;
            local dirs;
            local base;
            if [[ $# -eq 0 ]]; then
                dirs=/usr/include;
            else
                dirs="$@";
            fi;
            for dir in ${dirs};
            do
                base=${T}/gentoo-multilib/${dir}/gentoo-multilib;
                mkdir -p "${base}";
                [[ -d ${base}/${ABI} ]] && rm -rf "${base}/${ABI}";
                mv "${D}/${dir}" "${base}/${ABI}";
            done;
            if is_final_abi; then
                base=${T}/gentoo-multilib;
                pushd "${base}";
                find . | tar -c -T - -f - | tar -x --no-same-owner -f - -C "${D}";
                popd;
                set --;
                for dir in ${dirs};
                do
                    set -- "$@" "${dir}";
                    local abi;
                    for abi in $(get_install_abis);
                    do
                        set -- "$@" "$(get_abi_CDEFINE ${abi}):${dir}/gentoo-multilib/${abi}";
                    done;
                    create_ml_includes "$@";
                done;
            fi;
        fi
    }
    preserve_old_lib () 
    { 
        if [[ ${EBUILD_PHASE} != "preinst" ]]; then
            eerror "preserve_old_lib() must be called from pkg_preinst() only";
            die "Invalid preserve_old_lib() usage";
        fi;
        [[ -z $1 ]] && die "Usage: preserve_old_lib <library to preserve> [more libraries to preserve]";
        has preserve-libs ${FEATURES} && return 0;
        local lib dir;
        for lib in "$@";
        do
            [[ -e ${ROOT}/${lib} ]] || continue;
            dir=${lib%/*};
            dodir ${dir} || die "dodir ${dir} failed";
            cp "${ROOT}"/${lib} "${D}"/${lib} || die "cp ${lib} failed";
            touch "${D}"/${lib};
        done
    }
    preserve_old_lib_notify () 
    { 
        if [[ ${EBUILD_PHASE} != "postinst" ]]; then
            eerror "preserve_old_lib_notify() must be called from pkg_postinst() only";
            die "Invalid preserve_old_lib_notify() usage";
        fi;
        has preserve-libs ${FEATURES} && return 0;
        local lib notice=0;
        for lib in "$@";
        do
            [[ -e ${ROOT}/${lib} ]] || continue;
            if [[ ${notice} -eq 0 ]]; then
                notice=1;
                ewarn "Old versions of installed libraries were detected on your system.";
                ewarn "In order to avoid breaking packages that depend on these old libs,";
                ewarn "the libraries are not being removed.  You need to run revdep-rebuild";
                ewarn "in order to remove these old dependencies.  If you do not have this";
                ewarn "helper program, simply emerge the 'gentoolkit' package.";
                ewarn;
            fi;
            ewarn "  # revdep-rebuild --library '${lib}'";
        done;
        if [[ ${notice} -eq 1 ]]; then
            ewarn;
            ewarn "Once you've finished running revdep-rebuild, it should be safe to";
            ewarn "delete the old libraries.  Here is a copy & paste for the lazy:";
            for lib in "$@";
            do
                ewarn "  # rm '${lib}'";
            done;
        fi
    }
    raw-ldflags () 
    { 
        local x input="$@";
        [[ -z ${input} ]] && input=${LDFLAGS};
        set --;
        for x in ${input};
        do
            x=${x#-Wl,};
            set -- "$@" ${x//,/ };
        done;
        echo "$@"
    }
    register_success_hook () 
    { 
        local x;
        for x in $*;
        do
            hasq $x $EBUILD_SUCCESS_HOOKS || export EBUILD_SUCCESS_HOOKS="$EBUILD_SUCCESS_HOOKS $x";
        done
    }
    replace-cpu-flags () 
    { 
        local newcpu="$#";
        newcpu="${!newcpu}";
        while [ $# -gt 1 ]; do
            replace-flags "-march=${1}" "-march=${newcpu}";
            replace-flags "-mcpu=${1}" "-mcpu=${newcpu}";
            replace-flags "-mtune=${1}" "-mtune=${newcpu}";
            shift;
        done;
        return 0
    }
    replace-flags () 
    { 
        [[ $# != 2 ]] && echo && eerror "Usage: replace-flags <old flag> <new flag>" && die "replace-flags takes 2 arguments, not $#";
        local f fset;
        declare -a new_CFLAGS new_CXXFLAGS new_FFLAGS new_FCFLAGS;
        for fset in CFLAGS CXXFLAGS FFLAGS FCFLAGS;
        do
            for f in ${!fset};
            do
                [[ ${f} == ${1} ]] && f=${2};
                eval new_${fset}\[\${\#new_${fset}\[@]}]=\${f};
            done;
            eval export ${fset}=\${new_${fset}\[*]};
        done;
        return 0
    }
    replace-sparc64-flags () 
    { 
        local SPARC64_CPUS="ultrasparc3 ultrasparc v9";
        if [ "${CFLAGS/mtune}" != "${CFLAGS}" ]; then
            for x in ${SPARC64_CPUS};
            do
                CFLAGS="${CFLAGS/-mcpu=${x}/-mcpu=v8}";
            done;
        else
            for x in ${SPARC64_CPUS};
            do
                CFLAGS="${CFLAGS/-mcpu=${x}/-mcpu=v8 -mtune=${x}}";
            done;
        fi;
        if [ "${CXXFLAGS/mtune}" != "${CXXFLAGS}" ]; then
            for x in ${SPARC64_CPUS};
            do
                CXXFLAGS="${CXXFLAGS/-mcpu=${x}/-mcpu=v8}";
            done;
        else
            for x in ${SPARC64_CPUS};
            do
                CXXFLAGS="${CXXFLAGS/-mcpu=${x}/-mcpu=v8 -mtune=${x}}";
            done;
        fi;
        export CFLAGS CXXFLAGS
    }
    seq () 
    { 
        local p=$(type -P seq);
        if [[ -n ${p} ]]; then
            "${p}" "$@";
            return $?;
        fi;
        case $# in 
            1)
                min=1 max=$1 step=1
            ;;
            2)
                min=$1 max=$2 step=1
            ;;
            3)
                min=$1 max=$3 step=$2
            ;;
            *)
                die "seq called with wrong number of arguments"
            ;;
        esac;
        p=$(type -P jot);
        if [[ -n ${p} ]]; then
            local reps;
            if [[ ${step} != 0 ]]; then
                reps=$(( (max - min) / step + 1 ));
            else
                reps=0;
            fi;
            jot $reps $min $max $step;
            return $?;
        fi;
        while :; do
            [[ $max < $min && $step > 0 ]] && break;
            [[ $min < $max && $step < 0 ]] && break;
            echo $min;
            : $(( min += step ));
        done;
        return 0
    }
    setup-allowed-flags () 
    { 
        if [[ -z ${ALLOWED_FLAGS} ]]; then
            export ALLOWED_FLAGS="-pipe";
            export ALLOWED_FLAGS="${ALLOWED_FLAGS} -O -O0 -O1 -O2 -mcpu -march -mtune";
            export ALLOWED_FLAGS="${ALLOWED_FLAGS} -fstack-protector -fstack-protector-all";
            export ALLOWED_FLAGS="${ALLOWED_FLAGS} -fbounds-checking -fno-strict-overflow";
            export ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-PIE -fno-pie -fno-unit-at-a-time";
            export ALLOWED_FLAGS="${ALLOWED_FLAGS} -g -g[0-9] -ggdb -ggdb[0-9] -gstabs -gstabs+";
            export ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-ident";
            export ALLOWED_FLAGS="${ALLOWED_FLAGS} -W* -w";
        fi;
        ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-stack-protector -fno-stack-protector-all 		-fno-strict-aliasing -fno-bounds-checking -fstrict-overflow -fno-omit-frame-pointer";
        ALLOWED_FLAGS="${ALLOWED_FLAGS} -mregparm -mno-app-regs -mapp-regs 		-mno-mmx -mno-sse -mno-sse2 -mno-sse3 -mno-ssse3 -mno-sse4 -mno-sse4.1 		-mno-sse4.2 -mno-avx -mno-aes -mno-pclmul -mno-sse4a -mno-3dnow 		-mno-popcnt -mno-abm 		-mips1 -mips2 -mips3 -mips4 -mips32 -mips64 -mips16 -mplt 		-msoft-float -mno-soft-float -mhard-float -mno-hard-float -mfpu 		-mieee -mieee-with-inexact -mschedule -mfloat-gprs -mspe -mno-spe 		-mtls-direct-seg-refs -mno-tls-direct-seg-refs 		-mflat -mno-flat -mno-faster-structs -mfaster-structs 		-m32 -m64 -mabi -mlittle-endian -mbig-endian -EL -EB -fPIC 		-mlive-g0 -mcmodel -mstack-bias -mno-stack-bias 		-msecure-plt -m*-toc -D* -U*";
        ALLOWED_FLAGS="${ALLOWED_FLAGS} -mno-fma4 -mno-movbe -mno-xop -mno-lwp";
        ALLOWED_FLAGS="${ALLOWED_FLAGS} -mno-fsgsbase -mno-rdrnd -mno-f16c 		-mno-bmi -mno-tbm";
        export UNSTABLE_FLAGS="-Os -O3 -freorder-blocks";
        return 0
    }
    src_compile () 
    { 
        _eapi2_src_compile "$@"
    }
    src_configure () 
    { 
        lfs_fallocate_test;
        econf --enable-fs-paths-extra=/usr/sbin $(use_enable nls) --enable-agetty $(use_enable cramfs) $(use_enable old-linux elvtune) --disable-init --disable-kill --disable-last --disable-mesg --enable-partx --enable-raw --enable-rename --disable-reset --disable-login-utils --enable-schedutils --disable-wall --enable-write --without-pam $(use unicode || echo --with-ncurses) $(use_with selinux) $(use_with slang) $(tc-has-tls || echo --disable-tls)
    }
    src_install () 
    { 
        emake install DESTDIR="${D}" || die "install failed";
        dodoc AUTHORS NEWS README* TODO docs/*;
        if ! use perl; then
            rm "${D}"/usr/bin/chkdupexe || die;
            rm "${D}"/usr/share/man/man1/chkdupexe.1 || die;
        fi;
        gen_usr_ldscript -a blkid uuid;
        rm -f "${D}"/usr/$(get_libdir)/*.la;
        if use crypt; then
            newinitd "${FILESDIR}"/crypto-loop.initd crypto-loop || die;
            newconfd "${FILESDIR}"/crypto-loop.confd crypto-loop || die;
        fi
    }
    src_prepare () 
    { 
        if [[ ${PV} == "9999" ]]; then
            autopoint --force;
            eautoreconf;
        else
            use loop-aes && epatch "${WORKDIR}"/util-linux-ng-*.diff;
        fi;
        use uclibc && sed -i -e s/versionsort/alphasort/g -e s/strverscmp.h/dirent.h/g mount/lomount.c;
        elibtoolize
    }
    src_test () 
    { 
        _eapi0_src_test "$@"
    }
    src_unpack () 
    { 
        _eapi0_src_unpack "$@"
    }
    strip-flags () 
    { 
        local x y flag NEW_CFLAGS NEW_CXXFLAGS NEW_FFLAGS NEW_FCFLAGS;
        setup-allowed-flags;
        local NEW_CFLAGS="";
        local NEW_CXXFLAGS="";
        local NEW_FFLAGS="";
        local NEW_FCFLAGS="";
        if has "~$(tc-arch)" ${ACCEPT_KEYWORDS}; then
            ALLOWED_FLAGS="${ALLOWED_FLAGS} ${UNSTABLE_FLAGS}";
        fi;
        set -f;
        for x in ${CFLAGS};
        do
            for y in ${ALLOWED_FLAGS};
            do
                flag=${x%%=*};
                if [ "${flag%%${y}}" = "" ]; then
                    NEW_CFLAGS="${NEW_CFLAGS} ${x}";
                    break;
                fi;
            done;
        done;
        for x in ${CXXFLAGS};
        do
            for y in ${ALLOWED_FLAGS};
            do
                flag=${x%%=*};
                if [ "${flag%%${y}}" = "" ]; then
                    NEW_CXXFLAGS="${NEW_CXXFLAGS} ${x}";
                    break;
                fi;
            done;
        done;
        for x in ${FFLAGS};
        do
            for y in ${ALLOWED_FLAGS};
            do
                flag=${x%%=*};
                if [ "${flag%%${y}}" = "" ]; then
                    NEW_FFLAGS="${NEW_FFLAGS} ${x}";
                    break;
                fi;
            done;
        done;
        for x in ${FCFLAGS};
        do
            for y in ${ALLOWED_FLAGS};
            do
                flag=${x%%=*};
                if [ "${flag%%${y}}" = "" ]; then
                    NEW_FCFLAGS="${NEW_FCFLAGS} ${x}";
                    break;
                fi;
            done;
        done;
        if [ "${CFLAGS/-O}" != "${CFLAGS}" -a "${NEW_CFLAGS/-O}" = "${NEW_CFLAGS}" ]; then
            NEW_CFLAGS="${NEW_CFLAGS} -O2";
        fi;
        if [ "${CXXFLAGS/-O}" != "${CXXFLAGS}" -a "${NEW_CXXFLAGS/-O}" = "${NEW_CXXFLAGS}" ]; then
            NEW_CXXFLAGS="${NEW_CXXFLAGS} -O2";
        fi;
        if [ "${FFLAGS/-O}" != "${FFLAGS}" -a "${NEW_FFLAGS/-O}" = "${NEW_FFLAGS}" ]; then
            NEW_FFLAGS="${NEW_FFLAGS} -O2";
        fi;
        if [ "${FCFLAGS/-O}" != "${FCFLAGS}" -a "${NEW_FCFLAGS/-O}" = "${NEW_FCFLAGS}" ]; then
            NEW_FCFLAGS="${NEW_FCFLAGS} -O2";
        fi;
        set +f;
        export CFLAGS="${NEW_CFLAGS}";
        export CXXFLAGS="${NEW_CXXFLAGS}";
        export FFLAGS="${NEW_FFLAGS}";
        export FCFLAGS="${NEW_FCFLAGS}";
        return 0
    }
    strip-linguas () 
    { 
        local ls newls nols;
        if [[ $1 == "-i" ]] || [[ $1 == "-u" ]]; then
            local op=$1;
            shift;
            ls=$(find "$1" -name '*.po' -exec basename {} .po ';');
            shift;
            local d f;
            for d in "$@";
            do
                if [[ ${op} == "-u" ]]; then
                    newls=${ls};
                else
                    newls="";
                fi;
                for f in $(find "$d" -name '*.po' -exec basename {} .po ';');
                do
                    if [[ ${op} == "-i" ]]; then
                        hasq ${f} ${ls} && newls="${newls} ${f}";
                    else
                        hasq ${f} ${ls} || newls="${newls} ${f}";
                    fi;
                done;
                ls=${newls};
            done;
        else
            ls="$@";
        fi;
        nols="";
        newls="";
        for f in ${LINGUAS};
        do
            if hasq ${f} ${ls}; then
                newls="${newls} ${f}";
            else
                nols="${nols} ${f}";
            fi;
        done;
        [[ -n ${nols} ]] && ewarn "Sorry, but ${PN} does not support the LINGUAS:" ${nols};
        export LINGUAS=${newls:1}
    }
    strip-unsupported-flags () 
    { 
        export CFLAGS=$(test-flags-CC ${CFLAGS});
        export CXXFLAGS=$(test-flags-CXX ${CXXFLAGS});
        export FFLAGS=$(test-flags-F77 ${FFLAGS});
        export FCFLAGS=$(test-flags-FC ${FCFLAGS})
    }
    tc-arch () 
    { 
        tc-ninja_magic_to_arch portage "$@"
    }
    tc-arch-kernel () 
    { 
        tc-ninja_magic_to_arch kern "$@"
    }
    tc-endian () 
    { 
        local host=$1;
        [[ -z ${host} ]] && host=${CTARGET:-${CHOST}};
        host=${host%%-*};
        case ${host} in 
            alpha*)
                echo big
            ;;
            arm*b*)
                echo big
            ;;
            arm*)
                echo little
            ;;
            cris*)
                echo little
            ;;
            hppa*)
                echo big
            ;;
            i?86*)
                echo little
            ;;
            ia64*)
                echo little
            ;;
            m68*)
                echo big
            ;;
            mips*l*)
                echo little
            ;;
            mips*)
                echo big
            ;;
            powerpc*)
                echo big
            ;;
            s390*)
                echo big
            ;;
            sh*b*)
                echo big
            ;;
            sh*)
                echo little
            ;;
            sparc*)
                echo big
            ;;
            x86_64*)
                echo little
            ;;
            *)
                echo wtf
            ;;
        esac
    }
    tc-export () 
    { 
        local var;
        for var in "$@";
        do
            [[ $(type -t tc-get${var}) != "function" ]] && die "tc-export: invalid export variable '${var}'";
            eval tc-get${var} > /dev/null;
        done
    }
    tc-getAR () 
    { 
        tc-getPROG AR ar "$@"
    }
    tc-getAS () 
    { 
        tc-getPROG AS as "$@"
    }
    tc-getBUILD_CC () 
    { 
        local v;
        for v in CC_FOR_BUILD BUILD_CC HOSTCC;
        do
            if [[ -n ${!v} ]]; then
                export BUILD_CC=${!v};
                echo "${!v}";
                return 0;
            fi;
        done;
        local search=;
        if [[ -n ${CBUILD} ]]; then
            search=$(type -p ${CBUILD}-gcc);
            search=${search##*/};
        fi;
        search=${search:-gcc};
        export BUILD_CC=${search};
        echo "${search}"
    }
    tc-getCC () 
    { 
        tc-getPROG CC gcc "$@"
    }
    tc-getCPP () 
    { 
        tc-getPROG CPP cpp "$@"
    }
    tc-getCXX () 
    { 
        tc-getPROG CXX g++ "$@"
    }
    tc-getDLLWRAP () 
    { 
        tc-getPROG DLLWRAP dllwrap "$@"
    }
    tc-getF77 () 
    { 
        tc-getPROG F77 gfortran "$@"
    }
    tc-getFC () 
    { 
        tc-getPROG FC gfortran "$@"
    }
    tc-getGCJ () 
    { 
        tc-getPROG GCJ gcj "$@"
    }
    tc-getLD () 
    { 
        tc-getPROG LD ld "$@"
    }
    tc-getNM () 
    { 
        tc-getPROG NM nm "$@"
    }
    tc-getOBJCOPY () 
    { 
        tc-getPROG OBJCOPY objcopy "$@"
    }
    tc-getPKG_CONFIG () 
    { 
        tc-getPROG PKG_CONFIG pkg-config "$@"
    }
    tc-getPROG () 
    { 
        local var=$1;
        local prog=$2;
        if [[ -n ${!var} ]]; then
            echo "${!var}";
            return 0;
        fi;
        local search=;
        [[ -n $3 ]] && search=$(type -p "$3-${prog}");
        [[ -z ${search} && -n ${CHOST} ]] && search=$(type -p "${CHOST}-${prog}");
        [[ -n ${search} ]] && prog=${search##*/};
        export ${var}=${prog};
        echo "${!var}"
    }
    tc-getRANLIB () 
    { 
        tc-getPROG RANLIB ranlib "$@"
    }
    tc-getRC () 
    { 
        tc-getPROG RC windres "$@"
    }
    tc-getSTRIP () 
    { 
        tc-getPROG STRIP strip "$@"
    }
    tc-has-openmp () 
    { 
        local base="${T}/test-tc-openmp";
        cat > "${base}.c"  <<-EOF
#include <omp.h>
    int main() {
    int nthreads, tid, ret = 0;
#pragma omp parallel private(nthreads, tid)
    {
    tid = omp_get_thread_num();
    nthreads = omp_get_num_threads(); ret += tid + nthreads;
    }
    return ret;
    }
    EOF

        $(tc-getCC "$@") -fopenmp "${base}.c" -o "${base}" &>/dev/null;
        local ret=$?;
        rm -f "${base}"*;
        return ${ret}
    }
    tc-has-tls () 
    { 
        local base="${T}/test-tc-tls";
        cat > "${base}.c"  <<-EOF
    int foo(int *i) {
    static __thread int j = 0;
    return *i ? j : *i;
    }
    EOF

        local flags;
        case $1 in 
            -s)
                flags="-S"
            ;;
            -c)
                flags="-c"
            ;;
            -l)

            ;;
            -*)
                die "Usage: tc-has-tls [-c|-l] [toolchain prefix]"
            ;;
        esac;
        : ${flags:=-fPIC -shared -Wl,-z,defs};
        [[ $1 == -* ]] && shift;
        $(tc-getCC "$@") ${flags} "${base}.c" -o "${base}" &>/dev/null;
        local ret=$?;
        rm -f "${base}"*;
        return ${ret}
    }
    tc-is-cross-compiler () 
    { 
        return $([[ ${CBUILD:-${CHOST}} != ${CHOST} ]])
    }
    tc-is-hardfloat () 
    { 
        [[ ${CTARGET//_/-} == *-hardfloat-* ]] && echo "yes" || echo "no"
    }
    tc-is-softfloat () 
    { 
        case ${CTARGET} in 
            bfin* | h8300*)
                echo "only"
            ;;
            *)
                [[ ${CTARGET//_/-} == *-softfloat-* ]] && echo "yes" || echo "no"
            ;;
        esac
    }
    tc-is-static-only () 
    { 
        local host=${CTARGET:-${CHOST}};
        return $([[ ${host} == *-mint* ]])
    }
    tc-ninja_magic_to_arch () 
    { 
        function ninj () 
        { 
            [[ ${type} == "kern" ]] && echo $1 || echo $2
        };
        local type=$1;
        local host=$2;
        [[ -z ${host} ]] && host=${CTARGET:-${CHOST}};
        case ${host} in 
            alpha*)
                echo alpha
            ;;
            arm*)
                echo arm
            ;;
            avr*)
                ninj avr32 avr
            ;;
            bfin*)
                ninj blackfin bfin
            ;;
            cris*)
                echo cris
            ;;
            hppa*)
                ninj parisc hppa
            ;;
            i?86*)
                if [[ ${type} == "kern" ]] && [[ $(KV_to_int ${KV}) -lt $(KV_to_int 2.6.24) || ${host} == *freebsd* ]]; then
                    echo i386;
                else
                    echo x86;
                fi
            ;;
            ia64*)
                echo ia64
            ;;
            m68*)
                echo m68k
            ;;
            mips*)
                echo mips
            ;;
            nios2*)
                echo nios2
            ;;
            nios*)
                echo nios
            ;;
            powerpc*)
                if [[ ${type} == "kern" ]] && [[ $(KV_to_int ${KV}) -ge $(KV_to_int 2.6.16) ]]; then
                    echo powerpc;
                else
                    if [[ ${type} == "kern" ]] && [[ $(KV_to_int ${KV}) -eq $(KV_to_int 2.6.15) ]]; then
                        if [[ ${host} == powerpc64* ]] || [[ ${PROFILE_ARCH} == "ppc64" ]]; then
                            echo powerpc;
                        else
                            echo ppc;
                        fi;
                    else
                        if [[ ${host} == powerpc64* ]]; then
                            echo ppc64;
                        else
                            if [[ ${PROFILE_ARCH} == "ppc64" ]]; then
                                ninj ppc64 ppc;
                            else
                                echo ppc;
                            fi;
                        fi;
                    fi;
                fi
            ;;
            s390*)
                echo s390
            ;;
            sh64*)
                ninj sh64 sh
            ;;
            sh*)
                echo sh
            ;;
            sparc64*)
                ninj sparc64 sparc
            ;;
            sparc*)
                [[ ${PROFILE_ARCH} == "sparc64" ]] && ninj sparc64 sparc || echo sparc
            ;;
            vax*)
                echo vax
            ;;
            x86_64*)
                if [[ ${type} == "kern" ]] && [[ $(KV_to_int ${KV}) -ge $(KV_to_int 2.6.24) ]]; then
                    echo x86;
                else
                    ninj x86_64 amd64;
                fi
            ;;
            *)
                echo unknown
            ;;
        esac
    }
    test-flag-CC () 
    { 
        test-flag-PROG "CC" "$1"
    }
    test-flag-CXX () 
    { 
        test-flag-PROG "CXX" "$1"
    }
    test-flag-F77 () 
    { 
        test-flag-PROG "F77" "$1"
    }
    test-flag-FC () 
    { 
        test-flag-PROG "FC" "$1"
    }
    test-flag-PROG () 
    { 
        local comp=$1;
        local flags="$2";
        [[ -z ${comp} || -z ${flags} ]] && return 1;
        local PROG=$(tc-get${comp});
        ${PROG} ${flags} -S -o /dev/null -xc /dev/null > /dev/null 2>&1
    }
    test-flags () 
    { 
        test-flags-CC "$@"
    }
    test-flags-CC () 
    { 
        test-flags-PROG "CC" "$@"
    }
    test-flags-CXX () 
    { 
        test-flags-PROG "CXX" "$@"
    }
    test-flags-F77 () 
    { 
        test-flags-PROG "F77" "$@"
    }
    test-flags-FC () 
    { 
        test-flags-PROG "FC" "$@"
    }
    test-flags-PROG () 
    { 
        local comp=$1;
        local flags;
        local x;
        shift;
        [[ -z ${comp} ]] && return 1;
        x="";
        for x in "$@";
        do
            test-flag-${comp} "${x}" && flags="${flags}${flags:+ }${x}";
        done;
        echo "${flags}";
        [[ -n ${flags} ]]
    }
    test_flag () 
    { 
        ewarn "test_flag: deprecated, please use test-flags()!" 1>&2;
        test-flags-CC "$@"
    }
    test_version_info () 
    { 
        if [[ $($(tc-getCC) --version 2>&1) == *$1* ]]; then
            return 0;
        else
            return 1;
        fi
    }
    treecopy () 
    { 
        dest=${!#};
        files_count=$#;
        while (( $# > 1 )); do
            dirstruct=$(dirname "$1");
            mkdir -p "${dest}/${dirstruct}";
            cp -pPR "$1" "${dest}/${dirstruct}";
            shift;
        done
    }
    uclibctoolize () 
    { 
        die "Use elibtoolize"
    }
    unpack_makeself () 
    { 
        local src_input=${1:-${A}};
        local src=$(find_unpackable_file "${src_input}");
        local skip=$2;
        local exe=$3;
        [[ -z ${src} ]] && die "Could not locate source for '${src_input}'";
        local shrtsrc=$(basename "${src}");
        echo ">>> Unpacking ${shrtsrc} to ${PWD}";
        if [[ -z ${skip} ]]; then
            local ver=$(grep -m1 -a '#.*Makeself' "${src}" | awk '{print $NF}');
            local skip=0;
            exe=tail;
            case ${ver} in 
                1.5.* | 1.6.0-nv)
                    skip=$(grep -a ^skip= "${src}" | cut -d= -f2)
                ;;
                2.0 | 2.0.1)
                    skip=$(grep -a ^'	'tail "${src}" | awk '{print $2}' | cut -b2-)
                ;;
                2.1.1)
                    skip=$(grep -a ^offset= "${src}" | awk '{print $2}' | cut -b2-);
                    (( skip++ ))
                ;;
                2.1.2)
                    skip=$(grep -a ^offset= "${src}" | awk '{print $3}' | head -n 1);
                    (( skip++ ))
                ;;
                2.1.3)
                    skip=`grep -a ^offset= "${src}" | awk '{print $3}'`;
                    (( skip++ ))
                ;;
                2.1.4 | 2.1.5)
                    skip=$(grep -a offset=.*head.*wc "${src}" | awk '{print $3}' | head -n 1);
                    skip=$(head -n ${skip} "${src}" | wc -c);
                    exe="dd"
                ;;
                *)
                    eerror "I'm sorry, but I was unable to support the Makeself file.";
                    eerror "The version I detected was '${ver}'.";
                    eerror "Please file a bug about the file ${shrtsrc} at";
                    eerror "http://bugs.gentoo.org/ so that support can be added.";
                    die "makeself version '${ver}' not supported"
                ;;
            esac;
            debug-print "Detected Makeself version ${ver} ... using ${skip} as offset";
        fi;
        case ${exe} in 
            tail)
                exe="tail -n +${skip} '${src}'"
            ;;
            dd)
                exe="dd ibs=${skip} skip=1 if='${src}'"
            ;;
            *)
                die "makeself cant handle exe '${exe}'"
            ;;
        esac;
        local tmpfile=$(emktemp);
        eval ${exe} 2> /dev/null | head -c 512 > "${tmpfile}";
        local filetype=$(file -b "${tmpfile}");
        case ${filetype} in 
            *tar\ archive*)
                eval ${exe} | tar --no-same-owner -xf -
            ;;
            bzip2*)
                eval ${exe} | bzip2 -dc | tar --no-same-owner -xf -
            ;;
            gzip*)
                eval ${exe} | tar --no-same-owner -xzf -
            ;;
            compress*)
                eval ${exe} | gunzip | tar --no-same-owner -xf -
            ;;
            *)
                eerror "Unknown filetype \"${filetype}\" ?";
                false
            ;;
        esac;
        assert "failure unpacking (${filetype}) makeself ${shrtsrc} ('${ver}' +${skip})"
    }
    unpack_pdv () 
    { 
        local src=$(find_unpackable_file "$1");
        local sizeoff_t=$2;
        [[ -z ${src} ]] && die "Could not locate source for '$1'";
        [[ -z ${sizeoff_t} ]] && die "No idea what off_t size was used for this pdv :(";
        local shrtsrc=$(basename "${src}");
        echo ">>> Unpacking ${shrtsrc} to ${PWD}";
        local metaskip=$(tail -c ${sizeoff_t} "${src}" | hexdump -e \"%i\");
        local tailskip=$(tail -c $((${sizeoff_t}*2)) "${src}" | head -c ${sizeoff_t} | hexdump -e \"%i\");
        local metafile=$(emktemp);
        tail -c +$((${metaskip}+1)) "${src}" > "${metafile}";
        local datafile=$(tail -c +$((${metaskip}+1)) "${src}" | strings | head -n 1);
        datafile=$(basename "${datafile}");
        local tmpfile=$(emktemp);
        tail -c +$((${tailskip}+1)) ${src} 2> /dev/null | head -c 512 > ${tmpfile};
        local iscompressed=$(file -b "${tmpfile}");
        if [[ ${iscompressed:0:8} == "compress" ]]; then
            iscompressed=1;
            mv ${tmpfile}{,.Z};
            gunzip ${tmpfile};
        else
            iscompressed=0;
        fi;
        local istar=$(file -b "${tmpfile}");
        if [[ ${istar:0:9} == "POSIX tar" ]]; then
            istar=1;
        else
            istar=0;
        fi;
        if [ ${iscompressed} -eq 1 ]; then
            if [ ${istar} -eq 1 ]; then
                tail -c +$((${tailskip}+1)) ${src} 2> /dev/null | head -c $((${metaskip}-${tailskip})) | tar -xzf -;
            else
                tail -c +$((${tailskip}+1)) ${src} 2> /dev/null | head -c $((${metaskip}-${tailskip})) | gzip -dc > ${datafile};
            fi;
        else
            if [ ${istar} -eq 1 ]; then
                tail -c +$((${tailskip}+1)) ${src} 2> /dev/null | head -c $((${metaskip}-${tailskip})) | tar --no-same-owner -xf -;
            else
                tail -c +$((${tailskip}+1)) ${src} 2> /dev/null | head -c $((${metaskip}-${tailskip})) > ${datafile};
            fi;
        fi;
        true
    }
    validate_desktop_entries () 
    { 
        if [[ -x /usr/bin/desktop-file-validate ]]; then
            einfo "Checking desktop entry validity";
            local directories="";
            for d in /usr/share/applications $@;
            do
                [[ -d ${D}${d} ]] && directories="${directories} ${D}${d}";
            done;
            if [[ -n ${directories} ]]; then
                for FILE in $(find ${directories} -name "*\.desktop" 							-not -path '*.hidden*' | sort -u 2>/dev/null);
                do
                    local temp=$(desktop-file-validate ${FILE} | grep -v "warning:" | 								sed -e "s|error: ||" -e "s|${FILE}:|--|g" );
                    [[ -n $temp ]] && elog ${temp/--/${FILE/${D}/}:};
                done;
            fi;
            echo "";
        else
            einfo "Passing desktop entry validity check. Install dev-util/desktop-file-utils, if you want to help to improve Gentoo.";
        fi
    }





How can I fix this issue?

Thank you very much for any help in advance!

Best regards,
mcc







^ permalink raw reply	[flat|nested] 2+ messages in thread

* [gentoo-user] Re: util-linux failed to patch while emergeing
  2011-02-13  5:58 [gentoo-user] util-linux failed to patch while emergeing meino.cramer
@ 2011-02-14 17:11 ` walt
  0 siblings, 0 replies; 2+ messages in thread
From: walt @ 2011-02-14 17:11 UTC (permalink / raw
  To: gentoo-user

On 02/12/2011 09:58 PM, meino.cramer@gmx.de wrote:
> Hi,
>
> this morning I got this while emergeing util-linux:
>
>      >>>  Emerging (1 of 1) sys-apps/util-linux-2.19
>      * util-linux-2.19.tar.bz2 RMD160 SHA1 SHA256 size ;-) ...              [ ok ]
>      * util-linux-ng-2.18-20100706.diff.bz2 RMD160 SHA1 SHA256 size ;-) ... [ ok ]
>      * Package:    sys-apps/util-linux-2.19
>      * Repository: gentoo
>      * Maintainer: base-system@gentoo.org
>      * USE:  amd64 cramfs crypt elibc_glibc kernel_linux loop-aes multilib nls perl userland_GNU
>      >>>  Unpacking source...
>      >>>  Unpacking util-linux-2.19.tar.bz2 to /var/tmp/portage/sys-apps/util-linux-2.19/work
>      >>>  Unpacking util-linux-ng-2.18-20100706.diff.bz2 to /var/tmp/portage/sys-apps/util-linux-2.19/work
>      >>>  Source unpacked in /var/tmp/portage/sys-apps/util-linux-2.19/work
>      >>>  Preparing source in /var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-2.19 ...
>      * Applying util-linux-ng-2.18-20100706.diff ...
>
>      * Failed Patch: util-linux-ng-2.18-20100706.diff !
>      *  ( /var/tmp/portage/sys-apps/util-linux-2.19/work/util-linux-ng-2.18-20100706.diff )
>      *
>      * Include in your bugreport the contents of:
>      *
>      *   /var/tmp/portage/sys-apps/util-linux-2.19/temp/util-linux-ng-2.18-20100706.diff.out

That diff.out file shows that the patch being applied is grossly broken for version 2.19.

If you really need the loop-aes useflag, you'll just have to wait for the gentoo dev to fix
the ebuild.  Otherwise, just unset the loop-aes flag.  Dunno if there is a bug report open
for this, but there should be.





^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2011-02-14 17:13 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-02-13  5:58 [gentoo-user] util-linux failed to patch while emergeing meino.cramer
2011-02-14 17:11 ` [gentoo-user] " walt

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox