summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeremy Huddleston <eradicator@gentoo.org>2005-01-07 12:04:40 +0000
committerJeremy Huddleston <eradicator@gentoo.org>2005-01-07 12:04:40 +0000
commit9b130435f622418d0fb35eb3f6c54481aad322eb (patch)
treedf364b33852a8b76184c01b42f12f567385fedbe
parentadd metadata. (diff)
downloadhistorical-9b130435f622418d0fb35eb3f6c54481aad322eb.tar.gz
historical-9b130435f622418d0fb35eb3f6c54481aad322eb.tar.bz2
historical-9b130435f622418d0fb35eb3f6c54481aad322eb.zip
Added get_all_libdirs. Changed die to eerror/exit since die doesn't have the expected result when called from a subshell.
-rw-r--r--eclass/eutils.eclass146
1 files changed, 85 insertions, 61 deletions
diff --git a/eclass/eutils.eclass b/eclass/eutils.eclass
index fa12e10312a0..d035477a3a3a 100644
--- a/eclass/eutils.eclass
+++ b/eclass/eutils.eclass
@@ -1,6 +1,6 @@
# Copyright 1999-2004 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.137 2005/01/07 11:21:42 eradicator Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.138 2005/01/07 12:04:40 eradicator Exp $
#
# Author: Martin Schlemmer <azarah@gentoo.org>
#
@@ -43,66 +43,6 @@ ebeep() {
fi
}
-# This function simply returns the desired lib directory. With portage
-# 2.0.51, we now have support for installing libraries to lib32/lib64
-# to accomidate the needs of multilib systems. It's no longer a good idea
-# to assume all libraries will end up in lib. Replace any (sane) instances
-# where lib is named directly with $(get_libdir) if possible.
-#
-# Travis Tilley <lv@gentoo.org> (24 Aug 2004)
-#
-# Jeremy Huddleston <eradicator@gentoo.org> (23 Dec 2004):
-# Added support for ${ABI} and ${DEFAULT_ABI}. If they're both not set,
-# fall back on old behavior. Any profile that has these set should also
-# depend on a newer version of portage (not yet released) which uses these
-# over CONF_LIBDIR in econf, dolib, etc...
-get_libdir() {
- LIBDIR_TEST=$(type econf)
- if [ ! -z "${CONF_LIBDIR_OVERRIDE}" ] ; then
- # if there is an override, we want to use that... always.
- CONF_LIBDIR="${CONF_LIBDIR_OVERRIDE}"
- # We don't need to know the verison of portage. We only need to know
- # if there is support for CONF_LIBDIR in econf and co.
- # Danny van Dyk <kugelfang@gentoo.org> 2004/17/09
- #elif portageq has_version / '<sys-apps/portage-2.0.51_pre20' ; then
- # # and if there isnt an override, and we're using a version of
- # # portage without CONF_LIBDIR support, force the use of lib. dolib
- # # and friends from portage 2.0.50 wont be too happy otherwise.
- # CONF_LIBDIR="lib"
- #fi
- elif [ -n "$(get_abi_LIBDIR)" ]; then # Using eradicator's LIBDIR_<abi> approach...
- CONF_LIBDIR="$(get_abi_LIBDIR)"
- elif [ "${LIBDIR_TEST/CONF_LIBDIR}" == "${LIBDIR_TEST}" ]; then # we don't have CONF_LIBDIR support
- # will be <portage-2.0.51_pre20
- CONF_LIBDIR="lib"
- fi
- # and of course, default to lib if CONF_LIBDIR isnt set
- echo ${CONF_LIBDIR:=lib}
- unset LIBDIR_TEST
-}
-
-get_multilibdir() {
- [ -n "$(get_abi_LIBDIR)" ] && die "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"
- echo ${CONF_MULTILIBDIR:=lib32}
-}
-
-# Sometimes you need to override the value returned by get_libdir. A good
-# example of this is xorg-x11, where lib32 isnt a supported configuration,
-# and where lib64 -must- be used on amd64 (for applications that need lib
-# to be 32bit, such as adobe acrobat). Note that this override also bypasses
-# portage version sanity checking.
-# get_libdir_override expects one argument, the result get_libdir should
-# return:
-#
-# get_libdir_override lib64
-#
-# Travis Tilley <lv@gentoo.org> (31 Aug 2004)
-get_libdir_override() {
- [ -n "$(get_abi_LIBDIR)" ] && die "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"
- CONF_LIBDIR="$1"
- CONF_LIBDIR_OVERRIDE="$1"
-}
-
# This function generate linker scripts in /usr/lib for dynamic
# libs in /lib. This is to fix linking problems when you have
# the .so in /lib, and the .a in /usr/lib. What happens is that
@@ -1653,6 +1593,72 @@ epunt_cxx() {
eend 0
}
+# This function simply returns the desired lib directory. With portage
+# 2.0.51, we now have support for installing libraries to lib32/lib64
+# to accomidate the needs of multilib systems. It's no longer a good idea
+# to assume all libraries will end up in lib. Replace any (sane) instances
+# where lib is named directly with $(get_libdir) if possible.
+#
+# Travis Tilley <lv@gentoo.org> (24 Aug 2004)
+#
+# Jeremy Huddleston <eradicator@gentoo.org> (23 Dec 2004):
+# Added support for ${ABI} and ${DEFAULT_ABI}. If they're both not set,
+# fall back on old behavior. Any profile that has these set should also
+# depend on a newer version of portage (not yet released) which uses these
+# over CONF_LIBDIR in econf, dolib, etc...
+get_libdir() {
+ LIBDIR_TEST=$(type econf)
+ if [ ! -z "${CONF_LIBDIR_OVERRIDE}" ] ; then
+ # if there is an override, we want to use that... always.
+ CONF_LIBDIR="${CONF_LIBDIR_OVERRIDE}"
+ # We don't need to know the verison of portage. We only need to know
+ # if there is support for CONF_LIBDIR in econf and co.
+ # Danny van Dyk <kugelfang@gentoo.org> 2004/17/09
+ #elif portageq has_version / '<sys-apps/portage-2.0.51_pre20' ; then
+ # # and if there isnt an override, and we're using a version of
+ # # portage without CONF_LIBDIR support, force the use of lib. dolib
+ # # and friends from portage 2.0.50 wont be too happy otherwise.
+ # CONF_LIBDIR="lib"
+ #fi
+ elif [ -n "$(get_abi_LIBDIR)" ]; then # Using eradicator's LIBDIR_<abi> approach...
+ CONF_LIBDIR="$(get_abi_LIBDIR)"
+ elif [ "${LIBDIR_TEST/CONF_LIBDIR}" == "${LIBDIR_TEST}" ]; then # we don't have CONF_LIBDIR support
+ # will be <portage-2.0.51_pre20
+ CONF_LIBDIR="lib"
+ fi
+ # and of course, default to lib if CONF_LIBDIR isnt set
+ echo ${CONF_LIBDIR:=lib}
+ unset LIBDIR_TEST
+}
+
+get_multilibdir() {
+ if [ -n "$(get_abi_LIBDIR)" ]; 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}
+}
+
+# Sometimes you need to override the value returned by get_libdir. A good
+# example of this is xorg-x11, where lib32 isnt a supported configuration,
+# and where lib64 -must- be used on amd64 (for applications that need lib
+# to be 32bit, such as adobe acrobat). Note that this override also bypasses
+# portage version sanity checking.
+# get_libdir_override expects one argument, the result get_libdir should
+# return:
+#
+# get_libdir_override lib64
+#
+# Travis Tilley <lv@gentoo.org> (31 Aug 2004)
+get_libdir_override() {
+ if [ -n "$(get_abi_LIBDIR)" ]; 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"
+}
+
# get_abi_var <VAR> [<ABI>]
# returns the value of ${<VAR>_<ABI>} which should be set in make.defaults
#
@@ -1688,3 +1694,21 @@ get_abi_CFLAGS() { get_abi_var CFLAGS ${@}; }
get_abi_CXXFLAGS() { get_abi_var CXXFLAGS ${@}; }
get_abi_ASFLAGS() { get_abi_var ASFLAGS ${@}; }
get_abi_LIBDIR() { get_abi_var LIBDIR ${@}; }
+
+# get_all_libdir()
+# Returns a list of all the libdirs used by this profile
+get_all_libdirs() {
+ local libdirs
+ if [ -n "${MULTILIB_ABIS}" ]; then
+ for abi in ${MULTILIB_ABIS}; do
+ libdirs="${libdirs} $(get_abi_LIBDIR ${abi})"
+ done
+ libdirs="${libdirs:1}"
+ elif [ -n "${CONF_LIBDIR}" ]; then
+ libdirs="${CONF_LIBDIR} ${CONF_MULTILIBDIR:=lib32}"
+ else
+ libdirs="lib"
+ fi
+
+ echo "${libdirs}"
+}