commit: 7345c7f2d1f42ec82330796f3b8cda8b6d558a49
Author: Daniel Campbell <zlg <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 27 07:25:49 2015 +0000
Commit: Daniel Campbell <zlg <AT> gentoo <DOT> org>
CommitDate: Thu Aug 27 07:25:49 2015 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7345c7f2
media-sound/apulse: Fix ebuild and script to support all ABIs
Prior solution was over-engineered and didn't cover all cases.
Thanks mgorny and jcallen for the assistance.
Gentoo-Bug: 547524
Package-Manager: portage-2.2.20.1
media-sound/apulse/apulse-0.1.6-r1.ebuild | 8 +++++++-
media-sound/apulse/files/apulse | 32 +++----------------------------
2 files changed, 10 insertions(+), 30 deletions(-)
diff --git a/media-sound/apulse/apulse-0.1.6-r1.ebuild
b/media-sound/apulse/apulse-0.1.6-r1.ebuild
index 2f68179..8324b90 100644
--- a/media-sound/apulse/apulse-0.1.6-r1.ebuild
+++ b/media-sound/apulse/apulse-0.1.6-r1.ebuild
@@ -25,9 +25,15 @@ multilib_src_configure() {
local mycmakeargs="-DAPULSEPATH=${EPREFIX}/usr/$(get_libdir)/apulse"
cmake-utils_src_configure
+
+ # Ensure all relevant libdirs are added
+ DIRS=
+ _add_dir() {
DIRS="${EPREFIX}/usr/$(get_libdir)/apulse${DIRS:+:${DIRS}}"; }
+ multilib_foreach_abi _add_dir
+ sed -e "s#@@DIRS@@#${DIRS}#g" "${FILESDIR}"/apulse > "${T}"/apulse
}
multilib_src_install() {
cmake-utils_src_install
- dobin "${FILESDIR}"/apulse
+ dobin "${T}"/apulse
}
diff --git a/media-sound/apulse/files/apulse b/media-sound/apulse/files/apulse
index f419565..32633b2 100755
--- a/media-sound/apulse/files/apulse
+++ b/media-sound/apulse/files/apulse
@@ -9,32 +9,6 @@ if [ $# -lt 1 ]; then
exit
fi
-# Get the full path of our application
-app_path=$(which ${1} 2>/dev/null)
-
-# The app might not be picked up by `which`, so let's use realpath as a backup
-[ -z ${app_path} ] && app_path=$(realpath ${1})
-
-# Then make sure it's executable
-[ ! -x ${app_path} ] && echo "${app_path} is not executable!" && exit 8
-
-# Fetch the app's ABI
-app_abi=$(file -L ${app_path} | sed 's/\([^,]*\), \([^,]*\), \(.*\)/\2/')
-
-# Determine libdir based on app_abi
-# Applications that don't have a header will default to native libdir
-case $app_abi in
- Intel\ 80386)
- APULSE_ABI="32"
- ;;
- x86-64)
- APULSE_ABI="64"
- ;;
- *)
- APULSE_ABI=$(readlink /usr/lib)
- APULSE_ABI=${APULSE_ABI#lib}
- ;;
-esac
-
-# Set library path for the application so it'll use apulse
-LD_LIBRARY_PATH=/usr/lib${APULSE_ABI}/apulse${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}
exec "$@"
+# Set library path for the application so it'll use apulse. DIRS is
+# replaced by the ebuild to include the correct paths
+LD_LIBRARY_PATH=@@DIRS@@${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH} exec "$@"