2008-04-11 14:55:43 -04:00
|
|
|
$OpenBSD: patch-ltmain_in,v 1.27 2008/04/11 18:55:43 steven Exp $
|
|
|
|
--- ltmain.in.orig Fri Feb 1 11:12:00 2008
|
|
|
|
+++ ltmain.in Sat Feb 2 18:45:38 2008
|
|
|
|
@@ -1651,6 +1651,7 @@ EOF
|
2007-06-04 15:00:16 -04:00
|
|
|
compiler_flags="$compiler_flags $arg"
|
|
|
|
compile_command="$compile_command $arg"
|
|
|
|
finalize_command="$finalize_command $arg"
|
|
|
|
+ deplibs="$deplibs $arg"
|
|
|
|
continue
|
|
|
|
;;
|
|
|
|
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -2126,6 +2127,17 @@ EOF
|
2004-12-18 18:30:36 -05:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
for pass in $passes; do
|
|
|
|
+ # The preopen pass in lib mode reverses $deplibs; put it back here
|
|
|
|
+ # so that -L comes before libs that need it for instance...
|
|
|
|
+ if test "$linkmode,$pass" = "lib,link"; then
|
|
|
|
+ ## FIXME: Find the place where the list is rebuilt in the wrong
|
|
|
|
+ ## order, and fix it there properly
|
|
|
|
+ tmp_deplibs=
|
|
|
|
+ for deplib in $deplibs; do
|
|
|
|
+ tmp_deplibs="$deplib $tmp_deplibs"
|
|
|
|
+ done
|
|
|
|
+ deplibs="$tmp_deplibs"
|
|
|
|
+ fi
|
|
|
|
if test "$linkmode,$pass" = "lib,link" ||
|
|
|
|
test "$linkmode,$pass" = "prog,scan"; then
|
|
|
|
libs="$deplibs"
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -2153,6 +2165,7 @@ EOF
|
2007-06-04 15:00:16 -04:00
|
|
|
finalize_deplibs="$deplib $finalize_deplibs"
|
|
|
|
else
|
|
|
|
compiler_flags="$compiler_flags $deplib"
|
|
|
|
+ test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
|
|
|
|
fi
|
|
|
|
continue
|
|
|
|
;;
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -2392,20 +2405,20 @@ EOF
|
2004-12-18 18:30:36 -05:00
|
|
|
# It is a libtool convenience library, so add in its objects.
|
|
|
|
convenience="$convenience $ladir/$objdir/$old_library"
|
|
|
|
old_convenience="$old_convenience $ladir/$objdir/$old_library"
|
|
|
|
- tmp_libs=
|
|
|
|
- for deplib in $dependency_libs; do
|
|
|
|
- deplibs="$deplib $deplibs"
|
|
|
|
- if test "X$duplicate_deps" = "Xyes" ; then
|
|
|
|
- case "$tmp_libs " in
|
|
|
|
- *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
|
|
|
|
- esac
|
|
|
|
- fi
|
|
|
|
- tmp_libs="$tmp_libs $deplib"
|
|
|
|
- done
|
|
|
|
elif test "$linkmode" != prog && test "$linkmode" != lib; then
|
|
|
|
$echo "$modename: \`$lib' is not a convenience library" 1>&2
|
|
|
|
exit $EXIT_FAILURE
|
|
|
|
fi
|
|
|
|
+ tmp_libs=
|
|
|
|
+ for deplib in $dependency_libs; do
|
|
|
|
+ deplibs="$deplib $deplibs"
|
|
|
|
+ if test "X$duplicate_deps" = "Xyes" ; then
|
|
|
|
+ case "$tmp_libs " in
|
|
|
|
+ *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
|
|
|
|
+ esac
|
|
|
|
+ fi
|
|
|
|
+ tmp_libs="$tmp_libs $deplib"
|
|
|
|
+ done
|
|
|
|
continue
|
|
|
|
fi # $pass = conv
|
|
|
|
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -2602,7 +2615,7 @@ EOF
|
2006-01-07 04:58:39 -05:00
|
|
|
{ test "$use_static_libs" = no || test -z "$old_library"; }; then
|
2005-11-01 21:47:09 -05:00
|
|
|
if test "$installed" = no; then
|
|
|
|
notinst_deplibs="$notinst_deplibs $lib"
|
2005-12-22 06:36:00 -05:00
|
|
|
- need_relink=yes
|
|
|
|
+ test -z "$DESTDIR" && need_relink=yes
|
|
|
|
fi
|
|
|
|
# This is a shared library
|
|
|
|
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -2801,7 +2814,7 @@ EOF
|
2004-08-05 14:04:55 -04:00
|
|
|
add_dir=
|
|
|
|
add=
|
|
|
|
# Finalize command for both is simple: just hardcode it.
|
|
|
|
- if test "$hardcode_direct" = yes; then
|
|
|
|
+ if test "$hardcode_direct" = yes && test -f $libdir/$linklib; then
|
|
|
|
add="$libdir/$linklib"
|
|
|
|
elif test "$hardcode_minus_L" = yes; then
|
|
|
|
add_dir="-L$libdir"
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -3431,6 +3444,20 @@ EOF
|
2006-10-21 09:31:51 -04:00
|
|
|
major=
|
|
|
|
versuffix=
|
|
|
|
verstring=""
|
|
|
|
+ else
|
|
|
|
+ # XXX
|
|
|
|
+ tmp=`echo $libname|sed -e 's,+,_,g' -e 's,-,_,g' -e 's,\.,_,g'`
|
|
|
|
+ eval tmp2=\$${tmp}_ltversion
|
|
|
|
+ if ! test -z "${SHARED_LIBS_LOG}"; then
|
2006-10-21 12:15:28 -04:00
|
|
|
+ if ! test -f ${SHARED_LIBS_LOG}; then
|
2006-10-23 09:55:07 -04:00
|
|
|
+ echo "# SHARED_LIBS+= <libname> <obsd version> # <orig version>" >${SHARED_LIBS_LOG}
|
2006-10-21 09:31:51 -04:00
|
|
|
+ fi
|
2006-10-21 09:51:15 -04:00
|
|
|
+ tmp4=`echo $libname|sed -e 's/^lib//'`
|
2006-10-23 09:55:07 -04:00
|
|
|
+ printf "SHARED_LIBS +=\t%-20s %-8s # %s\n" "$tmp4" "$tmp2" "$versuffix" >>${SHARED_LIBS_LOG}
|
2006-10-21 09:31:51 -04:00
|
|
|
+ fi
|
|
|
|
+ if test -n "$versuffix" && test -n "$tmp2"; then
|
|
|
|
+ versuffix=".$tmp2"
|
|
|
|
+ fi
|
2006-01-05 14:36:16 -05:00
|
|
|
fi
|
|
|
|
|
2006-10-21 09:31:51 -04:00
|
|
|
# Check to see if the archive will have undefined symbols.
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -5886,6 +5913,10 @@ relink_command=\"$relink_command\""
|
2007-04-14 11:58:03 -04:00
|
|
|
esac
|
|
|
|
install_prog="$install_prog $arg"
|
|
|
|
done
|
|
|
|
+ case " $install_prog " in
|
|
|
|
+ *[\\\ /]cp\ *) extra_mode=;;
|
|
|
|
+ *) extra_mode='-m 644';;
|
|
|
|
+ esac
|
|
|
|
|
|
|
|
if test -z "$install_prog"; then
|
|
|
|
$echo "$modename: you must specify an install program" 1>&2
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -6040,8 +6071,8 @@ relink_command=\"$relink_command\""
|
2007-04-14 11:58:03 -04:00
|
|
|
test -n "$relink_command" && srcname="$realname"T
|
|
|
|
|
|
|
|
# Install the shared library and build the symlinks.
|
|
|
|
- $show "$install_prog $dir/$srcname $destdir/$realname"
|
|
|
|
- $run eval "$install_prog $dir/$srcname $destdir/$realname" || exit $?
|
|
|
|
+ $show "$install_prog $extra_mode $dir/$srcname $destdir/$realname"
|
|
|
|
+ $run eval "$install_prog $extra_mode $dir/$srcname $destdir/$realname" || exit $?
|
|
|
|
if test -n "$stripme" && test -n "$striplib"; then
|
|
|
|
$show "$striplib $destdir/$realname"
|
|
|
|
$run eval "$striplib $destdir/$realname" || exit $?
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -6086,8 +6117,8 @@ relink_command=\"$relink_command\""
|
2007-04-14 11:58:03 -04:00
|
|
|
# Install the pseudo-library for information purposes.
|
|
|
|
name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
|
|
|
|
instname="$dir/$name"i
|
|
|
|
- $show "$install_prog $instname $destdir/$name"
|
|
|
|
- $run eval "$install_prog $instname $destdir/$name" || exit $?
|
|
|
|
+ $show "$install_prog $extra_mode $instname $destdir/$name"
|
|
|
|
+ $run eval "$install_prog $extra_mode $instname $destdir/$name" || exit $?
|
|
|
|
|
|
|
|
# Maybe install the static library, too.
|
|
|
|
test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library"
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -6122,8 +6153,8 @@ relink_command=\"$relink_command\""
|
2007-04-14 11:58:03 -04:00
|
|
|
|
|
|
|
# Install the libtool object if requested.
|
|
|
|
if test -n "$destfile"; then
|
|
|
|
- $show "$install_prog $file $destfile"
|
|
|
|
- $run eval "$install_prog $file $destfile" || exit $?
|
|
|
|
+ $show "$install_prog $extra_mode $file $destfile"
|
|
|
|
+ $run eval "$install_prog $extra_mode $file $destfile" || exit $?
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Install the old object if enabled.
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -6131,8 +6162,8 @@ relink_command=\"$relink_command\""
|
2007-04-14 11:58:03 -04:00
|
|
|
# Deduce the name of the old-style object file.
|
|
|
|
staticobj=`$echo "X$file" | $Xsed -e "$lo2o"`
|
|
|
|
|
|
|
|
- $show "$install_prog $staticobj $staticdest"
|
|
|
|
- $run eval "$install_prog \$staticobj \$staticdest" || exit $?
|
|
|
|
+ $show "$install_prog $extra_mode $staticobj $staticdest"
|
|
|
|
+ $run eval "$install_prog $extra_mode \$staticobj \$staticdest" || exit $?
|
|
|
|
fi
|
|
|
|
exit $EXIT_SUCCESS
|
|
|
|
;;
|
2008-04-11 14:55:43 -04:00
|
|
|
@@ -6346,40 +6377,6 @@ relink_command=\"$relink_command\""
|
2004-07-11 15:22:05 -04:00
|
|
|
# Exit here if they wanted silent mode.
|
|
|
|
test "$show" = : && exit $EXIT_SUCCESS
|
|
|
|
|
2006-01-07 04:58:39 -05:00
|
|
|
- $echo "X----------------------------------------------------------------------" | $Xsed
|
2004-07-11 15:22:05 -04:00
|
|
|
- $echo "Libraries have been installed in:"
|
|
|
|
- for libdir in $libdirs; do
|
|
|
|
- $echo " $libdir"
|
|
|
|
- done
|
|
|
|
- $echo
|
|
|
|
- $echo "If you ever happen to want to link against installed libraries"
|
|
|
|
- $echo "in a given directory, LIBDIR, you must either use libtool, and"
|
|
|
|
- $echo "specify the full pathname of the library, or use the \`-LLIBDIR'"
|
|
|
|
- $echo "flag during linking and do at least one of the following:"
|
|
|
|
- if test -n "$shlibpath_var"; then
|
|
|
|
- $echo " - add LIBDIR to the \`$shlibpath_var' environment variable"
|
|
|
|
- $echo " during execution"
|
|
|
|
- fi
|
|
|
|
- if test -n "$runpath_var"; then
|
|
|
|
- $echo " - add LIBDIR to the \`$runpath_var' environment variable"
|
|
|
|
- $echo " during linking"
|
|
|
|
- fi
|
|
|
|
- if test -n "$hardcode_libdir_flag_spec"; then
|
|
|
|
- libdir=LIBDIR
|
|
|
|
- eval flag=\"$hardcode_libdir_flag_spec\"
|
|
|
|
-
|
|
|
|
- $echo " - use the \`$flag' linker flag"
|
|
|
|
- fi
|
|
|
|
- if test -n "$admincmds"; then
|
|
|
|
- $echo " - have your system administrator run these commands:$admincmds"
|
|
|
|
- fi
|
|
|
|
- if test -f /etc/ld.so.conf; then
|
|
|
|
- $echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'"
|
|
|
|
- fi
|
|
|
|
- $echo
|
|
|
|
- $echo "See any operating system documentation about shared libraries for"
|
|
|
|
- $echo "more information, such as the ld(1) and ld.so(8) manual pages."
|
2006-01-07 04:58:39 -05:00
|
|
|
- $echo "X----------------------------------------------------------------------" | $Xsed
|
2004-07-11 15:22:05 -04:00
|
|
|
exit $EXIT_SUCCESS
|
|
|
|
;;
|
|
|
|
|