diff options
author | Javier Villavicencio <the_paya@gentoo.org> | 2010-03-16 02:25:33 +0000 |
---|---|---|
committer | Javier Villavicencio <the_paya@gentoo.org> | 2010-03-16 02:25:33 +0000 |
commit | b0d457c3837d6623698b969bb273899ab6e42fad (patch) | |
tree | 4e38ba3283a25c8ecbc102d055d501ec4d7c9c9c /profiles/default/bsd/fbsd | |
parent | Remove stray bracket from gnu mirrors. (diff) | |
download | historical-b0d457c3837d6623698b969bb273899ab6e42fad.tar.gz historical-b0d457c3837d6623698b969bb273899ab6e42fad.tar.bz2 historical-b0d457c3837d6623698b969bb273899ab6e42fad.zip |
Another hack on fbsd/profile.bashrc to patch known install-sh versions that are likely to fail during a parallel make install.
Diffstat (limited to 'profiles/default/bsd/fbsd')
-rw-r--r-- | profiles/default/bsd/fbsd/profile.bashrc | 62 |
1 files changed, 60 insertions, 2 deletions
diff --git a/profiles/default/bsd/fbsd/profile.bashrc b/profiles/default/bsd/fbsd/profile.bashrc index 11ebca7ba10e..a22e22aae70d 100644 --- a/profiles/default/bsd/fbsd/profile.bashrc +++ b/profiles/default/bsd/fbsd/profile.bashrc @@ -1,6 +1,6 @@ #!/bin/bash # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/profiles/default/bsd/fbsd/profile.bashrc,v 1.4 2009/03/11 14:43:09 drizzt Exp $ +# $Header: /var/cvsroot/gentoo-x86/profiles/default/bsd/fbsd/profile.bashrc,v 1.5 2010/03/16 02:25:33 the_paya Exp $ alias make=gmake alias patch=gpatch @@ -12,9 +12,67 @@ alias awk=gawk # See bugs 169678, 195148 and 256129. # Also the discussion on # http://archives.gentoo.org/gentoo-dev/msg_8cb1805411f37b4eb168a3e680e531f3.xml -post_src_install() +bsd-post_src_install() { if [ "${PN}" != "libiconv" -a -e "${D}"/usr/lib*/charset.alias ] ; then rm -f "${D}"/usr/lib*/charset.alias fi } + +# These are because of +# http://archives.gentoo.org/gentoo-dev/msg_529a0806ed2cf841a467940a57e2d588.xml +# The profile-* ones are meant to be used in etc/portage/profile.bashrc by user +# until there is the registration mechanism. +profile-post_src_install() { bsd-post_src_install ; } + post_src_install() { bsd-post_src_install ; } + + +# Another hack to fix old versions of install-sh (automake) where a non-gnu +# mkdir is not considered thread-safe (make install errors with -j > 1) +bsd-patch_install-sh() { + # Do nothing if we don't have patch installed: + if [[ -z $(type -P gpatch) ]]; then + return 0 + fi + local EPDIR="${ECLASSDIR}/ELT-patches/install-sh" + local EPATCHES="${EPDIR}/1.5.6 ${EPDIR}/1.5.4 ${EPDIR}/1.5" + local ret=0 + for file in $(find . -name "install-sh" -print); do + if [[ -n $(egrep "scriptversion=2005|scriptversion=2004" ${file}) ]]; then + einfo "Automatically patching parallel-make unfriendly install-sh." + # Stolen from libtool.eclass + for mypatch in ${EPATCHES}; do + if gpatch -p0 --dry-run "${file}" "${mypatch}" &> "${T}/patch_install-sh.log"; then + gpatch -p0 -g0 --no-backup-if-mismatch "${file}" "${mypatch}" \ + &> "${T}/patch_install-sh.log" + ret=$? + break + else + ret=1 + fi + done + if [[ ret -eq 0 ]]; then + einfo "Patch applied successfully on \"${file}\"." + else + ewarn "Unable to apply install-sh patch. " + ewarn "If you experience errors during install phase, try with MAKEOPTS=\"-j1\"" + fi + fi + done +} + +# It should be run after everything has been unpacked/patched, some developers +# do patch this little bastard from time to time. +# So do it after unpack() for EAPI=0|1 and after prepare() for everything else. +if [[ -n $EAPI ]] ; then + case "$EAPI" in + 0|1) + profile-post_src_unpack() { bsd-patch_install-sh ; } + post_src_unpack() { bsd-patch_install-sh ; } + ;; + *) + profile_post_src_prepare() { bsd-patch_install-sh ; } + post_src_prepare() { bsd-patch_install-sh ; } + ;; + esac +fi |