summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2009-03-25 20:13:56 +0000
committerZac Medico <zmedico@gentoo.org>2009-03-25 20:13:56 +0000
commit8cbdd24456cfc4d1fb6326068d9e6b64904ffc8e (patch)
tree8618df5f3b58dad0e2302b9dc09ed463d3567d36
parentf8127b9110ae0b3ac4660284c291c803ce8df992 (diff)
downloadportage-8cbdd24456cfc4d1fb6326068d9e6b64904ffc8e.tar.gz
portage-8cbdd24456cfc4d1fb6326068d9e6b64904ffc8e.tar.bz2
portage-8cbdd24456cfc4d1fb6326068d9e6b64904ffc8e.zip
Move distcc and ccache PATH setup later, after EAPI is guaranteed to be known,
so that it's possible to do indepenent EAPI-specific PATH modifications prior to the distcc/ccache modifications. svn path=/main/trunk/; revision=13183
-rwxr-xr-xbin/ebuild.sh93
1 files changed, 35 insertions, 58 deletions
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 9ac89174f..9ce5be334 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -1709,64 +1709,6 @@ preprocess_ebuild_env() {
# === === === === === functions end, main part begins === === === === ===
# === === === === === === === === === === === === === === === === === ===
-if [ -n "${EBUILD_SH_ARGS}" ] && \
- ! hasq ${EBUILD_SH_ARGS} clean depend help info nofetch ; then
-
- if [ "$(id -nu)" == "portage" ] ; then
- export USER=portage
- fi
-
- if hasq distcc ${FEATURES} ; then
- if [ -d /usr/lib/distcc/bin ]; then
- #We can enable distributed compile support
- if [ -z "${PATH/*distcc*/}" ]; then
- # Remove the other reference.
- remove_path_entry "distcc"
- fi
- export PATH="/usr/lib/distcc/bin:${PATH}"
- [ ! -z "${DISTCC_LOG}" ] && addwrite "$(dirname ${DISTCC_LOG})"
- elif which distcc &>/dev/null; then
- if ! hasq distcc $CC; then
- export CC="distcc $CC"
- fi
- if ! hasq distcc $CXX; then
- export CXX="distcc $CXX"
- fi
- fi
- fi
-
- if hasq ccache ${FEATURES} ; then
- #We can enable compiler cache support
- if [ -z "${PATH/*ccache*/}" ]; then
- # Remove the other reference.
- remove_path_entry "ccache"
- fi
-
- if [ -d /usr/lib/ccache/bin ]; then
- export PATH="/usr/lib/ccache/bin:${PATH}"
- elif [ -d /usr/bin/ccache ]; then
- export PATH="/usr/bin/ccache:${PATH}"
- fi
-
- [ -z "${CCACHE_DIR}" ] && export CCACHE_DIR="/var/tmp/ccache"
-
- addread "${CCACHE_DIR}"
- addwrite "${CCACHE_DIR}"
-
- [ -n "${CCACHE_SIZE}" ] && ccache -M ${CCACHE_SIZE} &> /dev/null
- else
- # Force configure scripts that automatically detect ccache to respect
- # FEATURES="-ccache"
- export CCACHE_DISABLE=1
- fi
-
- # XXX: Load up the helper functions.
-# for X in /usr/lib/portage/bin/functions/*.sh; do
-# source ${X} || die "Failed to source ${X}"
-# done
-
-fi # "$*"!="depend" && "$*"!="clean" && "$*" != "setup"
-
export SANDBOX_ON="1"
export S=${WORKDIR}/${P}
@@ -1943,6 +1885,41 @@ ebuild_main() {
local export_vars="ASFLAGS CCACHE_DIR CCACHE_SIZE
CFLAGS CXXFLAGS LDFLAGS LIBCFLAGS LIBCXXFLAGS"
+ if ! hasq $EBUILD_SH_ARGS clean depend help info nofetch ; then
+
+ if hasq distcc $FEATURES ; then
+ if [ -d /usr/lib/distcc/bin ] ; then
+ [[ -z ${PATH/*distcc*/} ]] && remove_path_entry distcc
+ export PATH="/usr/lib/distcc/bin:$PATH"
+ [[ -n $DISTCC_LOG ]] && addwrite "${DISTCC_LOG%/*}"
+ elif type -P distcc >/dev/null ; then
+ ! hasq distcc $CC && export CC="distcc $CC"
+ ! hasq distcc $CXX && export CXX="distcc $CXX"
+ fi
+ fi
+
+ if hasq ccache $FEATURES ; then
+ [[ -z ${PATH/*ccache*/} ]] && remove_path_entry ccache
+
+ if [ -d /usr/lib/ccache/bin ] ; then
+ export PATH="/usr/lib/ccache/bin:$PATH"
+ elif [ -d /usr/bin/ccache ] ; then
+ export PATH="/usr/bin/ccache:$PATH"
+ fi
+
+ [[ -z $CCACHE_DIR ]] && export CCACHE_DIR=/var/tmp/ccache
+
+ addread "$CCACHE_DIR"
+ addwrite "$CCACHE_DIR"
+
+ [[ -n $CCACHE_SIZE ]] && ccache -M $CCACHE_SIZE &> /dev/null
+ else
+ # Force configure scripts that automatically detect ccache to
+ # respect FEATURES="-ccache".
+ export CCACHE_DISABLE=1
+ fi
+ fi
+
case ${EBUILD_SH_ARGS} in
nofetch)
ebuild_phase_with_hooks pkg_nofetch