From 32aa646d8474333db4fa993400381dea982eff8ca0d02878df80f4d75cbcd30f Mon Sep 17 00:00:00 2001 From: "Dr. Werner Fink" Date: Fri, 18 Nov 2011 12:04:20 +0000 Subject: [PATCH] . OBS-URL: https://build.opensuse.org/package/show/Base:System/bash?expand=0&rev=98 --- bash.changes | 6 ++++++ bash.spec | 16 +++++++++------- 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/bash.changes b/bash.changes index fba58e4..189a1d5 100644 --- a/bash.changes +++ b/bash.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Fri Nov 18 12:03:56 UTC 2011 - werner@suse.de + +- Enforce bind references to global function symbols to the + definition within libreadline + ------------------------------------------------------------------- Wed Nov 16 11:11:21 UTC 2011 - werner@suse.de diff --git a/bash.spec b/bash.spec index fa4a8eb..9067b38 100644 --- a/bash.spec +++ b/bash.spec @@ -326,15 +326,13 @@ pushd ../readline-%{rl_vers}%{extend} case "${!var}" in *${flag}*) return esac + set -o noclobber case "$flag" in -Wl,*) - set -o noclobber - echo 'int main () { return 0; }' > ldtest.c - if ${CC:-gcc} -Werror $flag -o /dev/null -xc ldtest.c > /dev/null 2>&1 ; then + if echo 'int main () { return 0; }' | \ + ${CC:-gcc} -Werror $flag -o /dev/null -xc - > /dev/null 2>&1 ; then eval $var=\${$var:+\$$var\ }$flag fi - set +o noclobber - rm -f ldtest.c ;; *) if ${CC:-gcc} -Werror $flag -S -o /dev/null -xc /dev/null > /dev/null 2>&1 ; then @@ -344,6 +342,7 @@ pushd ../readline-%{rl_vers}%{extend} eval $var=\${$var:+\$$var\ }$flag fi esac + set +o noclobber } echo 'int main () { return !(sizeof(void*) >= 8); }' | gcc -x c -o test64 - if ./test64 ; then @@ -365,7 +364,8 @@ pushd ../readline-%{rl_vers}%{extend} cflags -pipe CFLAGS cflags -Wl,--as-needed LDFLAGS cflags -Wl,-O2 LDFLAGS - cflags -Wl,--hash-size=16699 LDFLAGS + cflags -Wl,--hash-size=8599 LDFLAGS + cflags -Wl,-Bsymbolic-functions LDFLAGS cflags -Wl,-rpath,%{_ldldir}/%{bash_vers} LDFLAGS CC=gcc CC_FOR_BUILD="$CC" @@ -388,7 +388,9 @@ popd # /proc is required for correct configuration test -d /dev/fd || { echo "/proc is not mounted!" >&2; exit 1; } ln -sf ../readline-%{rl_vers} readline - export LD_LIBRARY_PATH=$PWD/../readline-%{rl_vers} + LD_LIBRARY_PATH=$PWD/../readline-%{rl_vers} + export LD_LIBRARY_PATH + LDFLAGS="${LDFLAGS/hash-size=8599/hash-size=16699}" CC="gcc -I$PWD -L$PWD/../readline-%{rl_vers}" %if %_minsh cflags -Os CFLAGS