5022 lines
153 KiB
Diff
5022 lines
153 KiB
Diff
diff -uNr sundials-2.3.0-orig/config/ltmain.sh sundials-2.3.0/config/ltmain.sh
|
|
--- sundials-2.3.0-orig/config/ltmain.sh 2006-11-07 10:18:35.000000000 +1100
|
|
+++ sundials-2.3.0/config/ltmain.sh 2007-05-02 09:27:08.000000000 +1000
|
|
@@ -1,7 +1,7 @@
|
|
# ltmain.sh - Provide generalized library-building support services.
|
|
# NOTE: Changing this file will not affect anything until you rerun configure.
|
|
#
|
|
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001
|
|
+# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004
|
|
# Free Software Foundation, Inc.
|
|
# Originally by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
|
|
#
|
|
@@ -24,6 +24,32 @@
|
|
# configuration script generated by Autoconf, you may include it under
|
|
# the same distribution terms that you use for the rest of that program.
|
|
|
|
+basename="s,^.*/,,g"
|
|
+
|
|
+# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
|
|
+# is ksh but when the shell is invoked as "sh" and the current value of
|
|
+# the _XPG environment variable is not equal to 1 (one), the special
|
|
+# positional parameter $0, within a function call, is the name of the
|
|
+# function.
|
|
+progpath="$0"
|
|
+
|
|
+# RH: define SED for historic ltconfig's generated by Libtool 1.3
|
|
+[ -z "$SED" ] && SED=sed
|
|
+
|
|
+# The name of this program:
|
|
+progname=`echo "$progpath" | $SED $basename`
|
|
+modename="$progname"
|
|
+
|
|
+# Global variables:
|
|
+EXIT_SUCCESS=0
|
|
+EXIT_FAILURE=1
|
|
+
|
|
+PROGRAM=ltmain.sh
|
|
+PACKAGE=libtool
|
|
+VERSION=1.5.6
|
|
+TIMESTAMP=" (1.1220.2.95 2004/04/11 05:50:42)"
|
|
+
|
|
+
|
|
# Check that we have a working $echo.
|
|
if test "X$1" = X--no-reexec; then
|
|
# Discard the --no-reexec flag, and continue.
|
|
@@ -36,7 +62,7 @@
|
|
:
|
|
else
|
|
# Restart under the correct shell, and then maybe $echo will work.
|
|
- exec $SHELL "$0" --no-reexec ${1+"$@"}
|
|
+ exec $SHELL "$progpath" --no-reexec ${1+"$@"}
|
|
fi
|
|
|
|
if test "X$1" = X--fallback-echo; then
|
|
@@ -45,19 +71,9 @@
|
|
cat <<EOF
|
|
$*
|
|
EOF
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
fi
|
|
|
|
-# The name of this program.
|
|
-progname=`$echo "$0" | ${SED} 's%^.*/%%'`
|
|
-modename="$progname"
|
|
-
|
|
-# Constants.
|
|
-PROGRAM=ltmain.sh
|
|
-PACKAGE=libtool
|
|
-VERSION=1.4.3
|
|
-TIMESTAMP=" (1.922.2.110 2002/10/23 01:39:54)"
|
|
-
|
|
default_mode=
|
|
help="Try \`$progname --help' for more information."
|
|
magic="%%%MAGIC variable%%%"
|
|
@@ -69,17 +85,17 @@
|
|
# metacharacters that are still active within double-quoted strings.
|
|
Xsed="${SED}"' -e 1s/^X//'
|
|
sed_quote_subst='s/\([\\`\\"$\\\\]\)/\\\1/g'
|
|
-# test EBCDIC or ASCII
|
|
-case `echo A|od -x` in
|
|
- *[Cc]1*) # EBCDIC based system
|
|
- SP2NL="tr '\100' '\n'"
|
|
- NL2SP="tr '\r\n' '\100\100'"
|
|
- ;;
|
|
- *) # Assume ASCII based system
|
|
- SP2NL="tr '\040' '\012'"
|
|
- NL2SP="tr '\015\012' '\040\040'"
|
|
- ;;
|
|
-esac
|
|
+# test EBCDIC or ASCII
|
|
+case `echo A|tr A '\301'` in
|
|
+ A) # EBCDIC based system
|
|
+ SP2NL="tr '\100' '\n'"
|
|
+ NL2SP="tr '\r\n' '\100\100'"
|
|
+ ;;
|
|
+ *) # Assume ASCII based system
|
|
+ SP2NL="tr '\040' '\012'"
|
|
+ NL2SP="tr '\015\012' '\040\040'"
|
|
+ ;;
|
|
+esac
|
|
|
|
# NLS nuisances.
|
|
# Only set LANG and LC_ALL to C if already set.
|
|
@@ -94,12 +110,13 @@
|
|
fi
|
|
|
|
# Make sure IFS has a sensible default
|
|
-: ${IFS=" "}
|
|
+: ${IFS="
|
|
+"}
|
|
|
|
if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
|
|
- echo "$modename: not configured to build any kind of library" 1>&2
|
|
- echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2
|
|
- exit 1
|
|
+ $echo "$modename: not configured to build any kind of library" 1>&2
|
|
+ $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Global variables.
|
|
@@ -114,8 +131,121 @@
|
|
lo2o="s/\\.lo\$/.${objext}/"
|
|
o2lo="s/\\.${objext}\$/.lo/"
|
|
|
|
+#####################################
|
|
+# Shell function definitions:
|
|
+# This seems to be the best place for them
|
|
+
|
|
+# func_win32_libid arg
|
|
+# return the library type of file 'arg'
|
|
+#
|
|
+# Need a lot of goo to handle *both* DLLs and import libs
|
|
+# Has to be a shell function in order to 'eat' the argument
|
|
+# that is supplied when $file_magic_command is called.
|
|
+func_win32_libid () {
|
|
+ win32_libid_type="unknown"
|
|
+ win32_fileres=`file -L $1 2>/dev/null`
|
|
+ case $win32_fileres in
|
|
+ *ar\ archive\ import\ library*) # definitely import
|
|
+ win32_libid_type="x86 archive import"
|
|
+ ;;
|
|
+ *ar\ archive*) # could be an import, or static
|
|
+ if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | \
|
|
+ $EGREP -e 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then
|
|
+ win32_nmres=`eval $NM -f posix -A $1 | \
|
|
+ sed -n -e '1,100{/ I /{x;/import/!{s/^/import/;h;p;};x;};}'`
|
|
+ if test "X$win32_nmres" = "Ximport" ; then
|
|
+ win32_libid_type="x86 archive import"
|
|
+ else
|
|
+ win32_libid_type="x86 archive static"
|
|
+ fi
|
|
+ fi
|
|
+ ;;
|
|
+ *DLL*)
|
|
+ win32_libid_type="x86 DLL"
|
|
+ ;;
|
|
+ *executable*) # but shell scripts are "executable" too...
|
|
+ case $win32_fileres in
|
|
+ *MS\ Windows\ PE\ Intel*)
|
|
+ win32_libid_type="x86 DLL"
|
|
+ ;;
|
|
+ esac
|
|
+ ;;
|
|
+ esac
|
|
+ $echo $win32_libid_type
|
|
+}
|
|
+
|
|
+
|
|
+# func_infer_tag arg
|
|
+# Infer tagged configuration to use if any are available and
|
|
+# if one wasn't chosen via the "--tag" command line option.
|
|
+# Only attempt this if the compiler in the base compile
|
|
+# command doesn't match the default compiler.
|
|
+# arg is usually of the form 'gcc ...'
|
|
+func_infer_tag () {
|
|
+ if test -n "$available_tags" && test -z "$tagname"; then
|
|
+ CC_quoted=
|
|
+ for arg in $CC; do
|
|
+ case $arg in
|
|
+ *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
|
|
+ arg="\"$arg\""
|
|
+ ;;
|
|
+ esac
|
|
+ CC_quoted="$CC_quoted $arg"
|
|
+ done
|
|
+ case $@ in
|
|
+ # Blanks in the command may have been stripped by the calling shell,
|
|
+ # but not from the CC environment variable when configure was run.
|
|
+ " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) ;;
|
|
+ # Blanks at the start of $base_compile will cause this to fail
|
|
+ # if we don't check for them as well.
|
|
+ *)
|
|
+ for z in $available_tags; do
|
|
+ if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then
|
|
+ # Evaluate the configuration.
|
|
+ eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
|
|
+ CC_quoted=
|
|
+ for arg in $CC; do
|
|
+ # Double-quote args containing other shell metacharacters.
|
|
+ case $arg in
|
|
+ *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
|
|
+ arg="\"$arg\""
|
|
+ ;;
|
|
+ esac
|
|
+ CC_quoted="$CC_quoted $arg"
|
|
+ done
|
|
+ case "$@ " in
|
|
+ " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*)
|
|
+ # The compiler in the base compile command matches
|
|
+ # the one in the tagged configuration.
|
|
+ # Assume this is the tagged configuration we want.
|
|
+ tagname=$z
|
|
+ break
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
+ done
|
|
+ # If $tagname still isn't set, then no tagged configuration
|
|
+ # was found and let the user know that the "--tag" command
|
|
+ # line option must be used.
|
|
+ if test -z "$tagname"; then
|
|
+ $echo "$modename: unable to infer tagged configuration"
|
|
+ $echo "$modename: specify a tag with \`--tag'" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+# else
|
|
+# $echo "$modename: using $tagname tagged configuration"
|
|
+ fi
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
+}
|
|
+# End of Shell function definitions
|
|
+#####################################
|
|
+
|
|
+# Darwin sucks
|
|
+eval std_shrext=\"$shrext_cmds\"
|
|
+
|
|
# Parse our command line options once, thoroughly.
|
|
-while test $# -gt 0
|
|
+while test "$#" -gt 0
|
|
do
|
|
arg="$1"
|
|
shift
|
|
@@ -131,6 +261,34 @@
|
|
execute_dlfiles)
|
|
execute_dlfiles="$execute_dlfiles $arg"
|
|
;;
|
|
+ tag)
|
|
+ tagname="$arg"
|
|
+ preserve_args="${preserve_args}=$arg"
|
|
+
|
|
+ # Check whether tagname contains only valid characters
|
|
+ case $tagname in
|
|
+ *[!-_A-Za-z0-9,/]*)
|
|
+ $echo "$progname: invalid tag name: $tagname" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+ ;;
|
|
+ esac
|
|
+
|
|
+ case $tagname in
|
|
+ CC)
|
|
+ # Don't test for the "default" C tag, as we know, it's there, but
|
|
+ # not specially marked.
|
|
+ ;;
|
|
+ *)
|
|
+ if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "$progpath" > /dev/null; then
|
|
+ taglist="$taglist $tagname"
|
|
+ # Evaluate the configuration.
|
|
+ eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$tagname'$/,/^# ### END LIBTOOL TAG CONFIG: '$tagname'$/p' < $progpath`"
|
|
+ else
|
|
+ $echo "$progname: ignoring unknown tag $tagname" 1>&2
|
|
+ fi
|
|
+ ;;
|
|
+ esac
|
|
+ ;;
|
|
*)
|
|
eval "$prev=\$arg"
|
|
;;
|
|
@@ -148,18 +306,27 @@
|
|
;;
|
|
|
|
--version)
|
|
- echo "$PROGRAM (GNU $PACKAGE) $VERSION$TIMESTAMP"
|
|
- exit 0
|
|
+ $echo "$PROGRAM (GNU $PACKAGE) $VERSION$TIMESTAMP"
|
|
+ $echo
|
|
+ $echo "Copyright (C) 2003 Free Software Foundation, Inc."
|
|
+ $echo "This is free software; see the source for copying conditions. There is NO"
|
|
+ $echo "warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
--config)
|
|
- ${SED} -e '1,/^# ### BEGIN LIBTOOL CONFIG/d' -e '/^# ### END LIBTOOL CONFIG/,$d' $0
|
|
- exit 0
|
|
+ ${SED} -e '1,/^# ### BEGIN LIBTOOL CONFIG/d' -e '/^# ### END LIBTOOL CONFIG/,$d' $progpath
|
|
+ # Now print the configurations for the tags.
|
|
+ for tagname in $taglist; do
|
|
+ ${SED} -n -e "/^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$/,/^# ### END LIBTOOL TAG CONFIG: $tagname$/p" < "$progpath"
|
|
+ done
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
--debug)
|
|
- echo "$progname: enabling shell trace mode"
|
|
+ $echo "$progname: enabling shell trace mode"
|
|
set -x
|
|
+ preserve_args="$preserve_args $arg"
|
|
;;
|
|
|
|
--dry-run | -n)
|
|
@@ -167,18 +334,18 @@
|
|
;;
|
|
|
|
--features)
|
|
- echo "host: $host"
|
|
+ $echo "host: $host"
|
|
if test "$build_libtool_libs" = yes; then
|
|
- echo "enable shared libraries"
|
|
+ $echo "enable shared libraries"
|
|
else
|
|
- echo "disable shared libraries"
|
|
+ $echo "disable shared libraries"
|
|
fi
|
|
if test "$build_old_libs" = yes; then
|
|
- echo "enable static libraries"
|
|
+ $echo "enable static libraries"
|
|
else
|
|
- echo "disable static libraries"
|
|
+ $echo "disable static libraries"
|
|
fi
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
--finish) mode="finish" ;;
|
|
@@ -190,6 +357,15 @@
|
|
|
|
--quiet | --silent)
|
|
show=:
|
|
+ preserve_args="$preserve_args $arg"
|
|
+ ;;
|
|
+
|
|
+ --tag) prevopt="--tag" prev=tag ;;
|
|
+ --tag=*)
|
|
+ set tag "$optarg" ${1+"$@"}
|
|
+ shift
|
|
+ prev=tag
|
|
+ preserve_args="$preserve_args --tag"
|
|
;;
|
|
|
|
-dlopen)
|
|
@@ -200,7 +376,7 @@
|
|
-*)
|
|
$echo "$modename: unrecognized option \`$arg'" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
|
|
*)
|
|
@@ -213,7 +389,7 @@
|
|
if test -n "$prevopt"; then
|
|
$echo "$modename: option \`$prevopt' requires an argument" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# If this variable is set in any of the actions, the command in it
|
|
@@ -225,8 +401,10 @@
|
|
|
|
# Infer the operation mode.
|
|
if test -z "$mode"; then
|
|
+ $echo "*** Warning: inferring the mode of operation is deprecated." 1>&2
|
|
+ $echo "*** Future versions of Libtool will require -mode=MODE be specified." 1>&2
|
|
case $nonopt in
|
|
- *cc | *++ | gcc* | *-gcc* | xlc*)
|
|
+ *cc | cc* | *++ | gcc* | *-gcc* | g++* | xlc*)
|
|
mode=link
|
|
for arg
|
|
do
|
|
@@ -267,7 +445,7 @@
|
|
if test -n "$execute_dlfiles" && test "$mode" != execute; then
|
|
$echo "$modename: unrecognized option \`-dlopen'" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Change the help message to a mode-specific one.
|
|
@@ -281,158 +459,124 @@
|
|
modename="$modename: compile"
|
|
# Get the compilation command and the source file.
|
|
base_compile=
|
|
- prev=
|
|
- lastarg=
|
|
- srcfile="$nonopt"
|
|
+ srcfile="$nonopt" # always keep a non-empty value in "srcfile"
|
|
+ suppress_opt=yes
|
|
suppress_output=
|
|
+ arg_mode=normal
|
|
+ libobj=
|
|
+ later=
|
|
|
|
- user_target=no
|
|
for arg
|
|
do
|
|
- case $prev in
|
|
- "") ;;
|
|
- xcompiler)
|
|
- # Aesthetically quote the previous argument.
|
|
- prev=
|
|
- lastarg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
|
|
-
|
|
- case $arg in
|
|
- # Double-quote args containing other shell metacharacters.
|
|
- # Many Bourne shells cannot handle close brackets correctly
|
|
- # in scan sets, so we specify it separately.
|
|
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
|
|
- arg="\"$arg\""
|
|
- ;;
|
|
- esac
|
|
-
|
|
- # Add the previous argument to base_compile.
|
|
- if test -z "$base_compile"; then
|
|
- base_compile="$lastarg"
|
|
- else
|
|
- base_compile="$base_compile $lastarg"
|
|
- fi
|
|
- continue
|
|
- ;;
|
|
- esac
|
|
-
|
|
- # Accept any command-line options.
|
|
- case $arg in
|
|
- -o)
|
|
- if test "$user_target" != "no"; then
|
|
- $echo "$modename: you cannot specify \`-o' more than once" 1>&2
|
|
- exit 1
|
|
- fi
|
|
- user_target=next
|
|
+ case "$arg_mode" in
|
|
+ arg )
|
|
+ # do not "continue". Instead, add this to base_compile
|
|
+ lastarg="$arg"
|
|
+ arg_mode=normal
|
|
;;
|
|
|
|
- -static)
|
|
- build_old_libs=yes
|
|
+ target )
|
|
+ libobj="$arg"
|
|
+ arg_mode=normal
|
|
continue
|
|
;;
|
|
|
|
- -prefer-pic)
|
|
- pic_mode=yes
|
|
- continue
|
|
- ;;
|
|
+ normal )
|
|
+ # Accept any command-line options.
|
|
+ case $arg in
|
|
+ -o)
|
|
+ if test -n "$libobj" ; then
|
|
+ $echo "$modename: you cannot specify \`-o' more than once" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+ fi
|
|
+ arg_mode=target
|
|
+ continue
|
|
+ ;;
|
|
|
|
- -prefer-non-pic)
|
|
- pic_mode=no
|
|
- continue
|
|
- ;;
|
|
+ -static | -prefer-pic | -prefer-non-pic)
|
|
+ later="$later $arg"
|
|
+ continue
|
|
+ ;;
|
|
|
|
- -Xcompiler)
|
|
- prev=xcompiler
|
|
- continue
|
|
- ;;
|
|
+ -no-suppress)
|
|
+ suppress_opt=no
|
|
+ continue
|
|
+ ;;
|
|
|
|
- -Wc,*)
|
|
- args=`$echo "X$arg" | $Xsed -e "s/^-Wc,//"`
|
|
- lastarg=
|
|
- save_ifs="$IFS"; IFS=','
|
|
- for arg in $args; do
|
|
- IFS="$save_ifs"
|
|
+ -Xcompiler)
|
|
+ arg_mode=arg # the next one goes into the "base_compile" arg list
|
|
+ continue # The current "srcfile" will either be retained or
|
|
+ ;; # replaced later. I would guess that would be a bug.
|
|
+
|
|
+ -Wc,*)
|
|
+ args=`$echo "X$arg" | $Xsed -e "s/^-Wc,//"`
|
|
+ lastarg=
|
|
+ save_ifs="$IFS"; IFS=','
|
|
+ for arg in $args; do
|
|
+ IFS="$save_ifs"
|
|
|
|
- # Double-quote args containing other shell metacharacters.
|
|
- # Many Bourne shells cannot handle close brackets correctly
|
|
- # in scan sets, so we specify it separately.
|
|
- case $arg in
|
|
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
|
|
- arg="\"$arg\""
|
|
- ;;
|
|
- esac
|
|
- lastarg="$lastarg $arg"
|
|
- done
|
|
- IFS="$save_ifs"
|
|
- lastarg=`$echo "X$lastarg" | $Xsed -e "s/^ //"`
|
|
+ # Double-quote args containing other shell metacharacters.
|
|
+ # Many Bourne shells cannot handle close brackets correctly
|
|
+ # in scan sets, so we specify it separately.
|
|
+ case $arg in
|
|
+ *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
|
|
+ arg="\"$arg\""
|
|
+ ;;
|
|
+ esac
|
|
+ lastarg="$lastarg $arg"
|
|
+ done
|
|
+ IFS="$save_ifs"
|
|
+ lastarg=`$echo "X$lastarg" | $Xsed -e "s/^ //"`
|
|
|
|
- # Add the arguments to base_compile.
|
|
- if test -z "$base_compile"; then
|
|
- base_compile="$lastarg"
|
|
- else
|
|
+ # Add the arguments to base_compile.
|
|
base_compile="$base_compile $lastarg"
|
|
- fi
|
|
- continue
|
|
- ;;
|
|
- esac
|
|
+ continue
|
|
+ ;;
|
|
|
|
- case $user_target in
|
|
- next)
|
|
- # The next one is the -o target name
|
|
- user_target=yes
|
|
- continue
|
|
- ;;
|
|
- yes)
|
|
- # We got the output file
|
|
- user_target=set
|
|
- libobj="$arg"
|
|
- continue
|
|
+ * )
|
|
+ # Accept the current argument as the source file.
|
|
+ # The previous "srcfile" becomes the current argument.
|
|
+ #
|
|
+ lastarg="$srcfile"
|
|
+ srcfile="$arg"
|
|
+ ;;
|
|
+ esac # case $arg
|
|
;;
|
|
- esac
|
|
-
|
|
- # Accept the current argument as the source file.
|
|
- lastarg="$srcfile"
|
|
- srcfile="$arg"
|
|
+ esac # case $arg_mode
|
|
|
|
# Aesthetically quote the previous argument.
|
|
-
|
|
- # Backslashify any backslashes, double quotes, and dollar signs.
|
|
- # These are the only characters that are still specially
|
|
- # interpreted inside of double-quoted scrings.
|
|
lastarg=`$echo "X$lastarg" | $Xsed -e "$sed_quote_subst"`
|
|
|
|
+ case $lastarg in
|
|
# Double-quote args containing other shell metacharacters.
|
|
# Many Bourne shells cannot handle close brackets correctly
|
|
# in scan sets, so we specify it separately.
|
|
- case $lastarg in
|
|
*[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
|
|
lastarg="\"$lastarg\""
|
|
;;
|
|
esac
|
|
|
|
- # Add the previous argument to base_compile.
|
|
- if test -z "$base_compile"; then
|
|
- base_compile="$lastarg"
|
|
- else
|
|
- base_compile="$base_compile $lastarg"
|
|
- fi
|
|
- done
|
|
+ base_compile="$base_compile $lastarg"
|
|
+ done # for arg
|
|
|
|
- case $user_target in
|
|
- set)
|
|
+ case $arg_mode in
|
|
+ arg)
|
|
+ $echo "$modename: you must specify an argument for -Xcompile"
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
- no)
|
|
- # Get the name of the library object.
|
|
- libobj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%'`
|
|
+ target)
|
|
+ $echo "$modename: you must specify a target with \`-o'" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
*)
|
|
- $echo "$modename: you must specify a target with \`-o'" 1>&2
|
|
- exit 1
|
|
+ # Get the name of the library object.
|
|
+ [ -z "$libobj" ] && libobj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%'`
|
|
;;
|
|
esac
|
|
|
|
# Recognize several different file suffixes.
|
|
# If the user specifies -o file.o, it is replaced with file.lo
|
|
- xform='[cCFSfmso]'
|
|
+ xform='[cCFSifmso]'
|
|
case $libobj in
|
|
*.ada) xform=ada ;;
|
|
*.adb) xform=adb ;;
|
|
@@ -440,10 +584,13 @@
|
|
*.asm) xform=asm ;;
|
|
*.c++) xform=c++ ;;
|
|
*.cc) xform=cc ;;
|
|
+ *.ii) xform=ii ;;
|
|
+ *.class) xform=class ;;
|
|
*.cpp) xform=cpp ;;
|
|
*.cxx) xform=cxx ;;
|
|
*.f90) xform=f90 ;;
|
|
*.for) xform=for ;;
|
|
+ *.java) xform=java ;;
|
|
esac
|
|
|
|
libobj=`$echo "X$libobj" | $Xsed -e "s/\.$xform$/.lo/"`
|
|
@@ -452,25 +599,55 @@
|
|
*.lo) obj=`$echo "X$libobj" | $Xsed -e "$lo2o"` ;;
|
|
*)
|
|
$echo "$modename: cannot determine name of library object from \`$libobj'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
+ func_infer_tag $base_compile
|
|
+
|
|
+ for arg in $later; do
|
|
+ case $arg in
|
|
+ -static)
|
|
+ build_old_libs=yes
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
+ -prefer-pic)
|
|
+ pic_mode=yes
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
+ -prefer-non-pic)
|
|
+ pic_mode=no
|
|
+ continue
|
|
+ ;;
|
|
+ esac
|
|
+ done
|
|
+
|
|
+ objname=`$echo "X$obj" | $Xsed -e 's%^.*/%%'`
|
|
+ xdir=`$echo "X$obj" | $Xsed -e 's%/[^/]*$%%'`
|
|
+ if test "X$xdir" = "X$obj"; then
|
|
+ xdir=
|
|
+ else
|
|
+ xdir=$xdir/
|
|
+ fi
|
|
+ lobj=${xdir}$objdir/$objname
|
|
+
|
|
if test -z "$base_compile"; then
|
|
$echo "$modename: you must specify a compilation command" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Delete any leftover library objects.
|
|
if test "$build_old_libs" = yes; then
|
|
- removelist="$obj $libobj"
|
|
+ removelist="$obj $lobj $libobj ${libobj}T"
|
|
else
|
|
- removelist="$libobj"
|
|
+ removelist="$lobj $libobj ${libobj}T"
|
|
fi
|
|
|
|
$run $rm $removelist
|
|
- trap "$run $rm $removelist; exit 1" 1 2 15
|
|
+ trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15
|
|
|
|
# On Cygwin there's no "real" PIC flag so we must build both object types
|
|
case $host_os in
|
|
@@ -489,8 +666,9 @@
|
|
output_obj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext}
|
|
lockfile="$output_obj.lock"
|
|
removelist="$removelist $output_obj $lockfile"
|
|
- trap "$run $rm $removelist; exit 1" 1 2 15
|
|
+ trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15
|
|
else
|
|
+ output_obj=
|
|
need_locks=no
|
|
lockfile=
|
|
fi
|
|
@@ -498,13 +676,13 @@
|
|
# Lock this critical section if it is needed
|
|
# We use this script file to make the link, it avoids creating a new file
|
|
if test "$need_locks" = yes; then
|
|
- until $run ln "$0" "$lockfile" 2>/dev/null; do
|
|
+ until $run ln "$progpath" "$lockfile" 2>/dev/null; do
|
|
$show "Waiting for $lockfile to be removed"
|
|
sleep 2
|
|
done
|
|
elif test "$need_locks" = warn; then
|
|
if test -f "$lockfile"; then
|
|
- echo "\
|
|
+ $echo "\
|
|
*** ERROR, $lockfile exists and contains:
|
|
`cat $lockfile 2>/dev/null`
|
|
|
|
@@ -516,68 +694,67 @@
|
|
compiler."
|
|
|
|
$run $rm $removelist
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
- echo $srcfile > "$lockfile"
|
|
+ $echo $srcfile > "$lockfile"
|
|
fi
|
|
|
|
if test -n "$fix_srcfile_path"; then
|
|
eval srcfile=\"$fix_srcfile_path\"
|
|
fi
|
|
|
|
+ $run $rm "$libobj" "${libobj}T"
|
|
+
|
|
+ # Create a libtool object file (analogous to a ".la" file),
|
|
+ # but don't create it if we're doing a dry run.
|
|
+ test -z "$run" && cat > ${libobj}T <<EOF
|
|
+# $libobj - a libtool object file
|
|
+# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
|
|
+#
|
|
+# Please DO NOT delete this file!
|
|
+# It is necessary for linking the library.
|
|
+
|
|
+# Name of the PIC object.
|
|
+EOF
|
|
+
|
|
# Only build a PIC object if we are building libtool libraries.
|
|
if test "$build_libtool_libs" = yes; then
|
|
# Without this assignment, base_compile gets emptied.
|
|
fbsd_hideous_sh_bug=$base_compile
|
|
|
|
if test "$pic_mode" != no; then
|
|
- # All platforms use -DPIC, to notify preprocessed assembler code.
|
|
- command="$base_compile $srcfile $pic_flag -DPIC"
|
|
+ command="$base_compile $srcfile $pic_flag"
|
|
else
|
|
# Don't build PIC code
|
|
command="$base_compile $srcfile"
|
|
fi
|
|
- if test "$build_old_libs" = yes; then
|
|
- lo_libobj="$libobj"
|
|
- dir=`$echo "X$libobj" | $Xsed -e 's%/[^/]*$%%'`
|
|
- if test "X$dir" = "X$libobj"; then
|
|
- dir="$objdir"
|
|
- else
|
|
- dir="$dir/$objdir"
|
|
- fi
|
|
- libobj="$dir/"`$echo "X$libobj" | $Xsed -e 's%^.*/%%'`
|
|
|
|
- if test -d "$dir"; then
|
|
- $show "$rm $libobj"
|
|
- $run $rm $libobj
|
|
- else
|
|
- $show "$mkdir $dir"
|
|
- $run $mkdir $dir
|
|
- status=$?
|
|
- if test $status -ne 0 && test ! -d $dir; then
|
|
- exit $status
|
|
- fi
|
|
+ if test ! -d "${xdir}$objdir"; then
|
|
+ $show "$mkdir ${xdir}$objdir"
|
|
+ $run $mkdir ${xdir}$objdir
|
|
+ status=$?
|
|
+ if test "$status" -ne 0 && test ! -d "${xdir}$objdir"; then
|
|
+ exit $status
|
|
fi
|
|
fi
|
|
- if test "$compiler_o_lo" = yes; then
|
|
- output_obj="$libobj"
|
|
- command="$command -o $output_obj"
|
|
- elif test "$compiler_c_o" = yes; then
|
|
- output_obj="$obj"
|
|
- command="$command -o $output_obj"
|
|
+
|
|
+ if test -z "$output_obj"; then
|
|
+ # Place PIC objects in $objdir
|
|
+ command="$command -o $lobj"
|
|
fi
|
|
|
|
- $run $rm "$output_obj"
|
|
+ $run $rm "$lobj" "$output_obj"
|
|
+
|
|
$show "$command"
|
|
if $run eval "$command"; then :
|
|
else
|
|
test -n "$output_obj" && $run $rm $removelist
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
if test "$need_locks" = warn &&
|
|
- test x"`cat $lockfile 2>/dev/null`" != x"$srcfile"; then
|
|
- echo "\
|
|
+ test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
|
|
+ $echo "\
|
|
*** ERROR, $lockfile contains:
|
|
`cat $lockfile 2>/dev/null`
|
|
|
|
@@ -592,13 +769,13 @@
|
|
compiler."
|
|
|
|
$run $rm $removelist
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Just move the object if needed, then go on to compile the next one
|
|
- if test x"$output_obj" != x"$libobj"; then
|
|
- $show "$mv $output_obj $libobj"
|
|
- if $run $mv $output_obj $libobj; then :
|
|
+ if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then
|
|
+ $show "$mv $output_obj $lobj"
|
|
+ if $run $mv $output_obj $lobj; then :
|
|
else
|
|
error=$?
|
|
$run $rm $removelist
|
|
@@ -606,48 +783,23 @@
|
|
fi
|
|
fi
|
|
|
|
- # If we have no pic_flag, then copy the object into place and finish.
|
|
- if (test -z "$pic_flag" || test "$pic_mode" != default) &&
|
|
- test "$build_old_libs" = yes; then
|
|
- # Rename the .lo from within objdir to obj
|
|
- if test -f $obj; then
|
|
- $show $rm $obj
|
|
- $run $rm $obj
|
|
- fi
|
|
+ # Append the name of the PIC object to the libtool object file.
|
|
+ test -z "$run" && cat >> ${libobj}T <<EOF
|
|
+pic_object='$objdir/$objname'
|
|
|
|
- $show "$mv $libobj $obj"
|
|
- if $run $mv $libobj $obj; then :
|
|
- else
|
|
- error=$?
|
|
- $run $rm $removelist
|
|
- exit $error
|
|
- fi
|
|
+EOF
|
|
|
|
- xdir=`$echo "X$obj" | $Xsed -e 's%/[^/]*$%%'`
|
|
- if test "X$xdir" = "X$obj"; then
|
|
- xdir="."
|
|
- else
|
|
- xdir="$xdir"
|
|
- fi
|
|
- baseobj=`$echo "X$obj" | $Xsed -e "s%.*/%%"`
|
|
- libobj=`$echo "X$baseobj" | $Xsed -e "$o2lo"`
|
|
- # Now arrange that obj and lo_libobj become the same file
|
|
- $show "(cd $xdir && $LN_S $baseobj $libobj)"
|
|
- if $run eval '(cd $xdir && $LN_S $baseobj $libobj)'; then
|
|
- # Unlock the critical section if it was locked
|
|
- if test "$need_locks" != no; then
|
|
- $run $rm "$lockfile"
|
|
- fi
|
|
- exit 0
|
|
- else
|
|
- error=$?
|
|
- $run $rm $removelist
|
|
- exit $error
|
|
- fi
|
|
+ # Allow error messages only from the first compilation.
|
|
+ if test "$suppress_opt" = yes; then
|
|
+ suppress_output=' >/dev/null 2>&1'
|
|
fi
|
|
+ else
|
|
+ # No PIC object so indicate it doesn't exist in the libtool
|
|
+ # object file.
|
|
+ test -z "$run" && cat >> ${libobj}T <<EOF
|
|
+pic_object=none
|
|
|
|
- # Allow error messages only from the first compilation.
|
|
- suppress_output=' >/dev/null 2>&1'
|
|
+EOF
|
|
fi
|
|
|
|
# Only build a position-dependent object if we build old libraries.
|
|
@@ -656,27 +808,25 @@
|
|
# Don't build PIC code
|
|
command="$base_compile $srcfile"
|
|
else
|
|
- # All platforms use -DPIC, to notify preprocessed assembler code.
|
|
- command="$base_compile $srcfile $pic_flag -DPIC"
|
|
+ command="$base_compile $srcfile $pic_flag"
|
|
fi
|
|
if test "$compiler_c_o" = yes; then
|
|
command="$command -o $obj"
|
|
- output_obj="$obj"
|
|
fi
|
|
|
|
# Suppress compiler output if we already did a PIC compilation.
|
|
command="$command$suppress_output"
|
|
- $run $rm "$output_obj"
|
|
+ $run $rm "$obj" "$output_obj"
|
|
$show "$command"
|
|
if $run eval "$command"; then :
|
|
else
|
|
$run $rm $removelist
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
if test "$need_locks" = warn &&
|
|
- test x"`cat $lockfile 2>/dev/null`" != x"$srcfile"; then
|
|
- echo "\
|
|
+ test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
|
|
+ $echo "\
|
|
*** ERROR, $lockfile contains:
|
|
`cat $lockfile 2>/dev/null`
|
|
|
|
@@ -691,11 +841,11 @@
|
|
compiler."
|
|
|
|
$run $rm $removelist
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Just move the object if needed
|
|
- if test x"$output_obj" != x"$obj"; then
|
|
+ if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then
|
|
$show "$mv $output_obj $obj"
|
|
if $run $mv $output_obj $obj; then :
|
|
else
|
|
@@ -705,29 +855,31 @@
|
|
fi
|
|
fi
|
|
|
|
- # Create an invalid libtool object if no PIC, so that we do not
|
|
- # accidentally link it into a program.
|
|
- if test "$build_libtool_libs" != yes; then
|
|
- $show "echo timestamp > $libobj"
|
|
- $run eval "echo timestamp > \$libobj" || exit $?
|
|
- else
|
|
- # Move the .lo from within objdir
|
|
- $show "$mv $libobj $lo_libobj"
|
|
- if $run $mv $libobj $lo_libobj; then :
|
|
- else
|
|
- error=$?
|
|
- $run $rm $removelist
|
|
- exit $error
|
|
- fi
|
|
- fi
|
|
+ # Append the name of the non-PIC object the libtool object file.
|
|
+ # Only append if the libtool object file exists.
|
|
+ test -z "$run" && cat >> ${libobj}T <<EOF
|
|
+# Name of the non-PIC object.
|
|
+non_pic_object='$objname'
|
|
+
|
|
+EOF
|
|
+ else
|
|
+ # Append the name of the non-PIC object the libtool object file.
|
|
+ # Only append if the libtool object file exists.
|
|
+ test -z "$run" && cat >> ${libobj}T <<EOF
|
|
+# Name of the non-PIC object.
|
|
+non_pic_object=none
|
|
+
|
|
+EOF
|
|
fi
|
|
|
|
+ $run $mv "${libobj}T" "${libobj}"
|
|
+
|
|
# Unlock the critical section if it was locked
|
|
if test "$need_locks" != no; then
|
|
$run $rm "$lockfile"
|
|
fi
|
|
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
# libtool link mode
|
|
@@ -738,7 +890,7 @@
|
|
# It is impossible to link a dll without this setting, and
|
|
# we shouldn't force the makefile maintainer to figure out
|
|
# which system we are compiling for in order to pass an extra
|
|
- # flag for every libtool invokation.
|
|
+ # flag for every libtool invocation.
|
|
# allow_undefined=no
|
|
|
|
# FIXME: Unfortunately, there are problems with the above when trying
|
|
@@ -753,6 +905,7 @@
|
|
;;
|
|
esac
|
|
libtool_args="$nonopt"
|
|
+ base_compile="$nonopt $@"
|
|
compile_command="$nonopt"
|
|
finalize_command="$nonopt"
|
|
|
|
@@ -768,6 +921,7 @@
|
|
linker_flags=
|
|
dllsearchpath=
|
|
lib_search_path=`pwd`
|
|
+ inst_prefix_dir=
|
|
|
|
avoid_version=no
|
|
dlfiles=
|
|
@@ -782,6 +936,8 @@
|
|
module=no
|
|
no_install=no
|
|
objs=
|
|
+ non_pic_objects=
|
|
+ precious_files_regex=
|
|
prefer_static_libs=no
|
|
preload=no
|
|
prev=
|
|
@@ -793,6 +949,9 @@
|
|
temp_rpath=
|
|
thread_safe=no
|
|
vinfo=
|
|
+ vinfo_number=no
|
|
+
|
|
+ func_infer_tag $base_compile
|
|
|
|
# We need to know -static, to get the right output filenames.
|
|
for arg
|
|
@@ -823,7 +982,7 @@
|
|
test -n "$old_archive_from_new_cmds" && build_old_libs=yes
|
|
|
|
# Go through the arguments, transforming them on the way.
|
|
- while test $# -gt 0; do
|
|
+ while test "$#" -gt 0; do
|
|
arg="$1"
|
|
shift
|
|
case $arg in
|
|
@@ -888,7 +1047,7 @@
|
|
export_symbols="$arg"
|
|
if test ! -f "$arg"; then
|
|
$echo "$modename: symbol file \`$arg' does not exist"
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
prev=
|
|
continue
|
|
@@ -898,18 +1057,135 @@
|
|
prev=
|
|
continue
|
|
;;
|
|
+ inst_prefix)
|
|
+ inst_prefix_dir="$arg"
|
|
+ prev=
|
|
+ continue
|
|
+ ;;
|
|
+ precious_regex)
|
|
+ precious_files_regex="$arg"
|
|
+ prev=
|
|
+ continue
|
|
+ ;;
|
|
release)
|
|
release="-$arg"
|
|
prev=
|
|
continue
|
|
;;
|
|
+ objectlist)
|
|
+ if test -f "$arg"; then
|
|
+ save_arg=$arg
|
|
+ moreargs=
|
|
+ for fil in `cat $save_arg`
|
|
+ do
|
|
+# moreargs="$moreargs $fil"
|
|
+ arg=$fil
|
|
+ # A libtool-controlled object.
|
|
+
|
|
+ # Check to see that this really is a libtool object.
|
|
+ if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
+ pic_object=
|
|
+ non_pic_object=
|
|
+
|
|
+ # Read the .lo file
|
|
+ # If there is no directory component, then add one.
|
|
+ case $arg in
|
|
+ */* | *\\*) . $arg ;;
|
|
+ *) . ./$arg ;;
|
|
+ esac
|
|
+
|
|
+ if test -z "$pic_object" || \
|
|
+ test -z "$non_pic_object" ||
|
|
+ test "$pic_object" = none && \
|
|
+ test "$non_pic_object" = none; then
|
|
+ $echo "$modename: cannot find name of object for \`$arg'" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+ fi
|
|
+
|
|
+ # Extract subdirectory from the argument.
|
|
+ xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
|
|
+ if test "X$xdir" = "X$arg"; then
|
|
+ xdir=
|
|
+ else
|
|
+ xdir="$xdir/"
|
|
+ fi
|
|
+
|
|
+ if test "$pic_object" != none; then
|
|
+ # Prepend the subdirectory the object is found in.
|
|
+ pic_object="$xdir$pic_object"
|
|
+
|
|
+ if test "$prev" = dlfiles; then
|
|
+ if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
|
|
+ dlfiles="$dlfiles $pic_object"
|
|
+ prev=
|
|
+ continue
|
|
+ else
|
|
+ # If libtool objects are unsupported, then we need to preload.
|
|
+ prev=dlprefiles
|
|
+ fi
|
|
+ fi
|
|
+
|
|
+ # CHECK ME: I think I busted this. -Ossama
|
|
+ if test "$prev" = dlprefiles; then
|
|
+ # Preload the old-style object.
|
|
+ dlprefiles="$dlprefiles $pic_object"
|
|
+ prev=
|
|
+ fi
|
|
+
|
|
+ # A PIC object.
|
|
+ libobjs="$libobjs $pic_object"
|
|
+ arg="$pic_object"
|
|
+ fi
|
|
+
|
|
+ # Non-PIC object.
|
|
+ if test "$non_pic_object" != none; then
|
|
+ # Prepend the subdirectory the object is found in.
|
|
+ non_pic_object="$xdir$non_pic_object"
|
|
+
|
|
+ # A standard non-PIC object
|
|
+ non_pic_objects="$non_pic_objects $non_pic_object"
|
|
+ if test -z "$pic_object" || test "$pic_object" = none ; then
|
|
+ arg="$non_pic_object"
|
|
+ fi
|
|
+ fi
|
|
+ else
|
|
+ # Only an error if not doing a dry-run.
|
|
+ if test -z "$run"; then
|
|
+ $echo "$modename: \`$arg' is not a valid libtool object" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+ else
|
|
+ # Dry-run case.
|
|
+
|
|
+ # Extract subdirectory from the argument.
|
|
+ xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
|
|
+ if test "X$xdir" = "X$arg"; then
|
|
+ xdir=
|
|
+ else
|
|
+ xdir="$xdir/"
|
|
+ fi
|
|
+
|
|
+ pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"`
|
|
+ non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"`
|
|
+ libobjs="$libobjs $pic_object"
|
|
+ non_pic_objects="$non_pic_objects $non_pic_object"
|
|
+ fi
|
|
+ fi
|
|
+ done
|
|
+ else
|
|
+ $echo "$modename: link input file \`$save_arg' does not exist"
|
|
+ exit $EXIT_FAILURE
|
|
+ fi
|
|
+ arg=$save_arg
|
|
+ prev=
|
|
+ continue
|
|
+ ;;
|
|
rpath | xrpath)
|
|
# We need an absolute path.
|
|
case $arg in
|
|
[\\/]* | [A-Za-z]:[\\/]*) ;;
|
|
*)
|
|
$echo "$modename: only absolute run-paths are allowed" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
if test "$prev" = rpath; then
|
|
@@ -941,13 +1217,26 @@
|
|
finalize_command="$finalize_command $wl$qarg"
|
|
continue
|
|
;;
|
|
+ xcclinker)
|
|
+ linker_flags="$linker_flags $qarg"
|
|
+ compiler_flags="$compiler_flags $qarg"
|
|
+ prev=
|
|
+ compile_command="$compile_command $qarg"
|
|
+ finalize_command="$finalize_command $qarg"
|
|
+ continue
|
|
+ ;;
|
|
+ shrext)
|
|
+ shrext_cmds="$arg"
|
|
+ prev=
|
|
+ continue
|
|
+ ;;
|
|
*)
|
|
eval "$prev=\"\$arg\""
|
|
prev=
|
|
continue
|
|
;;
|
|
esac
|
|
- fi # test -n $prev
|
|
+ fi # test -n "$prev"
|
|
|
|
prevarg="$arg"
|
|
|
|
@@ -989,7 +1278,7 @@
|
|
-export-symbols | -export-symbols-regex)
|
|
if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
|
|
$echo "$modename: more than one -exported-symbols argument is not allowed"
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
if test "X$arg" = "X-export-symbols"; then
|
|
prev=expsyms
|
|
@@ -999,11 +1288,16 @@
|
|
continue
|
|
;;
|
|
|
|
+ -inst-prefix-dir)
|
|
+ prev=inst_prefix
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
# The native IRIX linker understands -LANG:*, -LIST:* and -LNO:*
|
|
# so, if we see these flags be careful not to treat them like -L
|
|
-L[A-Z][A-Z]*:*)
|
|
case $with_gcc/$host in
|
|
- no/*-*-irix* | no/*-*-nonstopux*)
|
|
+ no/*-*-irix* | /*-*-irix*)
|
|
compile_command="$compile_command $arg"
|
|
finalize_command="$finalize_command $arg"
|
|
;;
|
|
@@ -1020,7 +1314,7 @@
|
|
absdir=`cd "$dir" && pwd`
|
|
if test -z "$absdir"; then
|
|
$echo "$modename: cannot determine absolute directory name of \`$dir'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
dir="$absdir"
|
|
;;
|
|
@@ -1058,24 +1352,61 @@
|
|
# Do not include libc due to us having libc/libc_r.
|
|
test "X$arg" = "X-lc" && continue
|
|
;;
|
|
- esac
|
|
- elif test "X$arg" = "X-lc_r"; then
|
|
- case $host in
|
|
- *-*-openbsd* | *-*-freebsd*)
|
|
- # Do not include libc_r directly, use -pthread flag.
|
|
+ *-*-rhapsody* | *-*-darwin1.[012])
|
|
+ # Rhapsody C and math libraries are in the System framework
|
|
+ deplibs="$deplibs -framework System"
|
|
continue
|
|
- ;;
|
|
esac
|
|
+ elif test "X$arg" = "X-lc_r"; then
|
|
+ case $host in
|
|
+ *-*-openbsd* | *-*-freebsd*)
|
|
+ # Do not include libc_r directly, use -pthread flag.
|
|
+ continue
|
|
+ ;;
|
|
+ esac
|
|
fi
|
|
deplibs="$deplibs $arg"
|
|
continue
|
|
;;
|
|
|
|
+ -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe)
|
|
+ deplibs="$deplibs $arg"
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
-module)
|
|
module=yes
|
|
continue
|
|
;;
|
|
|
|
+ # gcc -m* arguments should be passed to the linker via $compiler_flags
|
|
+ # in order to pass architecture information to the linker
|
|
+ # (e.g. 32 vs 64-bit). This may also be accomplished via -Wl,-mfoo
|
|
+ # but this is not reliable with gcc because gcc may use -mfoo to
|
|
+ # select a different linker, different libraries, etc, while
|
|
+ # -Wl,-mfoo simply passes -mfoo to the linker.
|
|
+ -m*)
|
|
+ # Unknown arguments in both finalize_command and compile_command need
|
|
+ # to be aesthetically quoted because they are evaled later.
|
|
+ arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
|
|
+ case $arg in
|
|
+ *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
|
|
+ arg="\"$arg\""
|
|
+ ;;
|
|
+ esac
|
|
+ compile_command="$compile_command $arg"
|
|
+ finalize_command="$finalize_command $arg"
|
|
+ if test "$with_gcc" = "yes" ; then
|
|
+ compiler_flags="$compiler_flags $arg"
|
|
+ fi
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
+ -shrext)
|
|
+ prev=shrext
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
-no-fast-install)
|
|
fast_install=no
|
|
continue
|
|
@@ -1100,8 +1431,18 @@
|
|
continue
|
|
;;
|
|
|
|
+ -objectlist)
|
|
+ prev=objectlist
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
-o) prev=output ;;
|
|
|
|
+ -precious-files-regex)
|
|
+ prev=precious_regex
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
-release)
|
|
prev=release
|
|
continue
|
|
@@ -1124,7 +1465,7 @@
|
|
[\\/]* | [A-Za-z]:[\\/]*) ;;
|
|
*)
|
|
$echo "$modename: only absolute run-paths are allowed" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
case "$xrpath " in
|
|
@@ -1152,6 +1493,11 @@
|
|
prev=vinfo
|
|
continue
|
|
;;
|
|
+ -version-number)
|
|
+ prev=vinfo
|
|
+ vinfo_number=yes
|
|
+ continue
|
|
+ ;;
|
|
|
|
-Wc,*)
|
|
args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wc,//'`
|
|
@@ -1200,6 +1546,11 @@
|
|
continue
|
|
;;
|
|
|
|
+ -XCClinker)
|
|
+ prev=xcclinker
|
|
+ continue
|
|
+ ;;
|
|
+
|
|
# Some other compiler flag.
|
|
-* | +*)
|
|
# Unknown arguments in both finalize_command and compile_command need
|
|
@@ -1212,29 +1563,101 @@
|
|
esac
|
|
;;
|
|
|
|
- *.lo | *.$objext)
|
|
- # A library or standard object.
|
|
- if test "$prev" = dlfiles; then
|
|
- # This file was specified with -dlopen.
|
|
- if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
|
|
- dlfiles="$dlfiles $arg"
|
|
- prev=
|
|
- continue
|
|
- else
|
|
- # If libtool objects are unsupported, then we need to preload.
|
|
- prev=dlprefiles
|
|
- fi
|
|
- fi
|
|
+ *.$objext)
|
|
+ # A standard object.
|
|
+ objs="$objs $arg"
|
|
+ ;;
|
|
|
|
- if test "$prev" = dlprefiles; then
|
|
- # Preload the old-style object.
|
|
- dlprefiles="$dlprefiles "`$echo "X$arg" | $Xsed -e "$lo2o"`
|
|
- prev=
|
|
- else
|
|
+ *.lo)
|
|
+ # A libtool-controlled object.
|
|
+
|
|
+ # Check to see that this really is a libtool object.
|
|
+ if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
+ pic_object=
|
|
+ non_pic_object=
|
|
+
|
|
+ # Read the .lo file
|
|
+ # If there is no directory component, then add one.
|
|
case $arg in
|
|
- *.lo) libobjs="$libobjs $arg" ;;
|
|
- *) objs="$objs $arg" ;;
|
|
+ */* | *\\*) . $arg ;;
|
|
+ *) . ./$arg ;;
|
|
esac
|
|
+
|
|
+ if test -z "$pic_object" || \
|
|
+ test -z "$non_pic_object" ||
|
|
+ test "$pic_object" = none && \
|
|
+ test "$non_pic_object" = none; then
|
|
+ $echo "$modename: cannot find name of object for \`$arg'" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+ fi
|
|
+
|
|
+ # Extract subdirectory from the argument.
|
|
+ xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
|
|
+ if test "X$xdir" = "X$arg"; then
|
|
+ xdir=
|
|
+ else
|
|
+ xdir="$xdir/"
|
|
+ fi
|
|
+
|
|
+ if test "$pic_object" != none; then
|
|
+ # Prepend the subdirectory the object is found in.
|
|
+ pic_object="$xdir$pic_object"
|
|
+
|
|
+ if test "$prev" = dlfiles; then
|
|
+ if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
|
|
+ dlfiles="$dlfiles $pic_object"
|
|
+ prev=
|
|
+ continue
|
|
+ else
|
|
+ # If libtool objects are unsupported, then we need to preload.
|
|
+ prev=dlprefiles
|
|
+ fi
|
|
+ fi
|
|
+
|
|
+ # CHECK ME: I think I busted this. -Ossama
|
|
+ if test "$prev" = dlprefiles; then
|
|
+ # Preload the old-style object.
|
|
+ dlprefiles="$dlprefiles $pic_object"
|
|
+ prev=
|
|
+ fi
|
|
+
|
|
+ # A PIC object.
|
|
+ libobjs="$libobjs $pic_object"
|
|
+ arg="$pic_object"
|
|
+ fi
|
|
+
|
|
+ # Non-PIC object.
|
|
+ if test "$non_pic_object" != none; then
|
|
+ # Prepend the subdirectory the object is found in.
|
|
+ non_pic_object="$xdir$non_pic_object"
|
|
+
|
|
+ # A standard non-PIC object
|
|
+ non_pic_objects="$non_pic_objects $non_pic_object"
|
|
+ if test -z "$pic_object" || test "$pic_object" = none ; then
|
|
+ arg="$non_pic_object"
|
|
+ fi
|
|
+ fi
|
|
+ else
|
|
+ # Only an error if not doing a dry-run.
|
|
+ if test -z "$run"; then
|
|
+ $echo "$modename: \`$arg' is not a valid libtool object" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+ else
|
|
+ # Dry-run case.
|
|
+
|
|
+ # Extract subdirectory from the argument.
|
|
+ xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
|
|
+ if test "X$xdir" = "X$arg"; then
|
|
+ xdir=
|
|
+ else
|
|
+ xdir="$xdir/"
|
|
+ fi
|
|
+
|
|
+ pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"`
|
|
+ non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"`
|
|
+ libobjs="$libobjs $pic_object"
|
|
+ non_pic_objects="$non_pic_objects $non_pic_object"
|
|
+ fi
|
|
fi
|
|
;;
|
|
|
|
@@ -1285,7 +1708,7 @@
|
|
if test -n "$prev"; then
|
|
$echo "$modename: the \`$prevarg' option requires an argument" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then
|
|
@@ -1294,6 +1717,7 @@
|
|
finalize_command="$finalize_command $arg"
|
|
fi
|
|
|
|
+ oldlibs=
|
|
# calculate the name of the file, without its directory
|
|
outputname=`$echo "X$output" | $Xsed -e 's%^.*/%%'`
|
|
libobjs_save="$libobjs"
|
|
@@ -1314,11 +1738,11 @@
|
|
output_objdir="$output_objdir/$objdir"
|
|
fi
|
|
# Create the object directory.
|
|
- if test ! -d $output_objdir; then
|
|
+ if test ! -d "$output_objdir"; then
|
|
$show "$mkdir $output_objdir"
|
|
$run $mkdir $output_objdir
|
|
status=$?
|
|
- if test $status -ne 0 && test ! -d $output_objdir; then
|
|
+ if test "$status" -ne 0 && test ! -d "$output_objdir"; then
|
|
exit $status
|
|
fi
|
|
fi
|
|
@@ -1328,7 +1752,7 @@
|
|
"")
|
|
$echo "$modename: you must specify an output file" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
*.$libext) linkmode=oldlib ;;
|
|
*.lo | *.$objext) linkmode=obj ;;
|
|
@@ -1336,7 +1760,17 @@
|
|
*) linkmode=prog ;; # Anything else should be a program.
|
|
esac
|
|
|
|
+ case $host in
|
|
+ *cygwin* | *mingw* | *pw32*)
|
|
+ # don't eliminate duplications in $postdeps and $predeps
|
|
+ duplicate_compiler_generated_deps=yes
|
|
+ ;;
|
|
+ *)
|
|
+ duplicate_compiler_generated_deps=$duplicate_deps
|
|
+ ;;
|
|
+ esac
|
|
specialdeplibs=
|
|
+
|
|
libs=
|
|
# Find all interdependent deplibs by searching for libraries
|
|
# that are linked more than once (e.g. -la -lb -la)
|
|
@@ -1348,6 +1782,25 @@
|
|
fi
|
|
libs="$libs $deplib"
|
|
done
|
|
+
|
|
+ if test "$linkmode" = lib; then
|
|
+ libs="$predeps $libs $compiler_lib_search_path $postdeps"
|
|
+
|
|
+ # Compute libraries that are listed more than once in $predeps
|
|
+ # $postdeps and mark them as special (i.e., whose duplicates are
|
|
+ # not to be eliminated).
|
|
+ pre_post_deps=
|
|
+ if test "X$duplicate_compiler_generated_deps" = "Xyes" ; then
|
|
+ for pre_post_dep in $predeps $postdeps; do
|
|
+ case "$pre_post_deps " in
|
|
+ *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;;
|
|
+ esac
|
|
+ pre_post_deps="$pre_post_deps $pre_post_dep"
|
|
+ done
|
|
+ fi
|
|
+ pre_post_deps=
|
|
+ fi
|
|
+
|
|
deplibs=
|
|
newdependency_libs=
|
|
newlib_search_path=
|
|
@@ -1362,7 +1815,7 @@
|
|
*.la) ;;
|
|
*)
|
|
$echo "$modename: libraries can \`-dlopen' only libtool libraries: $file" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
done
|
|
@@ -1379,39 +1832,59 @@
|
|
;;
|
|
esac
|
|
for pass in $passes; do
|
|
- if test $linkmode = prog; then
|
|
- # Determine which files to process
|
|
+ if test "$linkmode,$pass" = "lib,link" ||
|
|
+ test "$linkmode,$pass" = "prog,scan"; then
|
|
+ libs="$deplibs"
|
|
+ deplibs=
|
|
+ fi
|
|
+ if test "$linkmode" = prog; then
|
|
case $pass in
|
|
- dlopen)
|
|
- libs="$dlfiles"
|
|
- save_deplibs="$deplibs" # Collect dlpreopened libraries
|
|
- deplibs=
|
|
- ;;
|
|
+ dlopen) libs="$dlfiles" ;;
|
|
dlpreopen) libs="$dlprefiles" ;;
|
|
link) libs="$deplibs %DEPLIBS% $dependency_libs" ;;
|
|
esac
|
|
fi
|
|
+ if test "$pass" = dlopen; then
|
|
+ # Collect dlpreopened libraries
|
|
+ save_deplibs="$deplibs"
|
|
+ deplibs=
|
|
+ fi
|
|
for deplib in $libs; do
|
|
lib=
|
|
found=no
|
|
case $deplib in
|
|
+ -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe)
|
|
+ if test "$linkmode,$pass" = "prog,link"; then
|
|
+ compile_deplibs="$deplib $compile_deplibs"
|
|
+ finalize_deplibs="$deplib $finalize_deplibs"
|
|
+ else
|
|
+ deplibs="$deplib $deplibs"
|
|
+ fi
|
|
+ continue
|
|
+ ;;
|
|
-l*)
|
|
- if test $linkmode = oldlib && test $linkmode = obj; then
|
|
- $echo "$modename: warning: \`-l' is ignored for archives/objects: $deplib" 1>&2
|
|
+ if test "$linkmode" != lib && test "$linkmode" != prog; then
|
|
+ $echo "$modename: warning: \`-l' is ignored for archives/objects" 1>&2
|
|
continue
|
|
fi
|
|
- if test $pass = conv; then
|
|
+ if test "$pass" = conv; then
|
|
deplibs="$deplib $deplibs"
|
|
continue
|
|
fi
|
|
name=`$echo "X$deplib" | $Xsed -e 's/^-l//'`
|
|
for searchdir in $newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path; do
|
|
- # Search the libtool library
|
|
- lib="$searchdir/lib${name}.la"
|
|
- if test -f "$lib"; then
|
|
- found=yes
|
|
- break
|
|
- fi
|
|
+ for search_ext in .la $std_shrext .so .a; do
|
|
+ # Search the libtool library
|
|
+ lib="$searchdir/lib${name}${search_ext}"
|
|
+ if test -f "$lib"; then
|
|
+ if test "$search_ext" = ".la"; then
|
|
+ found=yes
|
|
+ else
|
|
+ found=no
|
|
+ fi
|
|
+ break 2
|
|
+ fi
|
|
+ done
|
|
done
|
|
if test "$found" != yes; then
|
|
# deplib doesn't seem to be a libtool library
|
|
@@ -1420,40 +1893,76 @@
|
|
finalize_deplibs="$deplib $finalize_deplibs"
|
|
else
|
|
deplibs="$deplib $deplibs"
|
|
- test $linkmode = lib && newdependency_libs="$deplib $newdependency_libs"
|
|
+ test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
|
|
fi
|
|
continue
|
|
+ else # deplib is a libtool library
|
|
+ # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib,
|
|
+ # We need to do some special things here, and not later.
|
|
+ if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
|
+ case " $predeps $postdeps " in
|
|
+ *" $deplib "*)
|
|
+ if (${SED} -e '2q' $lib |
|
|
+ grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
+ library_names=
|
|
+ old_library=
|
|
+ case $lib in
|
|
+ */* | *\\*) . $lib ;;
|
|
+ *) . ./$lib ;;
|
|
+ esac
|
|
+ for l in $old_library $library_names; do
|
|
+ ll="$l"
|
|
+ done
|
|
+ if test "X$ll" = "X$old_library" ; then # only static version available
|
|
+ found=no
|
|
+ ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'`
|
|
+ test "X$ladir" = "X$lib" && ladir="."
|
|
+ lib=$ladir/$old_library
|
|
+ if test "$linkmode,$pass" = "prog,link"; then
|
|
+ compile_deplibs="$deplib $compile_deplibs"
|
|
+ finalize_deplibs="$deplib $finalize_deplibs"
|
|
+ else
|
|
+ deplibs="$deplib $deplibs"
|
|
+ test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
|
|
+ fi
|
|
+ continue
|
|
+ fi
|
|
+ fi
|
|
+ ;;
|
|
+ *) ;;
|
|
+ esac
|
|
+ fi
|
|
fi
|
|
;; # -l
|
|
-L*)
|
|
case $linkmode in
|
|
lib)
|
|
deplibs="$deplib $deplibs"
|
|
- test $pass = conv && continue
|
|
+ test "$pass" = conv && continue
|
|
newdependency_libs="$deplib $newdependency_libs"
|
|
newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`
|
|
;;
|
|
prog)
|
|
- if test $pass = conv; then
|
|
+ if test "$pass" = conv; then
|
|
deplibs="$deplib $deplibs"
|
|
continue
|
|
fi
|
|
- if test $pass = scan; then
|
|
+ if test "$pass" = scan; then
|
|
deplibs="$deplib $deplibs"
|
|
- newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`
|
|
else
|
|
compile_deplibs="$deplib $compile_deplibs"
|
|
finalize_deplibs="$deplib $finalize_deplibs"
|
|
fi
|
|
+ newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`
|
|
;;
|
|
*)
|
|
- $echo "$modename: warning: \`-L' is ignored for archives/objects: $deplib" 1>&2
|
|
+ $echo "$modename: warning: \`-L' is ignored for archives/objects" 1>&2
|
|
;;
|
|
esac # linkmode
|
|
continue
|
|
;; # -L
|
|
-R*)
|
|
- if test $pass = link; then
|
|
+ if test "$pass" = link; then
|
|
dir=`$echo "X$deplib" | $Xsed -e 's/^-R//'`
|
|
# Make sure the xrpath contains only unique directories.
|
|
case "$xrpath " in
|
|
@@ -1466,30 +1975,30 @@
|
|
;;
|
|
*.la) lib="$deplib" ;;
|
|
*.$libext)
|
|
- if test $pass = conv; then
|
|
+ if test "$pass" = conv; then
|
|
deplibs="$deplib $deplibs"
|
|
continue
|
|
fi
|
|
case $linkmode in
|
|
lib)
|
|
if test "$deplibs_check_method" != pass_all; then
|
|
- echo
|
|
- echo "*** Warning: Trying to link with static lib archive $deplib."
|
|
- echo "*** I have the capability to make that library automatically link in when"
|
|
- echo "*** you link to this library. But I can only do this if you have a"
|
|
- echo "*** shared version of the library, which you do not appear to have"
|
|
- echo "*** because the file extensions .$libext of this argument makes me believe"
|
|
- echo "*** that it is just a static archive that I should not used here."
|
|
+ $echo
|
|
+ $echo "*** Warning: Trying to link with static lib archive $deplib."
|
|
+ $echo "*** I have the capability to make that library automatically link in when"
|
|
+ $echo "*** you link to this library. But I can only do this if you have a"
|
|
+ $echo "*** shared version of the library, which you do not appear to have"
|
|
+ $echo "*** because the file extensions .$libext of this argument makes me believe"
|
|
+ $echo "*** that it is just a static archive that I should not used here."
|
|
else
|
|
- echo
|
|
- echo "*** Warning: Linking the shared library $output against the"
|
|
- echo "*** static library $deplib is not portable!"
|
|
+ $echo
|
|
+ $echo "*** Warning: Linking the shared library $output against the"
|
|
+ $echo "*** static library $deplib is not portable!"
|
|
deplibs="$deplib $deplibs"
|
|
fi
|
|
continue
|
|
;;
|
|
prog)
|
|
- if test $pass != link; then
|
|
+ if test "$pass" != link; then
|
|
deplibs="$deplib $deplibs"
|
|
else
|
|
compile_deplibs="$deplib $compile_deplibs"
|
|
@@ -1500,14 +2009,18 @@
|
|
esac # linkmode
|
|
;; # *.$libext
|
|
*.lo | *.$objext)
|
|
- if test $pass = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
|
|
- # If there is no dlopen support or we're linking statically,
|
|
- # we need to preload.
|
|
- newdlprefiles="$newdlprefiles $deplib"
|
|
- compile_deplibs="$deplib $compile_deplibs"
|
|
- finalize_deplibs="$deplib $finalize_deplibs"
|
|
- else
|
|
- newdlfiles="$newdlfiles $deplib"
|
|
+ if test "$pass" = conv; then
|
|
+ deplibs="$deplib $deplibs"
|
|
+ elif test "$linkmode" = prog; then
|
|
+ if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
|
|
+ # If there is no dlopen support or we're linking statically,
|
|
+ # we need to preload.
|
|
+ newdlprefiles="$newdlprefiles $deplib"
|
|
+ compile_deplibs="$deplib $compile_deplibs"
|
|
+ finalize_deplibs="$deplib $finalize_deplibs"
|
|
+ else
|
|
+ newdlfiles="$newdlfiles $deplib"
|
|
+ fi
|
|
fi
|
|
continue
|
|
;;
|
|
@@ -1516,17 +2029,17 @@
|
|
continue
|
|
;;
|
|
esac # case $deplib
|
|
- if test $found = yes || test -f "$lib"; then :
|
|
+ if test "$found" = yes || test -f "$lib"; then :
|
|
else
|
|
$echo "$modename: cannot find the library \`$lib'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Check to see that this really is a libtool archive.
|
|
- if (${SED} -e '2q' $lib | egrep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
|
|
+ if (${SED} -e '2q' $lib | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
|
|
else
|
|
$echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'`
|
|
@@ -1539,8 +2052,9 @@
|
|
library_names=
|
|
old_library=
|
|
# If the library was installed with an old release of libtool,
|
|
- # it will not redefine variable installed.
|
|
+ # it will not redefine variables installed, or shouldnotlink
|
|
installed=yes
|
|
+ shouldnotlink=no
|
|
|
|
# Read the .la file
|
|
case $lib in
|
|
@@ -1550,19 +2064,18 @@
|
|
|
|
if test "$linkmode,$pass" = "lib,link" ||
|
|
test "$linkmode,$pass" = "prog,scan" ||
|
|
- { test $linkmode = oldlib && test $linkmode = obj; }; then
|
|
- # Add dl[pre]opened files of deplib
|
|
+ { test "$linkmode" != prog && test "$linkmode" != lib; }; then
|
|
test -n "$dlopen" && dlfiles="$dlfiles $dlopen"
|
|
test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen"
|
|
fi
|
|
|
|
- if test $pass = conv; then
|
|
+ if test "$pass" = conv; then
|
|
# Only check for convenience libraries
|
|
deplibs="$lib $deplibs"
|
|
if test -z "$libdir"; then
|
|
if test -z "$old_library"; then
|
|
$echo "$modename: cannot find name of link library for \`$lib'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
# It is a libtool convenience library, so add in its objects.
|
|
convenience="$convenience $ladir/$objdir/$old_library"
|
|
@@ -1577,13 +2090,14 @@
|
|
fi
|
|
tmp_libs="$tmp_libs $deplib"
|
|
done
|
|
- elif test $linkmode != prog && test $linkmode != lib; then
|
|
+ elif test "$linkmode" != prog && test "$linkmode" != lib; then
|
|
$echo "$modename: \`$lib' is not a convenience library" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
continue
|
|
fi # $pass = conv
|
|
|
|
+
|
|
# Get the name of the library we link against.
|
|
linklib=
|
|
for l in $old_library $library_names; do
|
|
@@ -1591,19 +2105,23 @@
|
|
done
|
|
if test -z "$linklib"; then
|
|
$echo "$modename: cannot find name of link library for \`$lib'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# This library was specified with -dlopen.
|
|
- if test $pass = dlopen; then
|
|
+ if test "$pass" = dlopen; then
|
|
if test -z "$libdir"; then
|
|
$echo "$modename: cannot -dlopen a convenience library: \`$lib'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
- if test -z "$dlname" || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
|
|
+ if test -z "$dlname" ||
|
|
+ test "$dlopen_support" != yes ||
|
|
+ test "$build_libtool_libs" = no; then
|
|
# If there is no dlname, no dlopen support or we're linking
|
|
- # statically, we need to preload.
|
|
- dlprefiles="$dlprefiles $lib"
|
|
+ # statically, we need to preload. We also need to preload any
|
|
+ # dependent libraries so libltdl's deplib preloader doesn't
|
|
+ # bomb out in the load deplibs phase.
|
|
+ dlprefiles="$dlprefiles $lib $dependency_libs"
|
|
else
|
|
newdlfiles="$newdlfiles $lib"
|
|
fi
|
|
@@ -1644,10 +2162,10 @@
|
|
name=`$echo "X$laname" | $Xsed -e 's/\.la$//' -e 's/^lib//'`
|
|
|
|
# This library was specified with -dlpreopen.
|
|
- if test $pass = dlpreopen; then
|
|
+ if test "$pass" = dlpreopen; then
|
|
if test -z "$libdir"; then
|
|
$echo "$modename: cannot -dlpreopen a convenience library: \`$lib'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
# Prefer using a static library (so that no silly _DYNAMIC symbols
|
|
# are required to link).
|
|
@@ -1663,18 +2181,19 @@
|
|
|
|
if test -z "$libdir"; then
|
|
# Link the convenience library
|
|
- if test $linkmode = lib; then
|
|
+ if test "$linkmode" = lib; then
|
|
deplibs="$dir/$old_library $deplibs"
|
|
elif test "$linkmode,$pass" = "prog,link"; then
|
|
compile_deplibs="$dir/$old_library $compile_deplibs"
|
|
finalize_deplibs="$dir/$old_library $finalize_deplibs"
|
|
else
|
|
- deplibs="$lib $deplibs"
|
|
+ deplibs="$lib $deplibs" # used for prog,scan pass
|
|
fi
|
|
continue
|
|
fi
|
|
|
|
- if test $linkmode = prog && test $pass != link; then
|
|
+
|
|
+ if test "$linkmode" = prog && test "$pass" != link; then
|
|
newlib_search_path="$newlib_search_path $ladir"
|
|
deplibs="$lib $deplibs"
|
|
|
|
@@ -1690,7 +2209,7 @@
|
|
-L*) newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`;; ### testsuite: skip nested quoting test
|
|
esac
|
|
# Need to link against all dependency_libs?
|
|
- if test $linkalldeplibs = yes; then
|
|
+ if test "$linkalldeplibs" = yes; then
|
|
deplibs="$deplib $deplibs"
|
|
else
|
|
# Need to hardcode shared library paths
|
|
@@ -1707,13 +2226,19 @@
|
|
continue
|
|
fi # $linkmode = prog...
|
|
|
|
- link_static=no # Whether the deplib will be linked statically
|
|
- if test -n "$library_names" &&
|
|
- { test "$prefer_static_libs" = no || test -z "$old_library"; }; then
|
|
- # Link against this shared library
|
|
+ if test "$linkmode,$pass" = "prog,link"; then
|
|
+ if test -n "$library_names" &&
|
|
+ { test "$prefer_static_libs" = no || test -z "$old_library"; }; then
|
|
+ # We need to hardcode the library path
|
|
+ if test -n "$shlibpath_var"; then
|
|
+ # Make sure the rpath contains only unique directories.
|
|
+ case "$temp_rpath " in
|
|
+ *" $dir "*) ;;
|
|
+ *" $absdir "*) ;;
|
|
+ *) temp_rpath="$temp_rpath $dir" ;;
|
|
+ esac
|
|
+ fi
|
|
|
|
- if test "$linkmode,$pass" = "prog,link" ||
|
|
- { test $linkmode = lib && test $hardcode_into_libs = yes; }; then
|
|
# Hardcode the library path.
|
|
# Skip directories that are in the system default run-time
|
|
# search path.
|
|
@@ -1735,17 +2260,6 @@
|
|
esac
|
|
;;
|
|
esac
|
|
- if test $linkmode = prog; then
|
|
- # We need to hardcode the library path
|
|
- if test -n "$shlibpath_var"; then
|
|
- # Make sure the rpath contains only unique directories.
|
|
- case "$temp_rpath " in
|
|
- *" $dir "*) ;;
|
|
- *" $absdir "*) ;;
|
|
- *) temp_rpath="$temp_rpath $dir" ;;
|
|
- esac
|
|
- fi
|
|
- fi
|
|
fi # $linkmode,$pass = prog,link...
|
|
|
|
if test "$alldeplibs" = yes &&
|
|
@@ -1755,11 +2269,52 @@
|
|
# We only need to search for static libraries
|
|
continue
|
|
fi
|
|
+ fi
|
|
|
|
+ link_static=no # Whether the deplib will be linked statically
|
|
+ if test -n "$library_names" &&
|
|
+ { test "$prefer_static_libs" = no || test -z "$old_library"; }; then
|
|
if test "$installed" = no; then
|
|
notinst_deplibs="$notinst_deplibs $lib"
|
|
need_relink=yes
|
|
fi
|
|
+ # This is a shared library
|
|
+
|
|
+ # Warn about portability, can't link against -module's on
|
|
+ # some systems (darwin)
|
|
+ if test "$shouldnotlink" = yes && test "$pass" = link ; then
|
|
+ $echo
|
|
+ if test "$linkmode" = prog; then
|
|
+ $echo "*** Warning: Linking the executable $output against the loadable module"
|
|
+ else
|
|
+ $echo "*** Warning: Linking the shared library $output against the loadable module"
|
|
+ fi
|
|
+ $echo "*** $linklib is not portable!"
|
|
+ fi
|
|
+ if test "$linkmode" = lib &&
|
|
+ test "$hardcode_into_libs" = yes; then
|
|
+ # Hardcode the library path.
|
|
+ # Skip directories that are in the system default run-time
|
|
+ # search path.
|
|
+ case " $sys_lib_dlsearch_path " in
|
|
+ *" $absdir "*) ;;
|
|
+ *)
|
|
+ case "$compile_rpath " in
|
|
+ *" $absdir "*) ;;
|
|
+ *) compile_rpath="$compile_rpath $absdir"
|
|
+ esac
|
|
+ ;;
|
|
+ esac
|
|
+ case " $sys_lib_dlsearch_path " in
|
|
+ *" $libdir "*) ;;
|
|
+ *)
|
|
+ case "$finalize_rpath " in
|
|
+ *" $libdir "*) ;;
|
|
+ *) finalize_rpath="$finalize_rpath $libdir"
|
|
+ esac
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
|
|
if test -n "$old_archive_from_expsyms_cmds"; then
|
|
# figure out the soname
|
|
@@ -1773,7 +2328,7 @@
|
|
elif test -n "$soname_spec"; then
|
|
# bleh windows
|
|
case $host in
|
|
- *cygwin*)
|
|
+ *cygwin* | mingw*)
|
|
major=`expr $current - $age`
|
|
versuffix="-$major"
|
|
;;
|
|
@@ -1785,17 +2340,18 @@
|
|
|
|
# Make a new name for the extract_expsyms_cmds to use
|
|
soroot="$soname"
|
|
- soname=`echo $soroot | ${SED} -e 's/^.*\///'`
|
|
- newlib="libimp-`echo $soname | ${SED} 's/^lib//;s/\.dll$//'`.a"
|
|
+ soname=`$echo $soroot | ${SED} -e 's/^.*\///'`
|
|
+ newlib="libimp-`$echo $soname | ${SED} 's/^lib//;s/\.dll$//'`.a"
|
|
|
|
# If the library has no export list, then create one now
|
|
if test -f "$output_objdir/$soname-def"; then :
|
|
else
|
|
$show "extracting exported symbol list from \`$soname'"
|
|
save_ifs="$IFS"; IFS='~'
|
|
- eval cmds=\"$extract_expsyms_cmds\"
|
|
+ cmds=$extract_expsyms_cmds
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
done
|
|
@@ -1806,9 +2362,10 @@
|
|
if test -f "$output_objdir/$newlib"; then :; else
|
|
$show "generating import library for \`$soname'"
|
|
save_ifs="$IFS"; IFS='~'
|
|
- eval cmds=\"$old_archive_from_expsyms_cmds\"
|
|
+ cmds=$old_archive_from_expsyms_cmds
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
done
|
|
@@ -1817,9 +2374,9 @@
|
|
# make sure the library variables are pointing to the new library
|
|
dir=$output_objdir
|
|
linklib=$newlib
|
|
- fi # test -n $old_archive_from_expsyms_cmds
|
|
+ fi # test -n "$old_archive_from_expsyms_cmds"
|
|
|
|
- if test $linkmode = prog || test "$mode" != relink; then
|
|
+ if test "$linkmode" = prog || test "$mode" != relink; then
|
|
add_shlibpath=
|
|
add_dir=
|
|
add=
|
|
@@ -1828,6 +2385,22 @@
|
|
immediate | unsupported)
|
|
if test "$hardcode_direct" = no; then
|
|
add="$dir/$linklib"
|
|
+ case $host in
|
|
+ *-*-sco3.2v5* ) add_dir="-L$dir" ;;
|
|
+ *-*-darwin* )
|
|
+ # if the lib is a module then we can not link against
|
|
+ # it, someone is ignoring the new warnings I added
|
|
+ if /usr/bin/file -L $add 2> /dev/null | $EGREP "bundle" >/dev/null ; then
|
|
+ $echo "** Warning, lib $linklib is a module, not a shared library"
|
|
+ if test -z "$old_library" ; then
|
|
+ $echo
|
|
+ $echo "** And there doesn't seem to be a static archive available"
|
|
+ $echo "** The link will probably fail, sorry"
|
|
+ else
|
|
+ add="$dir/$old_library"
|
|
+ fi
|
|
+ fi
|
|
+ esac
|
|
elif test "$hardcode_minus_L" = no; then
|
|
case $host in
|
|
*-*-sunos*) add_shlibpath="$dir" ;;
|
|
@@ -1846,6 +2419,14 @@
|
|
add="$dir/$linklib"
|
|
elif test "$hardcode_minus_L" = yes; then
|
|
add_dir="-L$dir"
|
|
+ # Try looking first in the location we're being installed to.
|
|
+ if test -n "$inst_prefix_dir"; then
|
|
+ case "$libdir" in
|
|
+ [\\/]*)
|
|
+ add_dir="$add_dir -L$inst_prefix_dir$libdir"
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
add="-l$name"
|
|
elif test "$hardcode_shlibpath_var" = yes; then
|
|
add_shlibpath="$dir"
|
|
@@ -1859,7 +2440,7 @@
|
|
|
|
if test "$lib_linked" != yes; then
|
|
$echo "$modename: configuration error: unsupported hardcode properties"
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
if test -n "$add_shlibpath"; then
|
|
@@ -1868,7 +2449,7 @@
|
|
*) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;;
|
|
esac
|
|
fi
|
|
- if test $linkmode = prog; then
|
|
+ if test "$linkmode" = prog; then
|
|
test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs"
|
|
test -n "$add" && compile_deplibs="$add $compile_deplibs"
|
|
else
|
|
@@ -1885,7 +2466,7 @@
|
|
fi
|
|
fi
|
|
|
|
- if test $linkmode = prog || test "$mode" = relink; then
|
|
+ if test "$linkmode" = prog || test "$mode" = relink; then
|
|
add_shlibpath=
|
|
add_dir=
|
|
add=
|
|
@@ -1901,13 +2482,28 @@
|
|
*) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
|
|
esac
|
|
add="-l$name"
|
|
+ elif test "$hardcode_automatic" = yes; then
|
|
+ if test -n "$inst_prefix_dir" &&
|
|
+ test -f "$inst_prefix_dir$libdir/$linklib" ; then
|
|
+ add="$inst_prefix_dir$libdir/$linklib"
|
|
+ else
|
|
+ add="$libdir/$linklib"
|
|
+ fi
|
|
else
|
|
# We cannot seem to hardcode it, guess we'll fake it.
|
|
add_dir="-L$libdir"
|
|
+ # Try looking first in the location we're being installed to.
|
|
+ if test -n "$inst_prefix_dir"; then
|
|
+ case "$libdir" in
|
|
+ [\\/]*)
|
|
+ add_dir="$add_dir -L$inst_prefix_dir$libdir"
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
add="-l$name"
|
|
fi
|
|
|
|
- if test $linkmode = prog; then
|
|
+ if test "$linkmode" = prog; then
|
|
test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs"
|
|
test -n "$add" && finalize_deplibs="$add $finalize_deplibs"
|
|
else
|
|
@@ -1915,16 +2511,7 @@
|
|
test -n "$add" && deplibs="$add $deplibs"
|
|
fi
|
|
fi
|
|
- elif test $linkmode = prog; then
|
|
- if test "$alldeplibs" = yes &&
|
|
- { test "$deplibs_check_method" = pass_all ||
|
|
- { test "$build_libtool_libs" = yes &&
|
|
- test -n "$library_names"; }; }; then
|
|
- # We only need to search for static libraries
|
|
- continue
|
|
- fi
|
|
-
|
|
- # Try to link the static library
|
|
+ elif test "$linkmode" = prog; then
|
|
# Here we assume that one of hardcode_direct or hardcode_minus_L
|
|
# is not unsupported. This is valid on all known static and
|
|
# shared platforms.
|
|
@@ -1944,21 +2531,21 @@
|
|
|
|
# Just print a warning and add the library to dependency_libs so
|
|
# that the program can be linked against the static library.
|
|
- echo
|
|
- echo "*** Warning: This system can not link to static lib archive $lib."
|
|
- echo "*** I have the capability to make that library automatically link in when"
|
|
- echo "*** you link to this library. But I can only do this if you have a"
|
|
- echo "*** shared version of the library, which you do not appear to have."
|
|
+ $echo
|
|
+ $echo "*** Warning: This system can not link to static lib archive $lib."
|
|
+ $echo "*** I have the capability to make that library automatically link in when"
|
|
+ $echo "*** you link to this library. But I can only do this if you have a"
|
|
+ $echo "*** shared version of the library, which you do not appear to have."
|
|
if test "$module" = yes; then
|
|
- echo "*** But as you try to build a module library, libtool will still create "
|
|
- echo "*** a static module, that should work as long as the dlopening application"
|
|
- echo "*** is linked with the -dlopen flag to resolve symbols at runtime."
|
|
+ $echo "*** But as you try to build a module library, libtool will still create "
|
|
+ $echo "*** a static module, that should work as long as the dlopening application"
|
|
+ $echo "*** is linked with the -dlopen flag to resolve symbols at runtime."
|
|
if test -z "$global_symbol_pipe"; then
|
|
- echo
|
|
- echo "*** However, this would only work if libtool was able to extract symbol"
|
|
- echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
|
|
- echo "*** not find such a program. So, this module is probably useless."
|
|
- echo "*** \`nm' from GNU binutils and a full rebuild may help."
|
|
+ $echo
|
|
+ $echo "*** However, this would only work if libtool was able to extract symbol"
|
|
+ $echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
|
|
+ $echo "*** not find such a program. So, this module is probably useless."
|
|
+ $echo "*** \`nm' from GNU binutils and a full rebuild may help."
|
|
fi
|
|
if test "$build_old_libs" = no; then
|
|
build_libtool_libs=module
|
|
@@ -1975,10 +2562,11 @@
|
|
fi
|
|
fi # link shared/static library?
|
|
|
|
- if test $linkmode = lib; then
|
|
+ if test "$linkmode" = lib; then
|
|
if test -n "$dependency_libs" &&
|
|
- { test $hardcode_into_libs != yes || test $build_old_libs = yes ||
|
|
- test $link_static = yes; }; then
|
|
+ { test "$hardcode_into_libs" != yes ||
|
|
+ test "$build_old_libs" = yes ||
|
|
+ test "$link_static" = yes; }; then
|
|
# Extract -R from dependency_libs
|
|
temp_deplibs=
|
|
for libdir in $dependency_libs; do
|
|
@@ -2009,7 +2597,7 @@
|
|
tmp_libs="$tmp_libs $deplib"
|
|
done
|
|
|
|
- if test $link_all_deplibs != no; then
|
|
+ if test "$link_all_deplibs" != no; then
|
|
# Add the search paths of all dependency libraries
|
|
for deplib in $dependency_libs; do
|
|
case $deplib in
|
|
@@ -2029,22 +2617,67 @@
|
|
;;
|
|
esac
|
|
if grep "^installed=no" $deplib > /dev/null; then
|
|
- path="-L$absdir/$objdir"
|
|
+ path="$absdir/$objdir"
|
|
else
|
|
eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
|
|
if test -z "$libdir"; then
|
|
$echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
if test "$absdir" != "$libdir"; then
|
|
$echo "$modename: warning: \`$deplib' seems to be moved" 1>&2
|
|
fi
|
|
- path="-L$absdir"
|
|
+ path="$absdir"
|
|
fi
|
|
+ depdepl=
|
|
+ case $host in
|
|
+ *-*-darwin*)
|
|
+ # we do not want to link against static libs,
|
|
+ # but need to link against shared
|
|
+ eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
|
|
+ if test -n "$deplibrary_names" ; then
|
|
+ for tmp in $deplibrary_names ; do
|
|
+ depdepl=$tmp
|
|
+ done
|
|
+ if test -f "$path/$depdepl" ; then
|
|
+ depdepl="$path/$depdepl"
|
|
+ fi
|
|
+ # do not add paths which are already there
|
|
+ case " $newlib_search_path " in
|
|
+ *" $path "*) ;;
|
|
+ *) newlib_search_path="$newlib_search_path $path";;
|
|
+ esac
|
|
+ fi
|
|
+ path=""
|
|
+ ;;
|
|
+ *)
|
|
+ path="-L$path"
|
|
+ ;;
|
|
+ esac
|
|
+ ;;
|
|
+ -l*)
|
|
+ case $host in
|
|
+ *-*-darwin*)
|
|
+ # Again, we only want to link against shared libraries
|
|
+ eval tmp_libs=`$echo "X$deplib" | $Xsed -e "s,^\-l,,"`
|
|
+ for tmp in $newlib_search_path ; do
|
|
+ if test -f "$tmp/lib$tmp_libs.dylib" ; then
|
|
+ eval depdepl="$tmp/lib$tmp_libs.dylib"
|
|
+ break
|
|
+ fi
|
|
+ done
|
|
+ path=""
|
|
+ ;;
|
|
+ *) continue ;;
|
|
+ esac
|
|
;;
|
|
*) continue ;;
|
|
esac
|
|
case " $deplibs " in
|
|
+ *" $depdepl "*) ;;
|
|
+ *) deplibs="$depdepl $deplibs" ;;
|
|
+ esac
|
|
+ case " $deplibs " in
|
|
*" $path "*) ;;
|
|
*) deplibs="$deplibs $path" ;;
|
|
esac
|
|
@@ -2052,15 +2685,15 @@
|
|
fi # link_all_deplibs != no
|
|
fi # linkmode = lib
|
|
done # for deplib in $libs
|
|
- if test $pass = dlpreopen; then
|
|
+ dependency_libs="$newdependency_libs"
|
|
+ if test "$pass" = dlpreopen; then
|
|
# Link the dlpreopened libraries before other libraries
|
|
for deplib in $save_deplibs; do
|
|
deplibs="$deplib $deplibs"
|
|
done
|
|
fi
|
|
- if test $pass != dlopen; then
|
|
- test $pass != scan && dependency_libs="$newdependency_libs"
|
|
- if test $pass != conv; then
|
|
+ if test "$pass" != dlopen; then
|
|
+ if test "$pass" != conv; then
|
|
# Make sure lib_search_path contains only unique directories.
|
|
lib_search_path=
|
|
for dir in $newlib_search_path; do
|
|
@@ -2082,9 +2715,30 @@
|
|
eval tmp_libs=\"\$$var\"
|
|
new_libs=
|
|
for deplib in $tmp_libs; do
|
|
+ # FIXME: Pedantically, this is the right thing to do, so
|
|
+ # that some nasty dependency loop isn't accidentally
|
|
+ # broken:
|
|
+ #new_libs="$deplib $new_libs"
|
|
+ # Pragmatically, this seems to cause very few problems in
|
|
+ # practice:
|
|
case $deplib in
|
|
-L*) new_libs="$deplib $new_libs" ;;
|
|
+ -R*) ;;
|
|
*)
|
|
+ # And here is the reason: when a library appears more
|
|
+ # than once as an explicit dependence of a library, or
|
|
+ # is implicitly linked in more than once by the
|
|
+ # compiler, it is considered special, and multiple
|
|
+ # occurrences thereof are not removed. Compare this
|
|
+ # with having the same library being listed as a
|
|
+ # dependency of multiple other libraries: in this case,
|
|
+ # we know (pedantically, we assume) the library does not
|
|
+ # need to be listed more than once, so we keep only the
|
|
+ # last copy. This is not always right, but it is rare
|
|
+ # enough that we require users that really mean to play
|
|
+ # such unportable linking tricks to link the library
|
|
+ # using -Wl,-lname, so that libtool does not consider it
|
|
+ # for duplicate removal.
|
|
case " $specialdeplibs " in
|
|
*" $deplib "*) new_libs="$deplib $new_libs" ;;
|
|
*)
|
|
@@ -2112,19 +2766,32 @@
|
|
eval $var=\"$tmp_libs\"
|
|
done # for var
|
|
fi
|
|
- if test "$pass" = "conv" &&
|
|
- { test "$linkmode" = "lib" || test "$linkmode" = "prog"; }; then
|
|
- libs="$deplibs" # reset libs
|
|
- deplibs=
|
|
- fi
|
|
+ # Last step: remove runtime libs from dependency_libs
|
|
+ # (they stay in deplibs)
|
|
+ tmp_libs=
|
|
+ for i in $dependency_libs ; do
|
|
+ case " $predeps $postdeps $compiler_lib_search_path " in
|
|
+ *" $i "*)
|
|
+ i=""
|
|
+ ;;
|
|
+ esac
|
|
+ if test -n "$i" ; then
|
|
+ tmp_libs="$tmp_libs $i"
|
|
+ fi
|
|
+ done
|
|
+ dependency_libs=$tmp_libs
|
|
done # for pass
|
|
- if test $linkmode = prog; then
|
|
+ if test "$linkmode" = prog; then
|
|
dlfiles="$newdlfiles"
|
|
dlprefiles="$newdlprefiles"
|
|
fi
|
|
|
|
case $linkmode in
|
|
oldlib)
|
|
+ if test -n "$deplibs"; then
|
|
+ $echo "$modename: warning: \`-l' and \`-L' are ignored for archives" 1>&2
|
|
+ fi
|
|
+
|
|
if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
|
|
$echo "$modename: warning: \`-dlopen' is ignored for archives" 1>&2
|
|
fi
|
|
@@ -2138,7 +2805,7 @@
|
|
fi
|
|
|
|
if test -n "$vinfo"; then
|
|
- $echo "$modename: warning: \`-version-info' is ignored for archives" 1>&2
|
|
+ $echo "$modename: warning: \`-version-info/-version-number' is ignored for archives" 1>&2
|
|
fi
|
|
|
|
if test -n "$release"; then
|
|
@@ -2160,17 +2827,19 @@
|
|
case $outputname in
|
|
lib*)
|
|
name=`$echo "X$outputname" | $Xsed -e 's/\.la$//' -e 's/^lib//'`
|
|
+ eval shared_ext=\"$shrext_cmds\"
|
|
eval libname=\"$libname_spec\"
|
|
;;
|
|
*)
|
|
if test "$module" = no; then
|
|
$echo "$modename: libtool library \`$output' must begin with \`lib'" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
if test "$need_lib_prefix" != no; then
|
|
# Add the "lib" prefix for modules if required
|
|
name=`$echo "X$outputname" | $Xsed -e 's/\.la$//'`
|
|
+ eval shared_ext=\"$shrext_cmds\"
|
|
eval libname=\"$libname_spec\"
|
|
else
|
|
libname=`$echo "X$outputname" | $Xsed -e 's/\.la$//'`
|
|
@@ -2181,11 +2850,11 @@
|
|
if test -n "$objs"; then
|
|
if test "$deplibs_check_method" != pass_all; then
|
|
$echo "$modename: cannot build libtool library \`$output' from non-libtool objects on this host:$objs" 2>&1
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
else
|
|
- echo
|
|
- echo "*** Warning: Linking the shared library $output against the non-libtool"
|
|
- echo "*** objects $objs is not portable!"
|
|
+ $echo
|
|
+ $echo "*** Warning: Linking the shared library $output against the non-libtool"
|
|
+ $echo "*** objects $objs is not portable!"
|
|
libobjs="$libobjs $objs"
|
|
fi
|
|
fi
|
|
@@ -2195,7 +2864,7 @@
|
|
fi
|
|
|
|
set dummy $rpath
|
|
- if test $# -gt 2; then
|
|
+ if test "$#" -gt 2; then
|
|
$echo "$modename: warning: ignoring multiple \`-rpath's for a libtool library" 1>&2
|
|
fi
|
|
install_libdir="$2"
|
|
@@ -2204,14 +2873,16 @@
|
|
if test -z "$rpath"; then
|
|
if test "$build_libtool_libs" = yes; then
|
|
# Building a libtool convenience library.
|
|
- libext=al
|
|
+ # Some compilers have problems with a `.al' extension so
|
|
+ # convenience libraries should have the same extension an
|
|
+ # archive normally would.
|
|
oldlibs="$output_objdir/$libname.$libext $oldlibs"
|
|
build_libtool_libs=convenience
|
|
build_old_libs=yes
|
|
fi
|
|
|
|
if test -n "$vinfo"; then
|
|
- $echo "$modename: warning: \`-version-info' is ignored for convenience libraries" 1>&2
|
|
+ $echo "$modename: warning: \`-version-info/-version-number' is ignored for convenience libraries" 1>&2
|
|
fi
|
|
|
|
if test -n "$release"; then
|
|
@@ -2227,45 +2898,82 @@
|
|
if test -n "$8"; then
|
|
$echo "$modename: too many parameters to \`-version-info'" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
- current="$2"
|
|
- revision="$3"
|
|
- age="$4"
|
|
+ # convert absolute version numbers to libtool ages
|
|
+ # this retains compatibility with .la files and attempts
|
|
+ # to make the code below a bit more comprehensible
|
|
+
|
|
+ case $vinfo_number in
|
|
+ yes)
|
|
+ number_major="$2"
|
|
+ number_minor="$3"
|
|
+ number_revision="$4"
|
|
+ #
|
|
+ # There are really only two kinds -- those that
|
|
+ # use the current revision as the major version
|
|
+ # and those that subtract age and use age as
|
|
+ # a minor version. But, then there is irix
|
|
+ # which has an extra 1 added just for fun
|
|
+ #
|
|
+ case $version_type in
|
|
+ darwin|linux|osf|windows)
|
|
+ current=`expr $number_major + $number_minor`
|
|
+ age="$number_minor"
|
|
+ revision="$number_revision"
|
|
+ ;;
|
|
+ freebsd-aout|freebsd-elf|sunos)
|
|
+ current="$number_major"
|
|
+ revision="$number_minor"
|
|
+ age="0"
|
|
+ ;;
|
|
+ irix|nonstopux)
|
|
+ current=`expr $number_major + $number_minor - 1`
|
|
+ age="$number_minor"
|
|
+ revision="$number_minor"
|
|
+ ;;
|
|
+ esac
|
|
+ ;;
|
|
+ no)
|
|
+ current="$2"
|
|
+ revision="$3"
|
|
+ age="$4"
|
|
+ ;;
|
|
+ esac
|
|
|
|
# Check that each of the things are valid numbers.
|
|
case $current in
|
|
- 0 | [1-9] | [1-9][0-9] | [1-9][0-9][0-9]) ;;
|
|
+ [0-9]*) ;;
|
|
*)
|
|
$echo "$modename: CURRENT \`$current' is not a nonnegative integer" 1>&2
|
|
$echo "$modename: \`$vinfo' is not valid version information" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
case $revision in
|
|
- 0 | [1-9] | [1-9][0-9] | [1-9][0-9][0-9]) ;;
|
|
+ [0-9]*) ;;
|
|
*)
|
|
$echo "$modename: REVISION \`$revision' is not a nonnegative integer" 1>&2
|
|
$echo "$modename: \`$vinfo' is not valid version information" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
case $age in
|
|
- 0 | [1-9] | [1-9][0-9] | [1-9][0-9][0-9]) ;;
|
|
+ [0-9]*) ;;
|
|
*)
|
|
$echo "$modename: AGE \`$age' is not a nonnegative integer" 1>&2
|
|
$echo "$modename: \`$vinfo' is not valid version information" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
- if test $age -gt $current; then
|
|
+ if test "$age" -gt "$current"; then
|
|
$echo "$modename: AGE \`$age' is greater than the current interface number \`$current'" 1>&2
|
|
$echo "$modename: \`$vinfo' is not valid version information" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Calculate the version variables.
|
|
@@ -2306,7 +3014,7 @@
|
|
|
|
# Add in all the interfaces that we are compatible with.
|
|
loop=$revision
|
|
- while test $loop != 0; do
|
|
+ while test "$loop" -ne 0; do
|
|
iface=`expr $revision - $loop`
|
|
loop=`expr $loop - 1`
|
|
verstring="$verstring_prefix$major.$iface:$verstring"
|
|
@@ -2329,7 +3037,7 @@
|
|
|
|
# Add in all the interfaces that we are compatible with.
|
|
loop=$age
|
|
- while test $loop != 0; do
|
|
+ while test "$loop" -ne 0; do
|
|
iface=`expr $current - $loop`
|
|
loop=`expr $loop - 1`
|
|
verstring="$verstring:${iface}.0"
|
|
@@ -2353,20 +3061,19 @@
|
|
|
|
*)
|
|
$echo "$modename: unknown library version type \`$version_type'" 1>&2
|
|
- echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2
|
|
- exit 1
|
|
+ $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
# Clear the version info if we defaulted, and they specified a release.
|
|
if test -z "$vinfo" && test -n "$release"; then
|
|
major=
|
|
- verstring="0.0"
|
|
case $version_type in
|
|
darwin)
|
|
# we can't check for "0.0" in archive_cmds due to quoting
|
|
# problems, so we reset it completely
|
|
- verstring=""
|
|
+ verstring=
|
|
;;
|
|
*)
|
|
verstring="0.0"
|
|
@@ -2400,9 +3107,30 @@
|
|
fi
|
|
|
|
if test "$mode" != relink; then
|
|
- # Remove our outputs.
|
|
- $show "${rm}r $output_objdir/$outputname $output_objdir/$libname.* $output_objdir/${libname}${release}.*"
|
|
- $run ${rm}r $output_objdir/$outputname $output_objdir/$libname.* $output_objdir/${libname}${release}.*
|
|
+ # Remove our outputs, but don't remove object files since they
|
|
+ # may have been created when compiling PIC objects.
|
|
+ removelist=
|
|
+ tempremovelist=`$echo "$output_objdir/*"`
|
|
+ for p in $tempremovelist; do
|
|
+ case $p in
|
|
+ *.$objext)
|
|
+ ;;
|
|
+ $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*)
|
|
+ if test "X$precious_files_regex" != "X"; then
|
|
+ if echo $p | $EGREP -e "$precious_files_regex" >/dev/null 2>&1
|
|
+ then
|
|
+ continue
|
|
+ fi
|
|
+ fi
|
|
+ removelist="$removelist $p"
|
|
+ ;;
|
|
+ *) ;;
|
|
+ esac
|
|
+ done
|
|
+ if test -n "$removelist"; then
|
|
+ $show "${rm}r $removelist"
|
|
+ $run ${rm}r $removelist
|
|
+ fi
|
|
fi
|
|
|
|
# Now set the variables for building old libraries.
|
|
@@ -2415,9 +3143,9 @@
|
|
|
|
# Eliminate all temporary directories.
|
|
for path in $notinst_path; do
|
|
- lib_search_path=`echo "$lib_search_path " | ${SED} -e 's% $path % %g'`
|
|
- deplibs=`echo "$deplibs " | ${SED} -e 's% -L$path % %g'`
|
|
- dependency_libs=`echo "$dependency_libs " | ${SED} -e 's% -L$path % %g'`
|
|
+ lib_search_path=`$echo "$lib_search_path " | ${SED} -e 's% $path % %g'`
|
|
+ deplibs=`$echo "$deplibs " | ${SED} -e 's% -L$path % %g'`
|
|
+ dependency_libs=`$echo "$dependency_libs " | ${SED} -e 's% -L$path % %g'`
|
|
done
|
|
|
|
if test -n "$xrpath"; then
|
|
@@ -2430,7 +3158,7 @@
|
|
*) finalize_rpath="$finalize_rpath $libdir" ;;
|
|
esac
|
|
done
|
|
- if test $hardcode_into_libs != yes || test $build_old_libs = yes; then
|
|
+ if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then
|
|
dependency_libs="$temp_xrpath $dependency_libs"
|
|
fi
|
|
fi
|
|
@@ -2470,10 +3198,11 @@
|
|
;;
|
|
*-*-openbsd* | *-*-freebsd*)
|
|
# Do not include libc due to us having libc/libc_r.
|
|
+ test "X$arg" = "X-lc" && continue
|
|
;;
|
|
- *)
|
|
+ *)
|
|
# Add libc to deplibs on all other systems if necessary.
|
|
- if test $build_libtool_need_lc = "yes"; then
|
|
+ if test "$build_libtool_need_lc" = "yes"; then
|
|
deplibs="$deplibs -lc"
|
|
fi
|
|
;;
|
|
@@ -2500,7 +3229,7 @@
|
|
# This might be a little naive. We might want to check
|
|
# whether the library exists or not. But this is on
|
|
# osf3 & osf4 and I'm not really sure... Just
|
|
- # implementing what was already the behaviour.
|
|
+ # implementing what was already the behavior.
|
|
newdeplibs=$deplibs
|
|
;;
|
|
test_compile)
|
|
@@ -2513,68 +3242,88 @@
|
|
int main() { return 0; }
|
|
EOF
|
|
$rm conftest
|
|
- $CC -o conftest conftest.c $deplibs
|
|
- if test $? -eq 0 ; then
|
|
+ $LTCC -o conftest conftest.c $deplibs
|
|
+ if test "$?" -eq 0 ; then
|
|
ldd_output=`ldd conftest`
|
|
for i in $deplibs; do
|
|
name="`expr $i : '-l\(.*\)'`"
|
|
# If $name is empty we are operating on a -L argument.
|
|
- if test -n "$name" && test "$name" != "0"; then
|
|
- libname=`eval \\$echo \"$libname_spec\"`
|
|
- deplib_matches=`eval \\$echo \"$library_names_spec\"`
|
|
- set dummy $deplib_matches
|
|
- deplib_match=$2
|
|
- if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
|
|
- newdeplibs="$newdeplibs $i"
|
|
- else
|
|
- droppeddeps=yes
|
|
- echo
|
|
- echo "*** Warning: dynamic linker does not accept needed library $i."
|
|
- echo "*** I have the capability to make that library automatically link in when"
|
|
- echo "*** you link to this library. But I can only do this if you have a"
|
|
- echo "*** shared version of the library, which I believe you do not have"
|
|
- echo "*** because a test_compile did reveal that the linker did not use it for"
|
|
- echo "*** its dynamic dependency list that programs get resolved with at runtime."
|
|
+ if test "$name" != "" && test "$name" -ne "0"; then
|
|
+ if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
|
+ case " $predeps $postdeps " in
|
|
+ *" $i "*)
|
|
+ newdeplibs="$newdeplibs $i"
|
|
+ i=""
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
+ if test -n "$i" ; then
|
|
+ libname=`eval \\$echo \"$libname_spec\"`
|
|
+ deplib_matches=`eval \\$echo \"$library_names_spec\"`
|
|
+ set dummy $deplib_matches
|
|
+ deplib_match=$2
|
|
+ if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
|
|
+ newdeplibs="$newdeplibs $i"
|
|
+ else
|
|
+ droppeddeps=yes
|
|
+ $echo
|
|
+ $echo "*** Warning: dynamic linker does not accept needed library $i."
|
|
+ $echo "*** I have the capability to make that library automatically link in when"
|
|
+ $echo "*** you link to this library. But I can only do this if you have a"
|
|
+ $echo "*** shared version of the library, which I believe you do not have"
|
|
+ $echo "*** because a test_compile did reveal that the linker did not use it for"
|
|
+ $echo "*** its dynamic dependency list that programs get resolved with at runtime."
|
|
+ fi
|
|
fi
|
|
else
|
|
newdeplibs="$newdeplibs $i"
|
|
fi
|
|
done
|
|
else
|
|
- # Error occured in the first compile. Let's try to salvage
|
|
+ # Error occurred in the first compile. Let's try to salvage
|
|
# the situation: Compile a separate program for each library.
|
|
for i in $deplibs; do
|
|
name="`expr $i : '-l\(.*\)'`"
|
|
- # If $name is empty we are operating on a -L argument.
|
|
- if test -n "$name" && test "$name" != "0"; then
|
|
+ # If $name is empty we are operating on a -L argument.
|
|
+ if test "$name" != "" && test "$name" != "0"; then
|
|
$rm conftest
|
|
- $CC -o conftest conftest.c $i
|
|
+ $LTCC -o conftest conftest.c $i
|
|
# Did it work?
|
|
- if test $? -eq 0 ; then
|
|
+ if test "$?" -eq 0 ; then
|
|
ldd_output=`ldd conftest`
|
|
- libname=`eval \\$echo \"$libname_spec\"`
|
|
- deplib_matches=`eval \\$echo \"$library_names_spec\"`
|
|
- set dummy $deplib_matches
|
|
- deplib_match=$2
|
|
- if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
|
|
- newdeplibs="$newdeplibs $i"
|
|
- else
|
|
- droppeddeps=yes
|
|
- echo
|
|
- echo "*** Warning: dynamic linker does not accept needed library $i."
|
|
- echo "*** I have the capability to make that library automatically link in when"
|
|
- echo "*** you link to this library. But I can only do this if you have a"
|
|
- echo "*** shared version of the library, which you do not appear to have"
|
|
- echo "*** because a test_compile did reveal that the linker did not use this one"
|
|
- echo "*** as a dynamic dependency that programs can get resolved with at runtime."
|
|
+ if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
|
+ case " $predeps $postdeps " in
|
|
+ *" $i "*)
|
|
+ newdeplibs="$newdeplibs $i"
|
|
+ i=""
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
+ if test -n "$i" ; then
|
|
+ libname=`eval \\$echo \"$libname_spec\"`
|
|
+ deplib_matches=`eval \\$echo \"$library_names_spec\"`
|
|
+ set dummy $deplib_matches
|
|
+ deplib_match=$2
|
|
+ if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
|
|
+ newdeplibs="$newdeplibs $i"
|
|
+ else
|
|
+ droppeddeps=yes
|
|
+ $echo
|
|
+ $echo "*** Warning: dynamic linker does not accept needed library $i."
|
|
+ $echo "*** I have the capability to make that library automatically link in when"
|
|
+ $echo "*** you link to this library. But I can only do this if you have a"
|
|
+ $echo "*** shared version of the library, which you do not appear to have"
|
|
+ $echo "*** because a test_compile did reveal that the linker did not use this one"
|
|
+ $echo "*** as a dynamic dependency that programs can get resolved with at runtime."
|
|
+ fi
|
|
fi
|
|
else
|
|
droppeddeps=yes
|
|
- echo
|
|
- echo "*** Warning! Library $i is needed by this library but I was not able to"
|
|
- echo "*** make it link in! You will probably need to install it or some"
|
|
- echo "*** library that it depends on before this library will be fully"
|
|
- echo "*** functional. Installing it before continuing would be even better."
|
|
+ $echo
|
|
+ $echo "*** Warning! Library $i is needed by this library but I was not able to"
|
|
+ $echo "*** make it link in! You will probably need to install it or some"
|
|
+ $echo "*** library that it depends on before this library will be fully"
|
|
+ $echo "*** functional. Installing it before continuing would be even better."
|
|
fi
|
|
else
|
|
newdeplibs="$newdeplibs $i"
|
|
@@ -2588,11 +3337,20 @@
|
|
for a_deplib in $deplibs; do
|
|
name="`expr $a_deplib : '-l\(.*\)'`"
|
|
# If $name is empty we are operating on a -L argument.
|
|
- if test -n "$name" && test "$name" != "0"; then
|
|
- libname=`eval \\$echo \"$libname_spec\"`
|
|
- for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
|
|
- potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
|
|
- for potent_lib in $potential_libs; do
|
|
+ if test "$name" != "" && test "$name" != "0"; then
|
|
+ if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
|
+ case " $predeps $postdeps " in
|
|
+ *" $a_deplib "*)
|
|
+ newdeplibs="$newdeplibs $a_deplib"
|
|
+ a_deplib=""
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
+ if test -n "$a_deplib" ; then
|
|
+ libname=`eval \\$echo \"$libname_spec\"`
|
|
+ for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
|
|
+ potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
|
|
+ for potent_lib in $potential_libs; do
|
|
# Follow soft links.
|
|
if ls -lLd "$potent_lib" 2>/dev/null \
|
|
| grep " -> " >/dev/null; then
|
|
@@ -2613,26 +3371,27 @@
|
|
done
|
|
if eval $file_magic_cmd \"\$potlib\" 2>/dev/null \
|
|
| ${SED} 10q \
|
|
- | egrep "$file_magic_regex" > /dev/null; then
|
|
+ | $EGREP "$file_magic_regex" > /dev/null; then
|
|
newdeplibs="$newdeplibs $a_deplib"
|
|
a_deplib=""
|
|
break 2
|
|
fi
|
|
- done
|
|
- done
|
|
+ done
|
|
+ done
|
|
+ fi
|
|
if test -n "$a_deplib" ; then
|
|
droppeddeps=yes
|
|
- echo
|
|
- echo "*** Warning: linker path does not have real file for library $a_deplib."
|
|
- echo "*** I have the capability to make that library automatically link in when"
|
|
- echo "*** you link to this library. But I can only do this if you have a"
|
|
- echo "*** shared version of the library, which you do not appear to have"
|
|
- echo "*** because I did check the linker path looking for a file starting"
|
|
+ $echo
|
|
+ $echo "*** Warning: linker path does not have real file for library $a_deplib."
|
|
+ $echo "*** I have the capability to make that library automatically link in when"
|
|
+ $echo "*** you link to this library. But I can only do this if you have a"
|
|
+ $echo "*** shared version of the library, which you do not appear to have"
|
|
+ $echo "*** because I did check the linker path looking for a file starting"
|
|
if test -z "$potlib" ; then
|
|
- echo "*** with $libname but no candidates were found. (...for file magic test)"
|
|
+ $echo "*** with $libname but no candidates were found. (...for file magic test)"
|
|
else
|
|
- echo "*** with $libname and none of the candidates passed a file format test"
|
|
- echo "*** using a file magic. Last file checked: $potlib"
|
|
+ $echo "*** with $libname and none of the candidates passed a file format test"
|
|
+ $echo "*** using a file magic. Last file checked: $potlib"
|
|
fi
|
|
fi
|
|
else
|
|
@@ -2648,33 +3407,43 @@
|
|
name="`expr $a_deplib : '-l\(.*\)'`"
|
|
# If $name is empty we are operating on a -L argument.
|
|
if test -n "$name" && test "$name" != "0"; then
|
|
- libname=`eval \\$echo \"$libname_spec\"`
|
|
- for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
|
|
- potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
|
|
- for potent_lib in $potential_libs; do
|
|
- potlib="$potent_lib" # see symlink-check below in file_magic test
|
|
- if eval echo \"$potent_lib\" 2>/dev/null \
|
|
- | ${SED} 10q \
|
|
- | egrep "$match_pattern_regex" > /dev/null; then
|
|
- newdeplibs="$newdeplibs $a_deplib"
|
|
- a_deplib=""
|
|
- break 2
|
|
- fi
|
|
+ if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
|
+ case " $predeps $postdeps " in
|
|
+ *" $a_deplib "*)
|
|
+ newdeplibs="$newdeplibs $a_deplib"
|
|
+ a_deplib=""
|
|
+ ;;
|
|
+ esac
|
|
+ fi
|
|
+ if test -n "$a_deplib" ; then
|
|
+ libname=`eval \\$echo \"$libname_spec\"`
|
|
+ for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
|
|
+ potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
|
|
+ for potent_lib in $potential_libs; do
|
|
+ potlib="$potent_lib" # see symlink-check above in file_magic test
|
|
+ if eval $echo \"$potent_lib\" 2>/dev/null \
|
|
+ | ${SED} 10q \
|
|
+ | $EGREP "$match_pattern_regex" > /dev/null; then
|
|
+ newdeplibs="$newdeplibs $a_deplib"
|
|
+ a_deplib=""
|
|
+ break 2
|
|
+ fi
|
|
+ done
|
|
done
|
|
- done
|
|
+ fi
|
|
if test -n "$a_deplib" ; then
|
|
droppeddeps=yes
|
|
- echo
|
|
- echo "*** Warning: linker path does not have real file for library $a_deplib."
|
|
- echo "*** I have the capability to make that library automatically link in when"
|
|
- echo "*** you link to this library. But I can only do this if you have a"
|
|
- echo "*** shared version of the library, which you do not appear to have"
|
|
- echo "*** because I did check the linker path looking for a file starting"
|
|
+ $echo
|
|
+ $echo "*** Warning: linker path does not have real file for library $a_deplib."
|
|
+ $echo "*** I have the capability to make that library automatically link in when"
|
|
+ $echo "*** you link to this library. But I can only do this if you have a"
|
|
+ $echo "*** shared version of the library, which you do not appear to have"
|
|
+ $echo "*** because I did check the linker path looking for a file starting"
|
|
if test -z "$potlib" ; then
|
|
- echo "*** with $libname but no candidates were found. (...for regex pattern test)"
|
|
+ $echo "*** with $libname but no candidates were found. (...for regex pattern test)"
|
|
else
|
|
- echo "*** with $libname and none of the candidates passed a file format test"
|
|
- echo "*** using a regex pattern. Last file checked: $potlib"
|
|
+ $echo "*** with $libname and none of the candidates passed a file format test"
|
|
+ $echo "*** using a regex pattern. Last file checked: $potlib"
|
|
fi
|
|
fi
|
|
else
|
|
@@ -2685,16 +3454,23 @@
|
|
;;
|
|
none | unknown | *)
|
|
newdeplibs=""
|
|
- if $echo "X $deplibs" | $Xsed -e 's/ -lc$//' \
|
|
- -e 's/ -[LR][^ ]*//g' -e 's/[ ]//g' |
|
|
- grep . >/dev/null; then
|
|
- echo
|
|
+ tmp_deplibs=`$echo "X $deplibs" | $Xsed -e 's/ -lc$//' \
|
|
+ -e 's/ -[LR][^ ]*//g'`
|
|
+ if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
|
+ for i in $predeps $postdeps ; do
|
|
+ # can't use Xsed below, because $i might contain '/'
|
|
+ tmp_deplibs=`$echo "X $tmp_deplibs" | ${SED} -e "1s,^X,," -e "s,$i,,"`
|
|
+ done
|
|
+ fi
|
|
+ if $echo "X $tmp_deplibs" | $Xsed -e 's/[ ]//g' \
|
|
+ | grep . >/dev/null; then
|
|
+ $echo
|
|
if test "X$deplibs_check_method" = "Xnone"; then
|
|
- echo "*** Warning: inter-library dependencies are not supported in this platform."
|
|
+ $echo "*** Warning: inter-library dependencies are not supported in this platform."
|
|
else
|
|
- echo "*** Warning: inter-library dependencies are not known to be supported."
|
|
+ $echo "*** Warning: inter-library dependencies are not known to be supported."
|
|
fi
|
|
- echo "*** All declared inter-library dependencies are being dropped."
|
|
+ $echo "*** All declared inter-library dependencies are being dropped."
|
|
droppeddeps=yes
|
|
fi
|
|
;;
|
|
@@ -2714,17 +3490,17 @@
|
|
|
|
if test "$droppeddeps" = yes; then
|
|
if test "$module" = yes; then
|
|
- echo
|
|
- echo "*** Warning: libtool could not satisfy all declared inter-library"
|
|
- echo "*** dependencies of module $libname. Therefore, libtool will create"
|
|
- echo "*** a static module, that should work as long as the dlopening"
|
|
- echo "*** application is linked with the -dlopen flag."
|
|
+ $echo
|
|
+ $echo "*** Warning: libtool could not satisfy all declared inter-library"
|
|
+ $echo "*** dependencies of module $libname. Therefore, libtool will create"
|
|
+ $echo "*** a static module, that should work as long as the dlopening"
|
|
+ $echo "*** application is linked with the -dlopen flag."
|
|
if test -z "$global_symbol_pipe"; then
|
|
- echo
|
|
- echo "*** However, this would only work if libtool was able to extract symbol"
|
|
- echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
|
|
- echo "*** not find such a program. So, this module is probably useless."
|
|
- echo "*** \`nm' from GNU binutils and a full rebuild may help."
|
|
+ $echo
|
|
+ $echo "*** However, this would only work if libtool was able to extract symbol"
|
|
+ $echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
|
|
+ $echo "*** not find such a program. So, this module is probably useless."
|
|
+ $echo "*** \`nm' from GNU binutils and a full rebuild may help."
|
|
fi
|
|
if test "$build_old_libs" = no; then
|
|
oldlibs="$output_objdir/$libname.$libext"
|
|
@@ -2734,16 +3510,16 @@
|
|
build_libtool_libs=no
|
|
fi
|
|
else
|
|
- echo "*** The inter-library dependencies that have been dropped here will be"
|
|
- echo "*** automatically added whenever a program is linked with this library"
|
|
- echo "*** or is declared to -dlopen it."
|
|
-
|
|
- if test $allow_undefined = no; then
|
|
- echo
|
|
- echo "*** Since this library must not contain undefined symbols,"
|
|
- echo "*** because either the platform does not support them or"
|
|
- echo "*** it was explicitly requested with -no-undefined,"
|
|
- echo "*** libtool will only create a static version of it."
|
|
+ $echo "*** The inter-library dependencies that have been dropped here will be"
|
|
+ $echo "*** automatically added whenever a program is linked with this library"
|
|
+ $echo "*** or is declared to -dlopen it."
|
|
+
|
|
+ if test "$allow_undefined" = no; then
|
|
+ $echo
|
|
+ $echo "*** Since this library must not contain undefined symbols,"
|
|
+ $echo "*** because either the platform does not support them or"
|
|
+ $echo "*** it was explicitly requested with -no-undefined,"
|
|
+ $echo "*** libtool will only create a static version of it."
|
|
if test "$build_old_libs" = no; then
|
|
oldlibs="$output_objdir/$libname.$libext"
|
|
build_libtool_libs=module
|
|
@@ -2765,7 +3541,7 @@
|
|
|
|
# Test again, we may have decided not to build it any more
|
|
if test "$build_libtool_libs" = yes; then
|
|
- if test $hardcode_into_libs = yes; then
|
|
+ if test "$hardcode_into_libs" = yes; then
|
|
# Hardcode the library paths
|
|
hardcode_libdirs=
|
|
dep_rpath=
|
|
@@ -2801,7 +3577,11 @@
|
|
if test -n "$hardcode_libdir_separator" &&
|
|
test -n "$hardcode_libdirs"; then
|
|
libdir="$hardcode_libdirs"
|
|
- eval dep_rpath=\"$hardcode_libdir_flag_spec\"
|
|
+ if test -n "$hardcode_libdir_flag_spec_ld"; then
|
|
+ eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\"
|
|
+ else
|
|
+ eval dep_rpath=\"$hardcode_libdir_flag_spec\"
|
|
+ fi
|
|
fi
|
|
if test -n "$runpath_var" && test -n "$perm_rpath"; then
|
|
# We should set the runpath_var.
|
|
@@ -2821,6 +3601,7 @@
|
|
fi
|
|
|
|
# Get the real and link names of the library.
|
|
+ eval shared_ext=\"$shrext_cmds\"
|
|
eval library_names=\"$library_names_spec\"
|
|
set dummy $library_names
|
|
realname="$2"
|
|
@@ -2831,7 +3612,9 @@
|
|
else
|
|
soname="$realname"
|
|
fi
|
|
- test -z "$dlname" && dlname=$soname
|
|
+ if test -z "$dlname"; then
|
|
+ dlname=$soname
|
|
+ fi
|
|
|
|
lib="$output_objdir/$realname"
|
|
for link
|
|
@@ -2839,23 +3622,6 @@
|
|
linknames="$linknames $link"
|
|
done
|
|
|
|
- # Ensure that we have .o objects for linkers which dislike .lo
|
|
- # (e.g. aix) in case we are running --disable-static
|
|
- for obj in $libobjs; do
|
|
- xdir=`$echo "X$obj" | $Xsed -e 's%/[^/]*$%%'`
|
|
- if test "X$xdir" = "X$obj"; then
|
|
- xdir="."
|
|
- else
|
|
- xdir="$xdir"
|
|
- fi
|
|
- baseobj=`$echo "X$obj" | $Xsed -e 's%^.*/%%'`
|
|
- oldobj=`$echo "X$baseobj" | $Xsed -e "$lo2o"`
|
|
- if test ! -f $xdir/$oldobj; then
|
|
- $show "(cd $xdir && ${LN_S} $baseobj $oldobj)"
|
|
- $run eval '(cd $xdir && ${LN_S} $baseobj $oldobj)' || exit $?
|
|
- fi
|
|
- done
|
|
-
|
|
# Use standard objects if they are pic
|
|
test -z "$pic_flag" && libobjs=`$echo "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
|
|
|
|
@@ -2865,17 +3631,26 @@
|
|
$show "generating symbol list for \`$libname.la'"
|
|
export_symbols="$output_objdir/$libname.exp"
|
|
$run $rm $export_symbols
|
|
- eval cmds=\"$export_symbols_cmds\"
|
|
+ cmds=$export_symbols_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
- $show "$cmd"
|
|
- $run eval "$cmd" || exit $?
|
|
+ eval cmd=\"$cmd\"
|
|
+ if len=`expr "X$cmd" : ".*"` &&
|
|
+ test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
|
|
+ $show "$cmd"
|
|
+ $run eval "$cmd" || exit $?
|
|
+ skipped_export=false
|
|
+ else
|
|
+ # The command line is too long to execute in one step.
|
|
+ $show "using reloadable object file for export list..."
|
|
+ skipped_export=:
|
|
+ fi
|
|
done
|
|
IFS="$save_ifs"
|
|
if test -n "$export_symbols_regex"; then
|
|
- $show "egrep -e \"$export_symbols_regex\" \"$export_symbols\" > \"${export_symbols}T\""
|
|
- $run eval 'egrep -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
|
|
+ $show "$EGREP -e \"$export_symbols_regex\" \"$export_symbols\" > \"${export_symbols}T\""
|
|
+ $run eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
|
|
$show "$mv \"${export_symbols}T\" \"$export_symbols\""
|
|
$run eval '$mv "${export_symbols}T" "$export_symbols"'
|
|
fi
|
|
@@ -2886,17 +3661,29 @@
|
|
$run eval '$echo "X$include_expsyms" | $SP2NL >> "$export_symbols"'
|
|
fi
|
|
|
|
+ tmp_deplibs=
|
|
+ for test_deplib in $deplibs; do
|
|
+ case " $convenience " in
|
|
+ *" $test_deplib "*) ;;
|
|
+ *)
|
|
+ tmp_deplibs="$tmp_deplibs $test_deplib"
|
|
+ ;;
|
|
+ esac
|
|
+ done
|
|
+ deplibs="$tmp_deplibs"
|
|
+
|
|
if test -n "$convenience"; then
|
|
if test -n "$whole_archive_flag_spec"; then
|
|
+ save_libobjs=$libobjs
|
|
eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
|
|
else
|
|
gentop="$output_objdir/${outputname}x"
|
|
$show "${rm}r $gentop"
|
|
$run ${rm}r "$gentop"
|
|
- $show "mkdir $gentop"
|
|
- $run mkdir "$gentop"
|
|
+ $show "$mkdir $gentop"
|
|
+ $run $mkdir "$gentop"
|
|
status=$?
|
|
- if test $status -ne 0 && test ! -d "$gentop"; then
|
|
+ if test "$status" -ne 0 && test ! -d "$gentop"; then
|
|
exit $status
|
|
fi
|
|
generated="$generated $gentop"
|
|
@@ -2912,16 +3699,42 @@
|
|
|
|
$show "${rm}r $xdir"
|
|
$run ${rm}r "$xdir"
|
|
- $show "mkdir $xdir"
|
|
- $run mkdir "$xdir"
|
|
+ $show "$mkdir $xdir"
|
|
+ $run $mkdir "$xdir"
|
|
status=$?
|
|
- if test $status -ne 0 && test ! -d "$xdir"; then
|
|
+ if test "$status" -ne 0 && test ! -d "$xdir"; then
|
|
exit $status
|
|
fi
|
|
+ # We will extract separately just the conflicting names and we will no
|
|
+ # longer touch any unique names. It is faster to leave these extract
|
|
+ # automatically by $AR in one run.
|
|
$show "(cd $xdir && $AR x $xabs)"
|
|
$run eval "(cd \$xdir && $AR x \$xabs)" || exit $?
|
|
+ if ($AR t "$xabs" | sort | sort -uc >/dev/null 2>&1); then
|
|
+ :
|
|
+ else
|
|
+ $echo "$modename: warning: object name conflicts; renaming object files" 1>&2
|
|
+ $echo "$modename: warning: to ensure that they will not overwrite" 1>&2
|
|
+ $AR t "$xabs" | sort | uniq -cd | while read -r count name
|
|
+ do
|
|
+ i=1
|
|
+ while test "$i" -le "$count"
|
|
+ do
|
|
+ # Put our $i before any first dot (extension)
|
|
+ # Never overwrite any file
|
|
+ name_to="$name"
|
|
+ while test "X$name_to" = "X$name" || test -f "$xdir/$name_to"
|
|
+ do
|
|
+ name_to=`$echo "X$name_to" | $Xsed -e "s/\([^.]*\)/\1-$i/"`
|
|
+ done
|
|
+ $show "(cd $xdir && $AR xN $i $xabs '$name' && $mv '$name' '$name_to')"
|
|
+ $run eval "(cd \$xdir && $AR xN $i \$xabs '$name' && $mv '$name' '$name_to')" || exit $?
|
|
+ i=`expr $i + 1`
|
|
+ done
|
|
+ done
|
|
+ fi
|
|
|
|
- libobjs="$libobjs "`find $xdir -name \*.o -print -o -name \*.lo -print | $NL2SP`
|
|
+ libobjs="$libobjs "`find $xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP`
|
|
done
|
|
fi
|
|
fi
|
|
@@ -2937,25 +3750,147 @@
|
|
fi
|
|
|
|
# Do each of the archive commands.
|
|
+ if test "$module" = yes && test -n "$module_cmds" ; then
|
|
+ if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
|
|
+ eval test_cmds=\"$module_expsym_cmds\"
|
|
+ cmds=$module_expsym_cmds
|
|
+ else
|
|
+ eval test_cmds=\"$module_cmds\"
|
|
+ cmds=$module_cmds
|
|
+ fi
|
|
+ else
|
|
if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
|
|
- eval cmds=\"$archive_expsym_cmds\"
|
|
+ eval test_cmds=\"$archive_expsym_cmds\"
|
|
+ cmds=$archive_expsym_cmds
|
|
+ else
|
|
+ eval test_cmds=\"$archive_cmds\"
|
|
+ cmds=$archive_cmds
|
|
+ fi
|
|
+ fi
|
|
+
|
|
+ if test "X$skipped_export" != "X:" && len=`expr "X$test_cmds" : ".*"` &&
|
|
+ test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
|
|
+ :
|
|
else
|
|
- save_deplibs="$deplibs"
|
|
- for conv in $convenience; do
|
|
- tmp_deplibs=
|
|
- for test_deplib in $deplibs; do
|
|
- if test "$test_deplib" != "$conv"; then
|
|
- tmp_deplibs="$tmp_deplibs $test_deplib"
|
|
+ # The command line is too long to link in one step, link piecewise.
|
|
+ $echo "creating reloadable object files..."
|
|
+
|
|
+ # Save the value of $output and $libobjs because we want to
|
|
+ # use them later. If we have whole_archive_flag_spec, we
|
|
+ # want to use save_libobjs as it was before
|
|
+ # whole_archive_flag_spec was expanded, because we can't
|
|
+ # assume the linker understands whole_archive_flag_spec.
|
|
+ # This may have to be revisited, in case too many
|
|
+ # convenience libraries get linked in and end up exceeding
|
|
+ # the spec.
|
|
+ if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then
|
|
+ save_libobjs=$libobjs
|
|
+ fi
|
|
+ save_output=$output
|
|
+
|
|
+ # Clear the reloadable object creation command queue and
|
|
+ # initialize k to one.
|
|
+ test_cmds=
|
|
+ concat_cmds=
|
|
+ objlist=
|
|
+ delfiles=
|
|
+ last_robj=
|
|
+ k=1
|
|
+ output=$output_objdir/$save_output-${k}.$objext
|
|
+ # Loop over the list of objects to be linked.
|
|
+ for obj in $save_libobjs
|
|
+ do
|
|
+ eval test_cmds=\"$reload_cmds $objlist $last_robj\"
|
|
+ if test "X$objlist" = X ||
|
|
+ { len=`expr "X$test_cmds" : ".*"` &&
|
|
+ test "$len" -le "$max_cmd_len"; }; then
|
|
+ objlist="$objlist $obj"
|
|
+ else
|
|
+ # The command $test_cmds is almost too long, add a
|
|
+ # command to the queue.
|
|
+ if test "$k" -eq 1 ; then
|
|
+ # The first file doesn't have a previous command to add.
|
|
+ eval concat_cmds=\"$reload_cmds $objlist $last_robj\"
|
|
+ else
|
|
+ # All subsequent reloadable object files will link in
|
|
+ # the last one created.
|
|
+ eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj\"
|
|
fi
|
|
- done
|
|
- deplibs="$tmp_deplibs"
|
|
+ last_robj=$output_objdir/$save_output-${k}.$objext
|
|
+ k=`expr $k + 1`
|
|
+ output=$output_objdir/$save_output-${k}.$objext
|
|
+ objlist=$obj
|
|
+ len=1
|
|
+ fi
|
|
+ done
|
|
+ # Handle the remaining objects by creating one last
|
|
+ # reloadable object file. All subsequent reloadable object
|
|
+ # files will link in the last one created.
|
|
+ test -z "$concat_cmds" || concat_cmds=$concat_cmds~
|
|
+ eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\"
|
|
+
|
|
+ if ${skipped_export-false}; then
|
|
+ $show "generating symbol list for \`$libname.la'"
|
|
+ export_symbols="$output_objdir/$libname.exp"
|
|
+ $run $rm $export_symbols
|
|
+ libobjs=$output
|
|
+ # Append the command to create the export file.
|
|
+ eval concat_cmds=\"\$concat_cmds~$export_symbols_cmds\"
|
|
+ fi
|
|
+
|
|
+ # Set up a command to remove the reloadale object files
|
|
+ # after they are used.
|
|
+ i=0
|
|
+ while test "$i" -lt "$k"
|
|
+ do
|
|
+ i=`expr $i + 1`
|
|
+ delfiles="$delfiles $output_objdir/$save_output-${i}.$objext"
|
|
+ done
|
|
+
|
|
+ $echo "creating a temporary reloadable object file: $output"
|
|
+
|
|
+ # Loop through the commands generated above and execute them.
|
|
+ save_ifs="$IFS"; IFS='~'
|
|
+ for cmd in $concat_cmds; do
|
|
+ IFS="$save_ifs"
|
|
+ $show "$cmd"
|
|
+ $run eval "$cmd" || exit $?
|
|
done
|
|
- eval cmds=\"$archive_cmds\"
|
|
- deplibs="$save_deplibs"
|
|
+ IFS="$save_ifs"
|
|
+
|
|
+ libobjs=$output
|
|
+ # Restore the value of output.
|
|
+ output=$save_output
|
|
+
|
|
+ if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then
|
|
+ eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
|
|
+ fi
|
|
+ # Expand the library linking commands again to reset the
|
|
+ # value of $libobjs for piecewise linking.
|
|
+
|
|
+ # Do each of the archive commands.
|
|
+ if test "$module" = yes && test -n "$module_cmds" ; then
|
|
+ if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
|
|
+ cmds=$module_expsym_cmds
|
|
+ else
|
|
+ cmds=$module_cmds
|
|
+ fi
|
|
+ else
|
|
+ if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
|
|
+ cmds=$archive_expsym_cmds
|
|
+ else
|
|
+ cmds=$archive_cmds
|
|
+ fi
|
|
+ fi
|
|
+
|
|
+ # Append the command to remove the reloadable object files
|
|
+ # to the just-reset $cmds.
|
|
+ eval cmds=\"\$cmds~\$rm $delfiles\"
|
|
fi
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
done
|
|
@@ -2964,7 +3899,7 @@
|
|
# Restore the uninstalled library and exit
|
|
if test "$mode" = relink; then
|
|
$run eval '(cd $output_objdir && $rm ${realname}T && $mv $realname ${realname}T && $mv "$realname"U $realname)' || exit $?
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
fi
|
|
|
|
# Create links to the real library.
|
|
@@ -3012,7 +3947,7 @@
|
|
*.lo)
|
|
if test -n "$objs$old_deplibs"; then
|
|
$echo "$modename: cannot build library object \`$output' from non-libtool objects" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
libobj="$output"
|
|
obj=`$echo "X$output" | $Xsed -e "$lo2o"`
|
|
@@ -3043,10 +3978,10 @@
|
|
gentop="$output_objdir/${obj}x"
|
|
$show "${rm}r $gentop"
|
|
$run ${rm}r "$gentop"
|
|
- $show "mkdir $gentop"
|
|
- $run mkdir "$gentop"
|
|
+ $show "$mkdir $gentop"
|
|
+ $run $mkdir "$gentop"
|
|
status=$?
|
|
- if test $status -ne 0 && test ! -d "$gentop"; then
|
|
+ if test "$status" -ne 0 && test ! -d "$gentop"; then
|
|
exit $status
|
|
fi
|
|
generated="$generated $gentop"
|
|
@@ -3062,16 +3997,42 @@
|
|
|
|
$show "${rm}r $xdir"
|
|
$run ${rm}r "$xdir"
|
|
- $show "mkdir $xdir"
|
|
- $run mkdir "$xdir"
|
|
+ $show "$mkdir $xdir"
|
|
+ $run $mkdir "$xdir"
|
|
status=$?
|
|
- if test $status -ne 0 && test ! -d "$xdir"; then
|
|
+ if test "$status" -ne 0 && test ! -d "$xdir"; then
|
|
exit $status
|
|
fi
|
|
+ # We will extract separately just the conflicting names and we will no
|
|
+ # longer touch any unique names. It is faster to leave these extract
|
|
+ # automatically by $AR in one run.
|
|
$show "(cd $xdir && $AR x $xabs)"
|
|
$run eval "(cd \$xdir && $AR x \$xabs)" || exit $?
|
|
+ if ($AR t "$xabs" | sort | sort -uc >/dev/null 2>&1); then
|
|
+ :
|
|
+ else
|
|
+ $echo "$modename: warning: object name conflicts; renaming object files" 1>&2
|
|
+ $echo "$modename: warning: to ensure that they will not overwrite" 1>&2
|
|
+ $AR t "$xabs" | sort | uniq -cd | while read -r count name
|
|
+ do
|
|
+ i=1
|
|
+ while test "$i" -le "$count"
|
|
+ do
|
|
+ # Put our $i before any first dot (extension)
|
|
+ # Never overwrite any file
|
|
+ name_to="$name"
|
|
+ while test "X$name_to" = "X$name" || test -f "$xdir/$name_to"
|
|
+ do
|
|
+ name_to=`$echo "X$name_to" | $Xsed -e "s/\([^.]*\)/\1-$i/"`
|
|
+ done
|
|
+ $show "(cd $xdir && $AR xN $i $xabs '$name' && $mv '$name' '$name_to')"
|
|
+ $run eval "(cd \$xdir && $AR xN $i \$xabs '$name' && $mv '$name' '$name_to')" || exit $?
|
|
+ i=`expr $i + 1`
|
|
+ done
|
|
+ done
|
|
+ fi
|
|
|
|
- reload_conv_objs="$reload_objs "`find $xdir -name \*.o -print -o -name \*.lo -print | $NL2SP`
|
|
+ reload_conv_objs="$reload_objs "`find $xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP`
|
|
done
|
|
fi
|
|
fi
|
|
@@ -3080,10 +4041,11 @@
|
|
reload_objs="$objs$old_deplibs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test
|
|
|
|
output="$obj"
|
|
- eval cmds=\"$reload_cmds\"
|
|
+ cmds=$reload_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
done
|
|
@@ -3096,7 +4058,7 @@
|
|
$run ${rm}r $gentop
|
|
fi
|
|
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
fi
|
|
|
|
if test "$build_libtool_libs" != yes; then
|
|
@@ -3107,37 +4069,24 @@
|
|
|
|
# Create an invalid libtool object if no PIC, so that we don't
|
|
# accidentally link it into a program.
|
|
- $show "echo timestamp > $libobj"
|
|
- $run eval "echo timestamp > $libobj" || exit $?
|
|
- exit 0
|
|
+ # $show "echo timestamp > $libobj"
|
|
+ # $run eval "echo timestamp > $libobj" || exit $?
|
|
+ exit $EXIT_SUCCESS
|
|
fi
|
|
|
|
if test -n "$pic_flag" || test "$pic_mode" != default; then
|
|
# Only do commands if we really have different PIC objects.
|
|
reload_objs="$libobjs $reload_conv_objs"
|
|
output="$libobj"
|
|
- eval cmds=\"$reload_cmds\"
|
|
+ cmds=$reload_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
done
|
|
IFS="$save_ifs"
|
|
- else
|
|
- # Just create a symlink.
|
|
- $show $rm $libobj
|
|
- $run $rm $libobj
|
|
- xdir=`$echo "X$libobj" | $Xsed -e 's%/[^/]*$%%'`
|
|
- if test "X$xdir" = "X$libobj"; then
|
|
- xdir="."
|
|
- else
|
|
- xdir="$xdir"
|
|
- fi
|
|
- baseobj=`$echo "X$libobj" | $Xsed -e 's%^.*/%%'`
|
|
- oldobj=`$echo "X$baseobj" | $Xsed -e "$lo2o"`
|
|
- $show "(cd $xdir && $LN_S $oldobj $baseobj)"
|
|
- $run eval '(cd $xdir && $LN_S $oldobj $baseobj)' || exit $?
|
|
fi
|
|
|
|
if test -n "$gentop"; then
|
|
@@ -3145,12 +4094,12 @@
|
|
$run ${rm}r $gentop
|
|
fi
|
|
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
prog)
|
|
case $host in
|
|
- *cygwin*) output=`echo $output | ${SED} -e 's,.exe$,,;s,$,.exe,'` ;;
|
|
+ *cygwin*) output=`$echo $output | ${SED} -e 's,.exe$,,;s,$,.exe,'` ;;
|
|
esac
|
|
if test -n "$vinfo"; then
|
|
$echo "$modename: warning: \`-version-info' is ignored for programs" 1>&2
|
|
@@ -3172,16 +4121,19 @@
|
|
# On Rhapsody replace the C library is the System framework
|
|
compile_deplibs=`$echo "X $compile_deplibs" | $Xsed -e 's/ -lc / -framework System /'`
|
|
finalize_deplibs=`$echo "X $finalize_deplibs" | $Xsed -e 's/ -lc / -framework System /'`
|
|
- case $host in
|
|
- *darwin*)
|
|
- # Don't allow lazy linking, it breaks C++ global constructors
|
|
- compile_command="$compile_command ${wl}-bind_at_load"
|
|
- finalize_command="$finalize_command ${wl}-bind_at_load"
|
|
- ;;
|
|
- esac
|
|
;;
|
|
esac
|
|
|
|
+ case $host in
|
|
+ *darwin*)
|
|
+ # Don't allow lazy linking, it breaks C++ global constructors
|
|
+ if test "$tagname" = CXX ; then
|
|
+ compile_command="$compile_command ${wl}-bind_at_load"
|
|
+ finalize_command="$finalize_command ${wl}-bind_at_load"
|
|
+ fi
|
|
+ ;;
|
|
+ esac
|
|
+
|
|
compile_command="$compile_command $compile_deplibs"
|
|
finalize_command="$finalize_command $finalize_deplibs"
|
|
|
|
@@ -3332,12 +4284,12 @@
|
|
done
|
|
|
|
if test -n "$exclude_expsyms"; then
|
|
- $run eval 'egrep -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T'
|
|
+ $run eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T'
|
|
$run eval '$mv "$nlist"T "$nlist"'
|
|
fi
|
|
|
|
if test -n "$export_symbols_regex"; then
|
|
- $run eval 'egrep -e "$export_symbols_regex" "$nlist" > "$nlist"T'
|
|
+ $run eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T'
|
|
$run eval '$mv "$nlist"T "$nlist"'
|
|
fi
|
|
|
|
@@ -3355,8 +4307,8 @@
|
|
|
|
for arg in $dlprefiles; do
|
|
$show "extracting global C symbols from \`$arg'"
|
|
- name=`echo "$arg" | ${SED} -e 's%^.*/%%'`
|
|
- $run eval 'echo ": $name " >> "$nlist"'
|
|
+ name=`$echo "$arg" | ${SED} -e 's%^.*/%%'`
|
|
+ $run eval '$echo ": $name " >> "$nlist"'
|
|
$run eval "$NM $arg | $global_symbol_pipe >> '$nlist'"
|
|
done
|
|
|
|
@@ -3365,7 +4317,7 @@
|
|
test -f "$nlist" || : > "$nlist"
|
|
|
|
if test -n "$exclude_expsyms"; then
|
|
- egrep -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T
|
|
+ $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T
|
|
$mv "$nlist"T "$nlist"
|
|
fi
|
|
|
|
@@ -3385,7 +4337,7 @@
|
|
if test -f "$nlist"S; then
|
|
eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$dlsyms"'
|
|
else
|
|
- echo '/* NONE */' >> "$output_objdir/$dlsyms"
|
|
+ $echo '/* NONE */' >> "$output_objdir/$dlsyms"
|
|
fi
|
|
|
|
$echo >> "$output_objdir/$dlsyms" "\
|
|
@@ -3437,18 +4389,18 @@
|
|
*-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*)
|
|
case "$compile_command " in
|
|
*" -static "*) ;;
|
|
- *) pic_flag_for_symtable=" $pic_flag -DPIC -DFREEBSD_WORKAROUND";;
|
|
+ *) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND";;
|
|
esac;;
|
|
*-*-hpux*)
|
|
case "$compile_command " in
|
|
*" -static "*) ;;
|
|
- *) pic_flag_for_symtable=" $pic_flag -DPIC";;
|
|
+ *) pic_flag_for_symtable=" $pic_flag";;
|
|
esac
|
|
esac
|
|
|
|
# Now compile the dynamic symbol file.
|
|
- $show "(cd $output_objdir && $CC -c$no_builtin_flag$pic_flag_for_symtable \"$dlsyms\")"
|
|
- $run eval '(cd $output_objdir && $CC -c$no_builtin_flag$pic_flag_for_symtable "$dlsyms")' || exit $?
|
|
+ $show "(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable \"$dlsyms\")"
|
|
+ $run eval '(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable "$dlsyms")' || exit $?
|
|
|
|
# Clean up the generated files.
|
|
$show "$rm $output_objdir/$dlsyms $nlist ${nlist}S ${nlist}T"
|
|
@@ -3460,7 +4412,7 @@
|
|
;;
|
|
*)
|
|
$echo "$modename: unknown suffix for \`$dlsyms'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
else
|
|
@@ -3473,7 +4425,7 @@
|
|
finalize_command=`$echo "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"`
|
|
fi
|
|
|
|
- if test $need_relink = no || test "$build_libtool_libs" != yes; then
|
|
+ if test "$need_relink" = no || test "$build_libtool_libs" != yes; then
|
|
# Replace the output file specification.
|
|
compile_command=`$echo "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
|
|
link_command="$compile_command$compile_rpath"
|
|
@@ -3548,7 +4500,7 @@
|
|
# Link the executable and exit
|
|
$show "$link_command"
|
|
$run eval "$link_command" || exit $?
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
fi
|
|
|
|
if test "$hardcode_action" = relink; then
|
|
@@ -3603,10 +4555,10 @@
|
|
fi
|
|
|
|
# Quote $echo for shipping.
|
|
- if test "X$echo" = "X$SHELL $0 --fallback-echo"; then
|
|
- case $0 in
|
|
- [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $0 --fallback-echo";;
|
|
- *) qecho="$SHELL `pwd`/$0 --fallback-echo";;
|
|
+ if test "X$echo" = "X$SHELL $progpath --fallback-echo"; then
|
|
+ case $progpath in
|
|
+ [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";;
|
|
+ *) qecho="$SHELL `pwd`/$progpath --fallback-echo";;
|
|
esac
|
|
qecho=`$echo "X$qecho" | $Xsed -e "$sed_quote_subst"`
|
|
else
|
|
@@ -3618,15 +4570,230 @@
|
|
# win32 will think the script is a binary if it has
|
|
# a .exe suffix, so we strip it off here.
|
|
case $output in
|
|
- *.exe) output=`echo $output|${SED} 's,.exe$,,'` ;;
|
|
+ *.exe) output=`$echo $output|${SED} 's,.exe$,,'` ;;
|
|
esac
|
|
# test for cygwin because mv fails w/o .exe extensions
|
|
case $host in
|
|
- *cygwin*) exeext=.exe ;;
|
|
+ *cygwin*)
|
|
+ exeext=.exe
|
|
+ outputname=`$echo $outputname|${SED} 's,.exe$,,'` ;;
|
|
*) exeext= ;;
|
|
esac
|
|
+ case $host in
|
|
+ *cygwin* | *mingw* )
|
|
+ cwrappersource=`$echo ${objdir}/lt-${output}.c`
|
|
+ cwrapper=`$echo ${output}.exe`
|
|
+ $rm $cwrappersource $cwrapper
|
|
+ trap "$rm $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15
|
|
+
|
|
+ cat > $cwrappersource <<EOF
|
|
+
|
|
+/* $cwrappersource - temporary wrapper executable for $objdir/$outputname
|
|
+ Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
|
|
+
|
|
+ The $output program cannot be directly executed until all the libtool
|
|
+ libraries that it depends on are installed.
|
|
+
|
|
+ This wrapper executable should never be moved out of the build directory.
|
|
+ If it is, it will not operate correctly.
|
|
+
|
|
+ Currently, it simply execs the wrapper *script* "/bin/sh $output",
|
|
+ but could eventually absorb all of the scripts functionality and
|
|
+ exec $objdir/$outputname directly.
|
|
+*/
|
|
+EOF
|
|
+ cat >> $cwrappersource<<"EOF"
|
|
+#include <stdio.h>
|
|
+#include <stdlib.h>
|
|
+#include <unistd.h>
|
|
+#include <malloc.h>
|
|
+#include <stdarg.h>
|
|
+#include <assert.h>
|
|
+
|
|
+#if defined(PATH_MAX)
|
|
+# define LT_PATHMAX PATH_MAX
|
|
+#elif defined(MAXPATHLEN)
|
|
+# define LT_PATHMAX MAXPATHLEN
|
|
+#else
|
|
+# define LT_PATHMAX 1024
|
|
+#endif
|
|
+
|
|
+#ifndef DIR_SEPARATOR
|
|
+#define DIR_SEPARATOR '/'
|
|
+#endif
|
|
+
|
|
+#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \
|
|
+ defined (__OS2__)
|
|
+#define HAVE_DOS_BASED_FILE_SYSTEM
|
|
+#ifndef DIR_SEPARATOR_2
|
|
+#define DIR_SEPARATOR_2 '\\'
|
|
+#endif
|
|
+#endif
|
|
+
|
|
+#ifndef DIR_SEPARATOR_2
|
|
+# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR)
|
|
+#else /* DIR_SEPARATOR_2 */
|
|
+# define IS_DIR_SEPARATOR(ch) \
|
|
+ (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2))
|
|
+#endif /* DIR_SEPARATOR_2 */
|
|
+
|
|
+#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type)))
|
|
+#define XFREE(stale) do { \
|
|
+ if (stale) { free ((void *) stale); stale = 0; } \
|
|
+} while (0)
|
|
+
|
|
+const char *program_name = NULL;
|
|
+
|
|
+void * xmalloc (size_t num);
|
|
+char * xstrdup (const char *string);
|
|
+char * basename (const char *name);
|
|
+char * fnqualify(const char *path);
|
|
+char * strendzap(char *str, const char *pat);
|
|
+void lt_fatal (const char *message, ...);
|
|
+
|
|
+int
|
|
+main (int argc, char *argv[])
|
|
+{
|
|
+ char **newargz;
|
|
+ int i;
|
|
+
|
|
+ program_name = (char *) xstrdup ((char *) basename (argv[0]));
|
|
+ newargz = XMALLOC(char *, argc+2);
|
|
+EOF
|
|
+
|
|
+ cat >> $cwrappersource <<EOF
|
|
+ newargz[0] = "$SHELL";
|
|
+EOF
|
|
+
|
|
+ cat >> $cwrappersource <<"EOF"
|
|
+ newargz[1] = fnqualify(argv[0]);
|
|
+ /* we know the script has the same name, without the .exe */
|
|
+ /* so make sure newargz[1] doesn't end in .exe */
|
|
+ strendzap(newargz[1],".exe");
|
|
+ for (i = 1; i < argc; i++)
|
|
+ newargz[i+1] = xstrdup(argv[i]);
|
|
+ newargz[argc+1] = NULL;
|
|
+EOF
|
|
+
|
|
+ cat >> $cwrappersource <<EOF
|
|
+ execv("$SHELL",newargz);
|
|
+EOF
|
|
+
|
|
+ cat >> $cwrappersource <<"EOF"
|
|
+}
|
|
+
|
|
+void *
|
|
+xmalloc (size_t num)
|
|
+{
|
|
+ void * p = (void *) malloc (num);
|
|
+ if (!p)
|
|
+ lt_fatal ("Memory exhausted");
|
|
+
|
|
+ return p;
|
|
+}
|
|
+
|
|
+char *
|
|
+xstrdup (const char *string)
|
|
+{
|
|
+ return string ? strcpy ((char *) xmalloc (strlen (string) + 1), string) : NULL
|
|
+;
|
|
+}
|
|
+
|
|
+char *
|
|
+basename (const char *name)
|
|
+{
|
|
+ const char *base;
|
|
+
|
|
+#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
|
|
+ /* Skip over the disk name in MSDOS pathnames. */
|
|
+ if (isalpha (name[0]) && name[1] == ':')
|
|
+ name += 2;
|
|
+#endif
|
|
+
|
|
+ for (base = name; *name; name++)
|
|
+ if (IS_DIR_SEPARATOR (*name))
|
|
+ base = name + 1;
|
|
+ return (char *) base;
|
|
+}
|
|
+
|
|
+char *
|
|
+fnqualify(const char *path)
|
|
+{
|
|
+ size_t size;
|
|
+ char *p;
|
|
+ char tmp[LT_PATHMAX + 1];
|
|
+
|
|
+ assert(path != NULL);
|
|
+
|
|
+ /* Is it qualified already? */
|
|
+#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
|
|
+ if (isalpha (path[0]) && path[1] == ':')
|
|
+ return xstrdup (path);
|
|
+#endif
|
|
+ if (IS_DIR_SEPARATOR (path[0]))
|
|
+ return xstrdup (path);
|
|
+
|
|
+ /* prepend the current directory */
|
|
+ /* doesn't handle '~' */
|
|
+ if (getcwd (tmp, LT_PATHMAX) == NULL)
|
|
+ lt_fatal ("getcwd failed");
|
|
+ size = strlen(tmp) + 1 + strlen(path) + 1; /* +2 for '/' and '\0' */
|
|
+ p = XMALLOC(char, size);
|
|
+ sprintf(p, "%s%c%s", tmp, DIR_SEPARATOR, path);
|
|
+ return p;
|
|
+}
|
|
+
|
|
+char *
|
|
+strendzap(char *str, const char *pat)
|
|
+{
|
|
+ size_t len, patlen;
|
|
+
|
|
+ assert(str != NULL);
|
|
+ assert(pat != NULL);
|
|
+
|
|
+ len = strlen(str);
|
|
+ patlen = strlen(pat);
|
|
+
|
|
+ if (patlen <= len)
|
|
+ {
|
|
+ str += len - patlen;
|
|
+ if (strcmp(str, pat) == 0)
|
|
+ *str = '\0';
|
|
+ }
|
|
+ return str;
|
|
+}
|
|
+
|
|
+static void
|
|
+lt_error_core (int exit_status, const char * mode,
|
|
+ const char * message, va_list ap)
|
|
+{
|
|
+ fprintf (stderr, "%s: %s: ", program_name, mode);
|
|
+ vfprintf (stderr, message, ap);
|
|
+ fprintf (stderr, ".\n");
|
|
+
|
|
+ if (exit_status >= 0)
|
|
+ exit (exit_status);
|
|
+}
|
|
+
|
|
+void
|
|
+lt_fatal (const char *message, ...)
|
|
+{
|
|
+ va_list ap;
|
|
+ va_start (ap, message);
|
|
+ lt_error_core (EXIT_FAILURE, "FATAL", message, ap);
|
|
+ va_end (ap);
|
|
+}
|
|
+EOF
|
|
+ # we should really use a build-platform specific compiler
|
|
+ # here, but OTOH, the wrappers (shell script and this C one)
|
|
+ # are only useful if you want to execute the "real" binary.
|
|
+ # Since the "real" binary is built for $host, then this
|
|
+ # wrapper might as well be built for $host, too.
|
|
+ $run $LTCC -s -o $cwrapper $cwrappersource
|
|
+ ;;
|
|
+ esac
|
|
$rm $output
|
|
- trap "$rm $output; exit 1" 1 2 15
|
|
+ trap "$rm $output; exit $EXIT_FAILURE" 1 2 15
|
|
|
|
$echo > $output "\
|
|
#! $SHELL
|
|
@@ -3642,7 +4809,7 @@
|
|
|
|
# Sed substitution that helps us do robust quoting. It backslashifies
|
|
# metacharacters that are still active within double-quoted strings.
|
|
-Xsed="${SED}"' -e 1s/^X//'
|
|
+Xsed='${SED} -e 1s/^X//'
|
|
sed_quote_subst='$sed_quote_subst'
|
|
|
|
# The HP-UX ksh and POSIX shell print the target directory to stdout
|
|
@@ -3702,7 +4869,7 @@
|
|
"
|
|
|
|
if test "$fast_install" = yes; then
|
|
- echo >> $output "\
|
|
+ $echo >> $output "\
|
|
program=lt-'$outputname'$exeext
|
|
progdir=\"\$thisdir/$objdir\"
|
|
|
|
@@ -3718,7 +4885,7 @@
|
|
$rm \"\$progdir/\$file\"
|
|
fi"
|
|
|
|
- echo >> $output "\
|
|
+ $echo >> $output "\
|
|
|
|
# relink executable if necessary
|
|
if test -n \"\$relink_command\"; then
|
|
@@ -3726,7 +4893,7 @@
|
|
else
|
|
$echo \"\$relink_command_output\" >&2
|
|
$rm \"\$progdir/\$file\"
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
fi
|
|
|
|
@@ -3736,13 +4903,13 @@
|
|
$rm \"\$progdir/\$file\"
|
|
fi"
|
|
else
|
|
- echo >> $output "\
|
|
+ $echo >> $output "\
|
|
program='$outputname'
|
|
progdir=\"\$thisdir/$objdir\"
|
|
"
|
|
fi
|
|
|
|
- echo >> $output "\
|
|
+ $echo >> $output "\
|
|
|
|
if test -f \"\$progdir/\$program\"; then"
|
|
|
|
@@ -3753,7 +4920,7 @@
|
|
$shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
|
|
|
|
# Some systems cannot cope with colon-terminated $shlibpath_var
|
|
- # The second colon is a workaround for a bug in BeOS R4 ${SED}
|
|
+ # The second colon is a workaround for a bug in BeOS R4 sed
|
|
$shlibpath_var=\`\$echo \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\`
|
|
|
|
export $shlibpath_var
|
|
@@ -3773,14 +4940,6 @@
|
|
# Run the actual program with our arguments.
|
|
"
|
|
case $host in
|
|
- # win32 systems need to use the prog path for dll
|
|
- # lookup to work
|
|
- *-*-cygwin* | *-*-pw32*)
|
|
- $echo >> $output "\
|
|
- exec \$progdir/\$program \${1+\"\$@\"}
|
|
-"
|
|
- ;;
|
|
-
|
|
# Backslashes separate directories on plain windows
|
|
*-*-mingw | *-*-os2*)
|
|
$echo >> $output "\
|
|
@@ -3790,30 +4949,26 @@
|
|
|
|
*)
|
|
$echo >> $output "\
|
|
- # Export the path to the program.
|
|
- PATH=\"\$progdir:\$PATH\"
|
|
- export PATH
|
|
-
|
|
- exec \$program \${1+\"\$@\"}
|
|
+ exec \$progdir/\$program \${1+\"\$@\"}
|
|
"
|
|
;;
|
|
esac
|
|
$echo >> $output "\
|
|
\$echo \"\$0: cannot exec \$program \${1+\"\$@\"}\"
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
else
|
|
# The program doesn't exist.
|
|
\$echo \"\$0: error: \$progdir/\$program does not exist\" 1>&2
|
|
\$echo \"This script is just a wrapper for \$program.\" 1>&2
|
|
- echo \"See the $PACKAGE documentation for more information.\" 1>&2
|
|
- exit 1
|
|
+ $echo \"See the $PACKAGE documentation for more information.\" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
fi\
|
|
"
|
|
chmod +x $output
|
|
fi
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
esac
|
|
|
|
@@ -3829,7 +4984,7 @@
|
|
oldobjs="$libobjs_save"
|
|
build_libtool_libs=no
|
|
else
|
|
- oldobjs="$objs$old_deplibs "`$echo "X$libobjs_save" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`
|
|
+ oldobjs="$old_deplibs $non_pic_objects"
|
|
fi
|
|
addlibs="$old_convenience"
|
|
fi
|
|
@@ -3838,10 +4993,10 @@
|
|
gentop="$output_objdir/${outputname}x"
|
|
$show "${rm}r $gentop"
|
|
$run ${rm}r "$gentop"
|
|
- $show "mkdir $gentop"
|
|
- $run mkdir "$gentop"
|
|
+ $show "$mkdir $gentop"
|
|
+ $run $mkdir "$gentop"
|
|
status=$?
|
|
- if test $status -ne 0 && test ! -d "$gentop"; then
|
|
+ if test "$status" -ne 0 && test ! -d "$gentop"; then
|
|
exit $status
|
|
fi
|
|
generated="$generated $gentop"
|
|
@@ -3858,14 +5013,40 @@
|
|
|
|
$show "${rm}r $xdir"
|
|
$run ${rm}r "$xdir"
|
|
- $show "mkdir $xdir"
|
|
- $run mkdir "$xdir"
|
|
+ $show "$mkdir $xdir"
|
|
+ $run $mkdir "$xdir"
|
|
status=$?
|
|
- if test $status -ne 0 && test ! -d "$xdir"; then
|
|
+ if test "$status" -ne 0 && test ! -d "$xdir"; then
|
|
exit $status
|
|
fi
|
|
+ # We will extract separately just the conflicting names and we will no
|
|
+ # longer touch any unique names. It is faster to leave these extract
|
|
+ # automatically by $AR in one run.
|
|
$show "(cd $xdir && $AR x $xabs)"
|
|
$run eval "(cd \$xdir && $AR x \$xabs)" || exit $?
|
|
+ if ($AR t "$xabs" | sort | sort -uc >/dev/null 2>&1); then
|
|
+ :
|
|
+ else
|
|
+ $echo "$modename: warning: object name conflicts; renaming object files" 1>&2
|
|
+ $echo "$modename: warning: to ensure that they will not overwrite" 1>&2
|
|
+ $AR t "$xabs" | sort | uniq -cd | while read -r count name
|
|
+ do
|
|
+ i=1
|
|
+ while test "$i" -le "$count"
|
|
+ do
|
|
+ # Put our $i before any first dot (extension)
|
|
+ # Never overwrite any file
|
|
+ name_to="$name"
|
|
+ while test "X$name_to" = "X$name" || test -f "$xdir/$name_to"
|
|
+ do
|
|
+ name_to=`$echo "X$name_to" | $Xsed -e "s/\([^.]*\)/\1-$i/"`
|
|
+ done
|
|
+ $show "(cd $xdir && $AR xN $i $xabs '$name' && $mv '$name' '$name_to')"
|
|
+ $run eval "(cd \$xdir && $AR xN $i \$xabs '$name' && $mv '$name' '$name_to')" || exit $?
|
|
+ i=`expr $i + 1`
|
|
+ done
|
|
+ done
|
|
+ fi
|
|
|
|
oldobjs="$oldobjs "`find $xdir -name \*.${objext} -print -o -name \*.lo -print | $NL2SP`
|
|
done
|
|
@@ -3873,30 +5054,71 @@
|
|
|
|
# Do each command in the archive commands.
|
|
if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then
|
|
- eval cmds=\"$old_archive_from_new_cmds\"
|
|
+ cmds=$old_archive_from_new_cmds
|
|
else
|
|
- # Ensure that we have .o objects in place in case we decided
|
|
- # not to build a shared library, and have fallen back to building
|
|
- # static libs even though --disable-static was passed!
|
|
- for oldobj in $oldobjs; do
|
|
- if test ! -f $oldobj; then
|
|
- xdir=`$echo "X$oldobj" | $Xsed -e 's%/[^/]*$%%'`
|
|
- if test "X$xdir" = "X$oldobj"; then
|
|
- xdir="."
|
|
+ eval cmds=\"$old_archive_cmds\"
|
|
+
|
|
+ if len=`expr "X$cmds" : ".*"` &&
|
|
+ test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
|
|
+ cmds=$old_archive_cmds
|
|
+ else
|
|
+ # the command line is too long to link in one step, link in parts
|
|
+ $echo "using piecewise archive linking..."
|
|
+ save_RANLIB=$RANLIB
|
|
+ RANLIB=:
|
|
+ objlist=
|
|
+ concat_cmds=
|
|
+ save_oldobjs=$oldobjs
|
|
+ # GNU ar 2.10+ was changed to match POSIX; thus no paths are
|
|
+ # encoded into archives. This makes 'ar r' malfunction in
|
|
+ # this piecewise linking case whenever conflicting object
|
|
+ # names appear in distinct ar calls; check, warn and compensate.
|
|
+ if (for obj in $save_oldobjs
|
|
+ do
|
|
+ $echo "X$obj" | $Xsed -e 's%^.*/%%'
|
|
+ done | sort | sort -uc >/dev/null 2>&1); then
|
|
+ :
|
|
+ else
|
|
+ $echo "$modename: warning: object name conflicts; overriding AR_FLAGS to 'cq'" 1>&2
|
|
+ $echo "$modename: warning: to ensure that POSIX-compatible ar will work" 1>&2
|
|
+ AR_FLAGS=cq
|
|
+ fi
|
|
+ # Is there a better way of finding the last object in the list?
|
|
+ for obj in $save_oldobjs
|
|
+ do
|
|
+ last_oldobj=$obj
|
|
+ done
|
|
+ for obj in $save_oldobjs
|
|
+ do
|
|
+ oldobjs="$objlist $obj"
|
|
+ objlist="$objlist $obj"
|
|
+ eval test_cmds=\"$old_archive_cmds\"
|
|
+ if len=`expr "X$test_cmds" : ".*"` &&
|
|
+ test "$len" -le "$max_cmd_len"; then
|
|
+ :
|
|
else
|
|
- xdir="$xdir"
|
|
+ # the above command should be used before it gets too long
|
|
+ oldobjs=$objlist
|
|
+ if test "$obj" = "$last_oldobj" ; then
|
|
+ RANLIB=$save_RANLIB
|
|
+ fi
|
|
+ test -z "$concat_cmds" || concat_cmds=$concat_cmds~
|
|
+ eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\"
|
|
+ objlist=
|
|
fi
|
|
- baseobj=`$echo "X$oldobj" | $Xsed -e 's%^.*/%%'`
|
|
- obj=`$echo "X$baseobj" | $Xsed -e "$o2lo"`
|
|
- $show "(cd $xdir && ${LN_S} $obj $baseobj)"
|
|
- $run eval '(cd $xdir && ${LN_S} $obj $baseobj)' || exit $?
|
|
+ done
|
|
+ RANLIB=$save_RANLIB
|
|
+ oldobjs=$objlist
|
|
+ if test "X$oldobjs" = "X" ; then
|
|
+ eval cmds=\"\$concat_cmds\"
|
|
+ else
|
|
+ eval cmds=\"\$concat_cmds~\$old_archive_cmds\"
|
|
fi
|
|
- done
|
|
-
|
|
- eval cmds=\"$old_archive_cmds\"
|
|
+ fi
|
|
fi
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
+ eval cmd=\"$cmd\"
|
|
IFS="$save_ifs"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
@@ -3928,8 +5150,12 @@
|
|
fi
|
|
done
|
|
# Quote the link command for shipping.
|
|
- relink_command="(cd `pwd`; $SHELL $0 --mode=relink $libtool_args)"
|
|
+ relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
|
|
relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"`
|
|
+ if test "$hardcode_automatic" = yes ; then
|
|
+ relink_command=
|
|
+ fi
|
|
+
|
|
|
|
# Only create the output if not a dry run.
|
|
if test -z "$run"; then
|
|
@@ -3948,7 +5174,7 @@
|
|
eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
|
|
if test -z "$libdir"; then
|
|
$echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
newdependency_libs="$newdependency_libs $libdir/$name"
|
|
;;
|
|
@@ -3962,7 +5188,7 @@
|
|
eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
|
|
if test -z "$libdir"; then
|
|
$echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
newdlfiles="$newdlfiles $libdir/$name"
|
|
done
|
|
@@ -3973,17 +5199,36 @@
|
|
eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
|
|
if test -z "$libdir"; then
|
|
$echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
newdlprefiles="$newdlprefiles $libdir/$name"
|
|
done
|
|
dlprefiles="$newdlprefiles"
|
|
+ else
|
|
+ newdlfiles=
|
|
+ for lib in $dlfiles; do
|
|
+ case $lib in
|
|
+ [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
|
|
+ *) abs=`pwd`"/$lib" ;;
|
|
+ esac
|
|
+ newdlfiles="$newdlfiles $abs"
|
|
+ done
|
|
+ dlfiles="$newdlfiles"
|
|
+ newdlprefiles=
|
|
+ for lib in $dlprefiles; do
|
|
+ case $lib in
|
|
+ [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
|
|
+ *) abs=`pwd`"/$lib" ;;
|
|
+ esac
|
|
+ newdlprefiles="$newdlprefiles $abs"
|
|
+ done
|
|
+ dlprefiles="$newdlprefiles"
|
|
fi
|
|
$rm $output
|
|
# place dlname in correct position for cygwin
|
|
tdlname=$dlname
|
|
case $host,$output,$installed,$module,$dlname in
|
|
- *cygwin*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;;
|
|
+ *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;;
|
|
esac
|
|
$echo > $output "\
|
|
# $outputname - a libtool library file
|
|
@@ -4012,13 +5257,16 @@
|
|
# Is this an already installed library?
|
|
installed=$installed
|
|
|
|
+# Should we warn about portability when linking against -modules?
|
|
+shouldnotlink=$module
|
|
+
|
|
# Files to dlopen/dlpreopen
|
|
dlopen='$dlfiles'
|
|
dlpreopen='$dlprefiles'
|
|
|
|
# Directory that this library needs to be installed in:
|
|
libdir='$install_libdir'"
|
|
- if test "$installed" = no && test $need_relink = yes; then
|
|
+ if test "$installed" = no && test "$need_relink" = yes; then
|
|
$echo >> $output "\
|
|
relink_command=\"$relink_command\""
|
|
fi
|
|
@@ -4031,7 +5279,7 @@
|
|
$run eval '(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)' || exit $?
|
|
;;
|
|
esac
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
# libtool install mode
|
|
@@ -4120,13 +5368,13 @@
|
|
if test -z "$install_prog"; then
|
|
$echo "$modename: you must specify an install program" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
if test -n "$prev"; then
|
|
$echo "$modename: the \`$prev' option requires an argument" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
if test -z "$files"; then
|
|
@@ -4136,7 +5384,7 @@
|
|
$echo "$modename: you must specify a destination" 1>&2
|
|
fi
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Strip any trailing slash from the destination.
|
|
@@ -4154,10 +5402,10 @@
|
|
|
|
# Not a directory, so check to see that there is only one file specified.
|
|
set dummy $files
|
|
- if test $# -gt 2; then
|
|
+ if test "$#" -gt 2; then
|
|
$echo "$modename: \`$dest' is not a directory" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
fi
|
|
case $destdir in
|
|
@@ -4169,7 +5417,7 @@
|
|
*)
|
|
$echo "$modename: \`$destdir' must be an absolute directory name" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
done
|
|
@@ -4194,11 +5442,11 @@
|
|
|
|
*.la)
|
|
# Check to see that this really is a libtool archive.
|
|
- if (${SED} -e '2q' $file | egrep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
|
|
+ if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
|
|
else
|
|
$echo "$modename: \`$file' is not a valid libtool archive" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
library_names=
|
|
@@ -4229,12 +5477,33 @@
|
|
dir="$dir$objdir"
|
|
|
|
if test -n "$relink_command"; then
|
|
+ # Determine the prefix the user has applied to our future dir.
|
|
+ inst_prefix_dir=`$echo "$destdir" | $SED "s%$libdir\$%%"`
|
|
+
|
|
+ # Don't allow the user to place us outside of our expected
|
|
+ # location b/c this prevents finding dependent libraries that
|
|
+ # are installed to the same prefix.
|
|
+ # At present, this check doesn't affect windows .dll's that
|
|
+ # are installed into $libdir/../bin (currently, that works fine)
|
|
+ # but it's something to keep an eye on.
|
|
+ if test "$inst_prefix_dir" = "$destdir"; then
|
|
+ $echo "$modename: error: cannot install \`$file' to a directory not ending in $libdir" 1>&2
|
|
+ exit $EXIT_FAILURE
|
|
+ fi
|
|
+
|
|
+ if test -n "$inst_prefix_dir"; then
|
|
+ # Stick the inst_prefix_dir data into the link command.
|
|
+ relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"`
|
|
+ else
|
|
+ relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%%"`
|
|
+ fi
|
|
+
|
|
$echo "$modename: warning: relinking \`$file'" 1>&2
|
|
$show "$relink_command"
|
|
if $run eval "$relink_command"; then :
|
|
else
|
|
$echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2
|
|
- continue
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
fi
|
|
|
|
@@ -4256,7 +5525,7 @@
|
|
$run eval "$striplib $destdir/$realname" || exit $?
|
|
fi
|
|
|
|
- if test $# -gt 0; then
|
|
+ if test "$#" -gt 0; then
|
|
# Delete the old symlinks, and create new ones.
|
|
for linkname
|
|
do
|
|
@@ -4269,10 +5538,11 @@
|
|
|
|
# Do each command in the postinstall commands.
|
|
lib="$destdir/$realname"
|
|
- eval cmds=\"$postinstall_cmds\"
|
|
+ cmds=$postinstall_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
done
|
|
@@ -4312,7 +5582,7 @@
|
|
*)
|
|
$echo "$modename: cannot copy a libtool object to \`$destfile'" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
@@ -4330,7 +5600,7 @@
|
|
$show "$install_prog $staticobj $staticdest"
|
|
$run eval "$install_prog \$staticobj \$staticdest" || exit $?
|
|
fi
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
*)
|
|
@@ -4342,29 +5612,49 @@
|
|
destfile="$destdir/$destfile"
|
|
fi
|
|
|
|
+ # If the file is missing, and there is a .exe on the end, strip it
|
|
+ # because it is most likely a libtool script we actually want to
|
|
+ # install
|
|
+ stripped_ext=""
|
|
+ case $file in
|
|
+ *.exe)
|
|
+ if test ! -f "$file"; then
|
|
+ file=`$echo $file|${SED} 's,.exe$,,'`
|
|
+ stripped_ext=".exe"
|
|
+ fi
|
|
+ ;;
|
|
+ esac
|
|
+
|
|
# Do a test to see if this is really a libtool program.
|
|
case $host in
|
|
*cygwin*|*mingw*)
|
|
- wrapper=`echo $file | ${SED} -e 's,.exe$,,'`
|
|
+ wrapper=`$echo $file | ${SED} -e 's,.exe$,,'`
|
|
;;
|
|
*)
|
|
wrapper=$file
|
|
;;
|
|
esac
|
|
- if (${SED} -e '4q' $wrapper | egrep "^# Generated by .*$PACKAGE")>/dev/null 2>&1; then
|
|
+ if (${SED} -e '4q' $wrapper | grep "^# Generated by .*$PACKAGE")>/dev/null 2>&1; then
|
|
notinst_deplibs=
|
|
relink_command=
|
|
|
|
+ # To insure that "foo" is sourced, and not "foo.exe",
|
|
+ # finese the cygwin/MSYS system by explicitly sourcing "foo."
|
|
+ # which disallows the automatic-append-.exe behavior.
|
|
+ case $build in
|
|
+ *cygwin* | *mingw*) wrapperdot=${wrapper}. ;;
|
|
+ *) wrapperdot=${wrapper} ;;
|
|
+ esac
|
|
# If there is no directory component, then add one.
|
|
case $file in
|
|
- */* | *\\*) . $wrapper ;;
|
|
- *) . ./$wrapper ;;
|
|
+ */* | *\\*) . ${wrapperdot} ;;
|
|
+ *) . ./${wrapperdot} ;;
|
|
esac
|
|
|
|
# Check the variables that should have been set.
|
|
if test -z "$notinst_deplibs"; then
|
|
$echo "$modename: invalid libtool wrapper script \`$wrapper'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
finalize=yes
|
|
@@ -4386,10 +5676,17 @@
|
|
done
|
|
|
|
relink_command=
|
|
+ # To insure that "foo" is sourced, and not "foo.exe",
|
|
+ # finese the cygwin/MSYS system by explicitly sourcing "foo."
|
|
+ # which disallows the automatic-append-.exe behavior.
|
|
+ case $build in
|
|
+ *cygwin* | *mingw*) wrapperdot=${wrapper}. ;;
|
|
+ *) wrapperdot=${wrapper} ;;
|
|
+ esac
|
|
# If there is no directory component, then add one.
|
|
case $file in
|
|
- */* | *\\*) . $wrapper ;;
|
|
- *) . ./$wrapper ;;
|
|
+ */* | *\\*) . ${wrapperdot} ;;
|
|
+ *) . ./${wrapperdot} ;;
|
|
esac
|
|
|
|
outputname=
|
|
@@ -4398,12 +5695,16 @@
|
|
tmpdir="/tmp"
|
|
test -n "$TMPDIR" && tmpdir="$TMPDIR"
|
|
tmpdir="$tmpdir/libtool-$$"
|
|
- if $mkdir -p "$tmpdir" && chmod 700 "$tmpdir"; then :
|
|
+ save_umask=`umask`
|
|
+ umask 0077
|
|
+ if $mkdir "$tmpdir"; then
|
|
+ umask $save_umask
|
|
else
|
|
+ umask $save_umask
|
|
$echo "$modename: error: cannot create temporary directory \`$tmpdir'" 1>&2
|
|
continue
|
|
fi
|
|
- file=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
|
|
+ file=`$echo "X$file$stripped_ext" | $Xsed -e 's%^.*/%%'`
|
|
outputname="$tmpdir/$file"
|
|
# Replace the output file specification.
|
|
relink_command=`$echo "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'`
|
|
@@ -4421,14 +5722,14 @@
|
|
fi
|
|
else
|
|
# Install the binary that we compiled earlier.
|
|
- file=`$echo "X$file" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"`
|
|
+ file=`$echo "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"`
|
|
fi
|
|
fi
|
|
|
|
# remove .exe since cygwin /usr/bin/install will append another
|
|
# one anyways
|
|
case $install_prog,$host in
|
|
- /usr/bin/install*,*cygwin*)
|
|
+ */usr/bin/install*,*cygwin*)
|
|
case $file:$destfile in
|
|
*.exe:*.exe)
|
|
# this is ok
|
|
@@ -4437,7 +5738,7 @@
|
|
destfile=$destfile.exe
|
|
;;
|
|
*:*.exe)
|
|
- destfile=`echo $destfile | ${SED} -e 's,.exe$,,'`
|
|
+ destfile=`$echo $destfile | ${SED} -e 's,.exe$,,'`
|
|
;;
|
|
esac
|
|
;;
|
|
@@ -4458,16 +5759,17 @@
|
|
$show "$install_prog $file $oldlib"
|
|
$run eval "$install_prog \$file \$oldlib" || exit $?
|
|
|
|
- if test -n "$stripme" && test -n "$striplib"; then
|
|
+ if test -n "$stripme" && test -n "$old_striplib"; then
|
|
$show "$old_striplib $oldlib"
|
|
$run eval "$old_striplib $oldlib" || exit $?
|
|
fi
|
|
|
|
# Do each command in the postinstall commands.
|
|
- eval cmds=\"$old_postinstall_cmds\"
|
|
+ cmds=$old_postinstall_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || exit $?
|
|
done
|
|
@@ -4481,9 +5783,9 @@
|
|
if test -n "$current_libdirs"; then
|
|
# Maybe just do a dry run.
|
|
test -n "$run" && current_libdirs=" -n$current_libdirs"
|
|
- exec_cmd='$SHELL $0 --finish$current_libdirs'
|
|
+ exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs'
|
|
else
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
fi
|
|
;;
|
|
|
|
@@ -4502,10 +5804,11 @@
|
|
for libdir in $libdirs; do
|
|
if test -n "$finish_cmds"; then
|
|
# Do each command in the finish commands.
|
|
- eval cmds=\"$finish_cmds\"
|
|
+ cmds=$finish_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd" || admincmds="$admincmds
|
|
$cmd"
|
|
@@ -4522,43 +5825,43 @@
|
|
fi
|
|
|
|
# Exit here if they wanted silent mode.
|
|
- test "$show" = ":" && exit 0
|
|
+ test "$show" = : && exit $EXIT_SUCCESS
|
|
|
|
- echo "----------------------------------------------------------------------"
|
|
- echo "Libraries have been installed in:"
|
|
+ $echo "----------------------------------------------------------------------"
|
|
+ $echo "Libraries have been installed in:"
|
|
for libdir in $libdirs; do
|
|
- echo " $libdir"
|
|
+ $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:"
|
|
+ $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"
|
|
+ $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"
|
|
+ $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"
|
|
+ $echo " - use the \`$flag' linker flag"
|
|
fi
|
|
if test -n "$admincmds"; then
|
|
- echo " - have your system administrator run these commands:$admincmds"
|
|
+ $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'"
|
|
+ $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."
|
|
- echo "----------------------------------------------------------------------"
|
|
- exit 0
|
|
+ $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."
|
|
+ $echo "----------------------------------------------------------------------"
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
# libtool execute mode
|
|
@@ -4570,7 +5873,7 @@
|
|
if test -z "$cmd"; then
|
|
$echo "$modename: you must specify a COMMAND" 1>&2
|
|
$echo "$help"
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Handle -dlopen flags immediately.
|
|
@@ -4578,18 +5881,18 @@
|
|
if test ! -f "$file"; then
|
|
$echo "$modename: \`$file' is not a file" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
dir=
|
|
case $file in
|
|
*.la)
|
|
# Check to see that this really is a libtool archive.
|
|
- if (${SED} -e '2q' $file | egrep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
|
|
+ if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
|
|
else
|
|
$echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# Read the libtool library.
|
|
@@ -4616,7 +5919,7 @@
|
|
dir="$dir/$objdir"
|
|
else
|
|
$echo "$modename: cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
;;
|
|
|
|
@@ -4656,7 +5959,7 @@
|
|
-*) ;;
|
|
*)
|
|
# Do a test to see if this is really a libtool program.
|
|
- if (${SED} -e '4q' $file | egrep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
+ if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
# If there is no directory component, then add one.
|
|
case $file in
|
|
*/* | *\\*) . $file ;;
|
|
@@ -4679,7 +5982,7 @@
|
|
eval "export $shlibpath_var"
|
|
fi
|
|
|
|
- # Restore saved enviroment variables
|
|
+ # Restore saved environment variables
|
|
if test "${save_LC_ALL+set}" = set; then
|
|
LC_ALL="$save_LC_ALL"; export LC_ALL
|
|
fi
|
|
@@ -4696,7 +5999,7 @@
|
|
$echo "export $shlibpath_var"
|
|
fi
|
|
$echo "$cmd$args"
|
|
- exit 0
|
|
+ exit $EXIT_SUCCESS
|
|
fi
|
|
;;
|
|
|
|
@@ -4724,24 +6027,25 @@
|
|
if test -z "$rm"; then
|
|
$echo "$modename: you must specify an RM program" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
rmdirs=
|
|
|
|
+ origobjdir="$objdir"
|
|
for file in $files; do
|
|
dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`
|
|
if test "X$dir" = "X$file"; then
|
|
dir=.
|
|
- objdir="$objdir"
|
|
+ objdir="$origobjdir"
|
|
else
|
|
- objdir="$dir/$objdir"
|
|
+ objdir="$dir/$origobjdir"
|
|
fi
|
|
name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
|
|
- test $mode = uninstall && objdir="$dir"
|
|
+ test "$mode" = uninstall && objdir="$dir"
|
|
|
|
# Remember objdir for removal later, being careful to avoid duplicates
|
|
- if test $mode = clean; then
|
|
+ if test "$mode" = clean; then
|
|
case " $rmdirs " in
|
|
*" $objdir "*) ;;
|
|
*) rmdirs="$rmdirs $objdir" ;;
|
|
@@ -4765,7 +6069,7 @@
|
|
case $name in
|
|
*.la)
|
|
# Possibly a libtool archive, so verify it.
|
|
- if (${SED} -e '2q' $file | egrep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
+ if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
. $dir/$name
|
|
|
|
# Delete the libtool libraries and symlinks.
|
|
@@ -4773,18 +6077,19 @@
|
|
rmfiles="$rmfiles $objdir/$n"
|
|
done
|
|
test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library"
|
|
- test $mode = clean && rmfiles="$rmfiles $objdir/$name $objdir/${name}i"
|
|
+ test "$mode" = clean && rmfiles="$rmfiles $objdir/$name $objdir/${name}i"
|
|
|
|
- if test $mode = uninstall; then
|
|
+ if test "$mode" = uninstall; then
|
|
if test -n "$library_names"; then
|
|
# Do each command in the postuninstall commands.
|
|
- eval cmds=\"$postuninstall_cmds\"
|
|
+ cmds=$postuninstall_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd"
|
|
- if test $? != 0 && test "$rmforce" != yes; then
|
|
+ if test "$?" -ne 0 && test "$rmforce" != yes; then
|
|
exit_status=1
|
|
fi
|
|
done
|
|
@@ -4793,13 +6098,14 @@
|
|
|
|
if test -n "$old_library"; then
|
|
# Do each command in the old_postuninstall commands.
|
|
- eval cmds=\"$old_postuninstall_cmds\"
|
|
+ cmds=$old_postuninstall_cmds
|
|
save_ifs="$IFS"; IFS='~'
|
|
for cmd in $cmds; do
|
|
IFS="$save_ifs"
|
|
+ eval cmd=\"$cmd\"
|
|
$show "$cmd"
|
|
$run eval "$cmd"
|
|
- if test $? != 0 && test "$rmforce" != yes; then
|
|
+ if test "$?" -ne 0 && test "$rmforce" != yes; then
|
|
exit_status=1
|
|
fi
|
|
done
|
|
@@ -4811,22 +6117,52 @@
|
|
;;
|
|
|
|
*.lo)
|
|
- if test "$build_old_libs" = yes; then
|
|
- oldobj=`$echo "X$name" | $Xsed -e "$lo2o"`
|
|
- rmfiles="$rmfiles $dir/$oldobj"
|
|
+ # Possibly a libtool object, so verify it.
|
|
+ if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
+
|
|
+ # Read the .lo file
|
|
+ . $dir/$name
|
|
+
|
|
+ # Add PIC object to the list of files to remove.
|
|
+ if test -n "$pic_object" \
|
|
+ && test "$pic_object" != none; then
|
|
+ rmfiles="$rmfiles $dir/$pic_object"
|
|
+ fi
|
|
+
|
|
+ # Add non-PIC object to the list of files to remove.
|
|
+ if test -n "$non_pic_object" \
|
|
+ && test "$non_pic_object" != none; then
|
|
+ rmfiles="$rmfiles $dir/$non_pic_object"
|
|
+ fi
|
|
fi
|
|
;;
|
|
|
|
*)
|
|
- # Do a test to see if this is a libtool program.
|
|
- if test $mode = clean &&
|
|
- (${SED} -e '4q' $file | egrep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
- relink_command=
|
|
- . $dir/$file
|
|
+ if test "$mode" = clean ; then
|
|
+ noexename=$name
|
|
+ case $file in
|
|
+ *.exe)
|
|
+ file=`$echo $file|${SED} 's,.exe$,,'`
|
|
+ noexename=`$echo $name|${SED} 's,.exe$,,'`
|
|
+ # $file with .exe has already been added to rmfiles,
|
|
+ # add $file without .exe
|
|
+ rmfiles="$rmfiles $file"
|
|
+ ;;
|
|
+ esac
|
|
+ # Do a test to see if this is a libtool program.
|
|
+ if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
|
|
+ relink_command=
|
|
+ . $dir/$noexename
|
|
|
|
- rmfiles="$rmfiles $objdir/$name $objdir/${name}S.${objext}"
|
|
- if test "$fast_install" = yes && test -n "$relink_command"; then
|
|
- rmfiles="$rmfiles $objdir/lt-$name"
|
|
+ # note $name still contains .exe if it was in $file originally
|
|
+ # as does the version of $file that was added into $rmfiles
|
|
+ rmfiles="$rmfiles $objdir/$name $objdir/${name}S.${objext}"
|
|
+ if test "$fast_install" = yes && test -n "$relink_command"; then
|
|
+ rmfiles="$rmfiles $objdir/lt-$name"
|
|
+ fi
|
|
+ if test "X$noexename" != "X$name" ; then
|
|
+ rmfiles="$rmfiles $objdir/lt-${noexename}.c"
|
|
+ fi
|
|
fi
|
|
fi
|
|
;;
|
|
@@ -4834,6 +6170,7 @@
|
|
$show "$rm $rmfiles"
|
|
$run $rm $rmfiles || exit_status=1
|
|
done
|
|
+ objdir="$origobjdir"
|
|
|
|
# Try to remove the ${objdir}s in the directories where we deleted files
|
|
for dir in $rmdirs; do
|
|
@@ -4849,20 +6186,20 @@
|
|
"")
|
|
$echo "$modename: you must specify a MODE" 1>&2
|
|
$echo "$generic_help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
if test -z "$exec_cmd"; then
|
|
$echo "$modename: invalid operation mode \`$mode'" 1>&2
|
|
$echo "$generic_help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
fi # test -z "$show_help"
|
|
|
|
if test -n "$exec_cmd"; then
|
|
eval exec $exec_cmd
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
fi
|
|
|
|
# We need to display help for each of the modes.
|
|
@@ -4881,6 +6218,7 @@
|
|
--mode=MODE use operation mode MODE [default=inferred from MODE-ARGS]
|
|
--quiet same as \`--silent'
|
|
--silent don't print informational messages
|
|
+ --tag=TAG use configuration variables from tag TAG
|
|
--version print version information
|
|
|
|
MODE must be one of the following:
|
|
@@ -4894,8 +6232,10 @@
|
|
uninstall remove libraries from an installed directory
|
|
|
|
MODE-ARGS vary depending on the MODE. Try \`$modename --help --mode=MODE' for
|
|
-a more detailed description of MODE."
|
|
- exit 0
|
|
+a more detailed description of MODE.
|
|
+
|
|
+Report bugs to <bug-libtool@gnu.org>."
|
|
+ exit $EXIT_SUCCESS
|
|
;;
|
|
|
|
clean)
|
|
@@ -5006,6 +6346,9 @@
|
|
-no-install link a not-installable executable
|
|
-no-undefined declare that a library does not refer to external symbols
|
|
-o OUTPUT-FILE create OUTPUT-FILE from the specified objects
|
|
+ -objectlist FILE Use a list of object files found in FILE to specify objects
|
|
+ -precious-files-regex REGEX
|
|
+ don't remove output files matching REGEX
|
|
-release RELEASE specify package release information
|
|
-rpath LIBDIR the created library will eventually be installed in LIBDIR
|
|
-R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries
|
|
@@ -5047,14 +6390,34 @@
|
|
*)
|
|
$echo "$modename: invalid operation mode \`$mode'" 1>&2
|
|
$echo "$help" 1>&2
|
|
- exit 1
|
|
+ exit $EXIT_FAILURE
|
|
;;
|
|
esac
|
|
|
|
-echo
|
|
+$echo
|
|
$echo "Try \`$modename --help' for more information about other modes."
|
|
|
|
-exit 0
|
|
+exit $EXIT_SUCCESS
|
|
+
|
|
+# The TAGs below are defined such that we never get into a situation
|
|
+# in which we disable both kinds of libraries. Given conflicting
|
|
+# choices, we go for a static library, that is the most portable,
|
|
+# since we can't tell whether shared libraries were disabled because
|
|
+# the user asked for that or because the platform doesn't support
|
|
+# them. This is particularly important on AIX, because we don't
|
|
+# support having both static and shared libraries enabled at the same
|
|
+# time on that platform, so we default to a shared-only configuration.
|
|
+# If a disable-shared tag is given, we'll fallback to a static-only
|
|
+# configuration. But we'll never go from static-only to shared-only.
|
|
+
|
|
+# ### BEGIN LIBTOOL TAG CONFIG: disable-shared
|
|
+build_libtool_libs=no
|
|
+build_old_libs=yes
|
|
+# ### END LIBTOOL TAG CONFIG: disable-shared
|
|
+
|
|
+# ### BEGIN LIBTOOL TAG CONFIG: disable-static
|
|
+build_old_libs=`case $build_libtool_libs in yes) $echo no;; *) $echo yes;; esac`
|
|
+# ### END LIBTOOL TAG CONFIG: disable-static
|
|
|
|
# Local Variables:
|
|
# mode:shell-script
|