libtool-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH 05/12] ltmain.in: Don't encode RATHS which match default linker p


From: Richard Purdie
Subject: [PATCH 05/12] ltmain.in: Don't encode RATHS which match default linker paths
Date: Mon, 25 Oct 2021 15:33:30 +0100

We don't want to add RPATHS which match default linker search paths, they're
a waste of space. This patch filters libtools list of paths to encoode and
removes the ones we don't need.

Libtool may be passed link paths of the form "/usr/lib/../lib" so normalize
the paths before comparision.

Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
---
 build-aux/ltmain.in | 34 ++++++++++++++++++++++++++++------
 1 file changed, 28 insertions(+), 6 deletions(-)

diff --git a/build-aux/ltmain.in b/build-aux/ltmain.in
index 96238350..6fb58ed2 100644
--- a/build-aux/ltmain.in
+++ b/build-aux/ltmain.in
@@ -7672,8 +7672,16 @@ EOF
                  esac
                fi
              else
-               eval flag=\"$hardcode_libdir_flag_spec\"
-               func_append dep_rpath " $flag"
+                # We only want to hardcode in an rpath if it isn't in the
+                # default dlsearch path.
+                func_normal_abspath "$libdir"
+                libdir_norm=$func_normal_abspath_result
+               case " $sys_lib_dlsearch_path " in
+               *" $libdir_norm "*) ;;
+               *) eval flag=\"$hardcode_libdir_flag_spec\"
+                   func_append dep_rpath " $flag"
+                   ;;
+               esac
              fi
            elif test -n "$runpath_var"; then
              case "$perm_rpath " in
@@ -8406,8 +8414,16 @@ EOF
              esac
            fi
          else
-           eval flag=\"$hardcode_libdir_flag_spec\"
-           func_append rpath " $flag"
+            # We only want to hardcode in an rpath if it isn't in the
+            # default dlsearch path.
+            func_normal_abspath "$libdir"
+            libdir_norm=$func_normal_abspath_result
+           case " $sys_lib_dlsearch_path " in
+           *" $libdir_norm "*) ;;
+           *) eval flag=\"$hardcode_libdir_flag_spec\"
+               rpath+=" $flag"
+               ;;
+           esac
          fi
        elif test -n "$runpath_var"; then
          case "$perm_rpath " in
@@ -8461,8 +8477,14 @@ EOF
              esac
            fi
          else
-           eval flag=\"$hardcode_libdir_flag_spec\"
-           func_append rpath " $flag"
+            # We only want to hardcode in an rpath if it isn't in the
+            # default dlsearch path.
+           case " $sys_lib_dlsearch_path " in
+           *" $libdir "*) ;;
+           *) eval flag=\"$hardcode_libdir_flag_spec\"
+               func_append rpath " $flag"
+               ;;
+           esac    
          fi
        elif test -n "$runpath_var"; then
          case "$finalize_perm_rpath " in
-- 
2.25.1




reply via email to

[Prev in Thread] Current Thread [Next in Thread]