From: Zac Medico Date: Sat, 26 Jul 2008 10:31:59 +0000 (-0000) Subject: * Use pure bash ${PARAMETER%/*} instead of spawing`dirname`. X-Git-Tag: v2.2_rc4~28 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=29b86c987aba118e75428fd01b8e4261a3eba685;p=portage.git * Use pure bash ${PARAMETER%/*} instead of spawing`dirname`. * Break out of loop as early as possible when searching for libs in ${D}. svn path=/main/trunk/; revision=11199 --- diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh index b27c81e86..e8b23a4d3 100755 --- a/bin/misc-functions.sh +++ b/bin/misc-functions.sh @@ -170,7 +170,7 @@ install_qa_check() { echo "${obj} ${needed}" >> "${PORTAGE_BUILDDIR}"/build-info/NEEDED echo "${arch:3};${obj};${soname};${rpath};${needed}" >> "${PORTAGE_BUILDDIR}"/build-info/NEEDED.ELF.2 else - dir=$(dirname ${obj}) + dir=${obj%/*} # replace $ORIGIN with the dirname of the current object for the lookup opath=$(echo :${rpath}: | sed -e "s#.*:\(.*\)\$ORIGIN\(.*\):.*#\1${dir}\2#") sneeded=$(echo ${needed} | tr , ' ') @@ -178,7 +178,7 @@ install_qa_check() { for lib in ${sneeded}; do found=0 for path in ${opath//:/ }; do - [ -e "${D}/${path}/${lib}" ] && found=1 + [ -e "${D}/${path}/${lib}" ] && found=1 && break done [ "${found}" -eq 0 ] && rneeded="${rneeded},${lib}" done