summary refs log tree commit diff
path: root/tools
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2015-08-12 19:59:00 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2015-08-12 19:59:00 +0000
commit6f770a9de51ca5b37646bc76a5c13386b2bfd078 (patch)
treec51129b013adcf34df1c0dc4b93856a5ac68034f /tools
parentc33f8ef19fdb814169fb27c3ebac902d078c200c (diff)
downloads6-linux-utils-6f770a9de51ca5b37646bc76a5c13386b2bfd078.tar.gz
s6-linux-utils-6f770a9de51ca5b37646bc76a5c13386b2bfd078.tar.xz
s6-linux-utils-6f770a9de51ca5b37646bc76a5c13386b2bfd078.zip
Link shared libs against their -l deps, better libpath management v2.0.2.2
Diffstat (limited to 'tools')
-rwxr-xr-xtools/gen-deps.sh14
1 files changed, 10 insertions, 4 deletions
diff --git a/tools/gen-deps.sh b/tools/gen-deps.sh
index 1ca66ea..f8cf5ee 100755
--- a/tools/gen-deps.sh
+++ b/tools/gen-deps.sh
@@ -57,11 +57,17 @@ echo
 for dir in $(ls -1 src | grep -v ^include) ; do
   for file in $(ls -1 src/$dir/deps-lib) ; do
     deps=
+    libs=
     while read dep ; do
-      deps="$deps src/$dir/$dep"
+      if echo $dep | grep -q -e ^-l -e '^\${.*_LIB}' ; then
+        libs="$libs $dep"
+      else
+        deps="$deps src/$dir/$dep"
+      fi
     done < src/$dir/deps-lib/$file
-    echo "lib$file.a.xyzzy: $deps"
-    echo "lib${file}.so.xyzzy: $(echo "$deps" | sed 's/\.o/.lo/g')"
+    echo "lib${file}.a.xyzzy:$deps"
+    echo "lib${file}.so.xyzzy: private EXTRA_LIBS :=$libs"
+    echo "lib${file}.so.xyzzy:$(echo "$deps" | sed 's/\.o/.lo/g')"
   done
 
   for file in $(ls -1 src/$dir/deps-exe) ; do
@@ -71,7 +77,7 @@ for dir in $(ls -1 src | grep -v ^include) ; do
       if echo $dep | grep -q -- \\.o$ ; then
         dep="src/$dir/$dep"
       fi
-      if echo $dep | grep -q '^\${.*_LIB}' ; then
+      if echo $dep | grep -q -- '^\${.*_LIB}' ; then
         libs="$libs $dep"
       else
         deps="$deps $dep"