From: Zac Medico Date: Mon, 1 Aug 2011 23:48:07 +0000 (-0700) Subject: unpack: always unpack to cwd (bug #376741) X-Git-Tag: v2.2.0_alpha50~2 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=75a0cce2b6d7ecb8f369a65fbb047e3ce9d96b44;p=portage.git unpack: always unpack to cwd (bug #376741) This brings portage into agreement with PMS. Also, for existing EAPIs, if the source file is in a writable directory then this will create a symlink for backward-compatible emulation of tools like gunzip and bunzip2. --- diff --git a/bin/ebuild.sh b/bin/ebuild.sh index 4aef4134d..3d4d5576a 100755 --- a/bin/ebuild.sh +++ b/bin/ebuild.sh @@ -370,7 +370,21 @@ unpack() { $1 -c -- "$srcdir$x" | tar xof - assert_sigpipe_ok "$myfail" else - $1 -c -- "${srcdir}${x}" > ${x%.*} || die "$myfail" + local cwd_dest=${x##*/} + cwd_dest=${cwd_dest%.*} + $1 -c -- "${srcdir}${x}" > "${cwd_dest}" || die "$myfail" + case "$EAPI" in + 0|1|2|3|4|4-python) + # If the source file is in a writable directory then + # create a symlink for backward-compatible emulation + # of tools like gunzip and bunzip2 (see bug #376741). + if [[ ! -e ${x%.*} && -w ${x%/*} ]] && \ + [[ ${x} == "${PORTAGE_BUILDDIR}/"* || + ${x} == ./* || ${x} != /* ]] ; then + ln -snf "${PWD}/${cwd_dest}" "${x%.*}" + fi + ;; + esac fi }