| Index: third_party/freetype2/src/builds/unix/ltmain.sh
|
| diff --git a/third_party/tcmalloc/vendor/ltmain.sh b/third_party/freetype2/src/builds/unix/ltmain.sh
|
| similarity index 67%
|
| copy from third_party/tcmalloc/vendor/ltmain.sh
|
| copy to third_party/freetype2/src/builds/unix/ltmain.sh
|
| index 7ed280bc9525daa93de726e1100f11de4b113de2..a356acafa4548959e97355d1e8044b7201661754 100644
|
| --- a/third_party/tcmalloc/vendor/ltmain.sh
|
| +++ b/third_party/freetype2/src/builds/unix/ltmain.sh
|
| @@ -1,9 +1,9 @@
|
| -# Generated from ltmain.m4sh.
|
|
|
| -# ltmain.sh (GNU libtool) 2.2.6b
|
| +# libtool (GNU libtool) 2.4.2
|
| # Written by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
|
|
|
| -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, 2007 2008 Free Software Foundation, Inc.
|
| +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006,
|
| +# 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc.
|
| # This is free software; see the source for copying conditions. There is NO
|
| # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
| @@ -32,50 +32,57 @@
|
| #
|
| # Provide generalized library-building support services.
|
| #
|
| -# --config show all configuration variables
|
| -# --debug enable verbose shell tracing
|
| -# -n, --dry-run display commands without modifying any files
|
| -# --features display basic configuration information and exit
|
| -# --mode=MODE use operation mode MODE
|
| -# --preserve-dup-deps don't remove duplicate dependency libraries
|
| -# --quiet, --silent don't print informational messages
|
| -# --tag=TAG use configuration variables from tag TAG
|
| -# -v, --verbose print informational messages (default)
|
| -# --version print version information
|
| -# -h, --help print short or long help message
|
| +# --config show all configuration variables
|
| +# --debug enable verbose shell tracing
|
| +# -n, --dry-run display commands without modifying any files
|
| +# --features display basic configuration information and exit
|
| +# --mode=MODE use operation mode MODE
|
| +# --preserve-dup-deps don't remove duplicate dependency libraries
|
| +# --quiet, --silent don't print informational messages
|
| +# --no-quiet, --no-silent
|
| +# print informational messages (default)
|
| +# --no-warn don't display warning messages
|
| +# --tag=TAG use configuration variables from tag TAG
|
| +# -v, --verbose print more informational messages than default
|
| +# --no-verbose don't print the extra informational messages
|
| +# --version print version information
|
| +# -h, --help, --help-all print short, long, or detailed help message
|
| #
|
| # MODE must be one of the following:
|
| #
|
| -# clean remove files from the build directory
|
| -# compile compile a source file into a libtool object
|
| -# execute automatically set library path, then run a program
|
| -# finish complete the installation of libtool libraries
|
| -# install install libraries or executables
|
| -# link create a library or an executable
|
| -# uninstall remove libraries from an installed directory
|
| +# clean remove files from the build directory
|
| +# compile compile a source file into a libtool object
|
| +# execute automatically set library path, then run a program
|
| +# finish complete the installation of libtool libraries
|
| +# install install libraries or executables
|
| +# link create a library or an executable
|
| +# uninstall remove libraries from an installed directory
|
| #
|
| -# MODE-ARGS vary depending on the MODE.
|
| +# MODE-ARGS vary depending on the MODE. When passed as first option,
|
| +# `--mode=MODE' may be abbreviated as `MODE' or a unique abbreviation of that.
|
| # Try `$progname --help --mode=MODE' for a more detailed description of MODE.
|
| #
|
| # When reporting a bug, please describe a test case to reproduce it and
|
| # include the following information:
|
| #
|
| -# host-triplet: $host
|
| -# shell: $SHELL
|
| -# compiler: $LTCC
|
| -# compiler flags: $LTCFLAGS
|
| -# linker: $LD (gnu? $with_gnu_ld)
|
| -# $progname: (GNU libtool) 2.2.6b Debian-2.2.6b-2ubuntu1
|
| -# automake: $automake_version
|
| -# autoconf: $autoconf_version
|
| +# host-triplet: $host
|
| +# shell: $SHELL
|
| +# compiler: $LTCC
|
| +# compiler flags: $LTCFLAGS
|
| +# linker: $LD (gnu? $with_gnu_ld)
|
| +# $progname: (GNU libtool) 2.4.2 Debian-2.4.2-1.7ubuntu1
|
| +# automake: $automake_version
|
| +# autoconf: $autoconf_version
|
| #
|
| # Report bugs to <bug-libtool@gnu.org>.
|
| +# GNU libtool home page: <http://www.gnu.org/software/libtool/>.
|
| +# General help using GNU software: <http://www.gnu.org/gethelp/>.
|
|
|
| -PROGRAM=ltmain.sh
|
| +PROGRAM=libtool
|
| PACKAGE=libtool
|
| -VERSION="2.2.6b Debian-2.2.6b-2ubuntu1"
|
| +VERSION="2.4.2 Debian-2.4.2-1.7ubuntu1"
|
| TIMESTAMP=""
|
| -package_revision=1.3017
|
| +package_revision=1.3337
|
|
|
| # Be Bourne compatible
|
| if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
|
| @@ -91,10 +98,15 @@ fi
|
| BIN_SH=xpg4; export BIN_SH # for Tru64
|
| DUALCASE=1; export DUALCASE # for MKS sh
|
|
|
| +# A function that is used when there is no print builtin or printf.
|
| +func_fallback_echo ()
|
| +{
|
| + eval 'cat <<_LTECHO_EOF
|
| +$1
|
| +_LTECHO_EOF'
|
| +}
|
| +
|
| # NLS nuisances: We save the old values to restore during execute mode.
|
| -# Only set LANG and LC_ALL to C if already set.
|
| -# These must not be set unconditionally because not all systems understand
|
| -# e.g. LANG=C (notably SCO).
|
| lt_user_locale=
|
| lt_safe_locale=
|
| for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
|
| @@ -107,24 +119,28 @@ do
|
| lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\"
|
| fi"
|
| done
|
| +LC_ALL=C
|
| +LANGUAGE=C
|
| +export LANGUAGE LC_ALL
|
|
|
| $lt_unset CDPATH
|
|
|
|
|
| +# 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"
|
|
|
|
|
|
|
| : ${CP="cp -f"}
|
| -: ${ECHO="echo"}
|
| -: ${EGREP="/bin/grep -E"}
|
| -: ${FGREP="/bin/grep -F"}
|
| -: ${GREP="/bin/grep"}
|
| -: ${LN_S="ln -s"}
|
| +test "${ECHO+set}" = set || ECHO=${as_echo-'printf %s\n'}
|
| : ${MAKE="make"}
|
| : ${MKDIR="mkdir"}
|
| : ${MV="mv -f"}
|
| : ${RM="rm -f"}
|
| -: ${SED="/bin/sed"}
|
| : ${SHELL="${CONFIG_SHELL-/bin/sh}"}
|
| : ${Xsed="$SED -e 1s/^X//"}
|
|
|
| @@ -144,6 +160,27 @@ IFS=" $lt_nl"
|
| dirname="s,/[^/]*$,,"
|
| basename="s,^.*/,,"
|
|
|
| +# func_dirname file append nondir_replacement
|
| +# Compute the dirname of FILE. If nonempty, add APPEND to the result,
|
| +# otherwise set result to NONDIR_REPLACEMENT.
|
| +func_dirname ()
|
| +{
|
| + func_dirname_result=`$ECHO "${1}" | $SED "$dirname"`
|
| + if test "X$func_dirname_result" = "X${1}"; then
|
| + func_dirname_result="${3}"
|
| + else
|
| + func_dirname_result="$func_dirname_result${2}"
|
| + fi
|
| +} # func_dirname may be replaced by extended shell implementation
|
| +
|
| +
|
| +# func_basename file
|
| +func_basename ()
|
| +{
|
| + func_basename_result=`$ECHO "${1}" | $SED "$basename"`
|
| +} # func_basename may be replaced by extended shell implementation
|
| +
|
| +
|
| # func_dirname_and_basename file append nondir_replacement
|
| # perform func_basename and func_dirname in a single function
|
| # call:
|
| @@ -158,33 +195,183 @@ basename="s,^.*/,,"
|
| # those functions but instead duplicate the functionality here.
|
| func_dirname_and_basename ()
|
| {
|
| - # Extract subdirectory from the argument.
|
| - func_dirname_result=`$ECHO "X${1}" | $Xsed -e "$dirname"`
|
| - if test "X$func_dirname_result" = "X${1}"; then
|
| - func_dirname_result="${3}"
|
| - else
|
| - func_dirname_result="$func_dirname_result${2}"
|
| - fi
|
| - func_basename_result=`$ECHO "X${1}" | $Xsed -e "$basename"`
|
| + # Extract subdirectory from the argument.
|
| + func_dirname_result=`$ECHO "${1}" | $SED -e "$dirname"`
|
| + if test "X$func_dirname_result" = "X${1}"; then
|
| + func_dirname_result="${3}"
|
| + else
|
| + func_dirname_result="$func_dirname_result${2}"
|
| + fi
|
| + func_basename_result=`$ECHO "${1}" | $SED -e "$basename"`
|
| +} # func_dirname_and_basename may be replaced by extended shell implementation
|
| +
|
| +
|
| +# func_stripname prefix suffix name
|
| +# strip PREFIX and SUFFIX off of NAME.
|
| +# PREFIX and SUFFIX must not contain globbing or regex special
|
| +# characters, hashes, percent signs, but SUFFIX may contain a leading
|
| +# dot (in which case that matches only a dot).
|
| +# func_strip_suffix prefix name
|
| +func_stripname ()
|
| +{
|
| + case ${2} in
|
| + .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;;
|
| + *) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;;
|
| + esac
|
| +} # func_stripname may be replaced by extended shell implementation
|
| +
|
| +
|
| +# These SED scripts presuppose an absolute path with a trailing slash.
|
| +pathcar='s,^/\([^/]*\).*$,\1,'
|
| +pathcdr='s,^/[^/]*,,'
|
| +removedotparts=':dotsl
|
| + s@/\./@/@g
|
| + t dotsl
|
| + s,/\.$,/,'
|
| +collapseslashes='s@/\{1,\}@/@g'
|
| +finalslash='s,/*$,/,'
|
| +
|
| +# func_normal_abspath PATH
|
| +# Remove doubled-up and trailing slashes, "." path components,
|
| +# and cancel out any ".." path components in PATH after making
|
| +# it an absolute path.
|
| +# value returned in "$func_normal_abspath_result"
|
| +func_normal_abspath ()
|
| +{
|
| + # Start from root dir and reassemble the path.
|
| + func_normal_abspath_result=
|
| + func_normal_abspath_tpath=$1
|
| + func_normal_abspath_altnamespace=
|
| + case $func_normal_abspath_tpath in
|
| + "")
|
| + # Empty path, that just means $cwd.
|
| + func_stripname '' '/' "`pwd`"
|
| + func_normal_abspath_result=$func_stripname_result
|
| + return
|
| + ;;
|
| + # The next three entries are used to spot a run of precisely
|
| + # two leading slashes without using negated character classes;
|
| + # we take advantage of case's first-match behaviour.
|
| + ///*)
|
| + # Unusual form of absolute path, do nothing.
|
| + ;;
|
| + //*)
|
| + # Not necessarily an ordinary path; POSIX reserves leading '//'
|
| + # and for example Cygwin uses it to access remote file shares
|
| + # over CIFS/SMB, so we conserve a leading double slash if found.
|
| + func_normal_abspath_altnamespace=/
|
| + ;;
|
| + /*)
|
| + # Absolute path, do nothing.
|
| + ;;
|
| + *)
|
| + # Relative path, prepend $cwd.
|
| + func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath
|
| + ;;
|
| + esac
|
| + # Cancel out all the simple stuff to save iterations. We also want
|
| + # the path to end with a slash for ease of parsing, so make sure
|
| + # there is one (and only one) here.
|
| + func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
|
| + -e "$removedotparts" -e "$collapseslashes" -e "$finalslash"`
|
| + while :; do
|
| + # Processed it all yet?
|
| + if test "$func_normal_abspath_tpath" = / ; then
|
| + # If we ascended to the root using ".." the result may be empty now.
|
| + if test -z "$func_normal_abspath_result" ; then
|
| + func_normal_abspath_result=/
|
| + fi
|
| + break
|
| + fi
|
| + func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \
|
| + -e "$pathcar"`
|
| + func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
|
| + -e "$pathcdr"`
|
| + # Figure out what to do with it
|
| + case $func_normal_abspath_tcomponent in
|
| + "")
|
| + # Trailing empty path component, ignore it.
|
| + ;;
|
| + ..)
|
| + # Parent dir; strip last assembled component from result.
|
| + func_dirname "$func_normal_abspath_result"
|
| + func_normal_abspath_result=$func_dirname_result
|
| + ;;
|
| + *)
|
| + # Actual path component, append it.
|
| + func_normal_abspath_result=$func_normal_abspath_result/$func_normal_abspath_tcomponent
|
| + ;;
|
| + esac
|
| + done
|
| + # Restore leading double-slash if one was found on entry.
|
| + func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result
|
| }
|
|
|
| -# Generated shell functions inserted here.
|
| +# func_relative_path SRCDIR DSTDIR
|
| +# generates a relative path from SRCDIR to DSTDIR, with a trailing
|
| +# slash if non-empty, suitable for immediately appending a filename
|
| +# without needing to append a separator.
|
| +# value returned in "$func_relative_path_result"
|
| +func_relative_path ()
|
| +{
|
| + func_relative_path_result=
|
| + func_normal_abspath "$1"
|
| + func_relative_path_tlibdir=$func_normal_abspath_result
|
| + func_normal_abspath "$2"
|
| + func_relative_path_tbindir=$func_normal_abspath_result
|
| +
|
| + # Ascend the tree starting from libdir
|
| + while :; do
|
| + # check if we have found a prefix of bindir
|
| + case $func_relative_path_tbindir in
|
| + $func_relative_path_tlibdir)
|
| + # found an exact match
|
| + func_relative_path_tcancelled=
|
| + break
|
| + ;;
|
| + $func_relative_path_tlibdir*)
|
| + # found a matching prefix
|
| + func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir"
|
| + func_relative_path_tcancelled=$func_stripname_result
|
| + if test -z "$func_relative_path_result"; then
|
| + func_relative_path_result=.
|
| + fi
|
| + break
|
| + ;;
|
| + *)
|
| + func_dirname $func_relative_path_tlibdir
|
| + func_relative_path_tlibdir=${func_dirname_result}
|
| + if test "x$func_relative_path_tlibdir" = x ; then
|
| + # Have to descend all the way to the root!
|
| + func_relative_path_result=../$func_relative_path_result
|
| + func_relative_path_tcancelled=$func_relative_path_tbindir
|
| + break
|
| + fi
|
| + func_relative_path_result=../$func_relative_path_result
|
| + ;;
|
| + esac
|
| + done
|
|
|
| -# 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"
|
| + # Now calculate path; take care to avoid doubling-up slashes.
|
| + func_stripname '' '/' "$func_relative_path_result"
|
| + func_relative_path_result=$func_stripname_result
|
| + func_stripname '/' '/' "$func_relative_path_tcancelled"
|
| + if test "x$func_stripname_result" != x ; then
|
| + func_relative_path_result=${func_relative_path_result}/${func_stripname_result}
|
| + fi
|
| +
|
| + # Normalisation. If bindir is libdir, return empty string,
|
| + # else relative path ending with a slash; either way, target
|
| + # file name can be directly appended.
|
| + if test ! -z "$func_relative_path_result"; then
|
| + func_stripname './' '' "$func_relative_path_result/"
|
| + func_relative_path_result=$func_stripname_result
|
| + fi
|
| +}
|
|
|
| # The name of this program:
|
| -# In the unlikely event $progname began with a '-', it would play havoc with
|
| -# func_echo (imagine progname=-n), so we prepend ./ in that case:
|
| func_dirname_and_basename "$progpath"
|
| progname=$func_basename_result
|
| -case $progname in
|
| - -*) progname=./$progname ;;
|
| -esac
|
|
|
| # Make sure we have an absolute path for reexecution:
|
| case $progpath in
|
| @@ -196,7 +383,7 @@ case $progpath in
|
| ;;
|
| *)
|
| save_IFS="$IFS"
|
| - IFS=:
|
| + IFS=${PATH_SEPARATOR-:}
|
| for progdir in $PATH; do
|
| IFS="$save_IFS"
|
| test -x "$progdir/$progname" && break
|
| @@ -215,6 +402,15 @@ sed_quote_subst='s/\([`"$\\]\)/\\\1/g'
|
| # Same as above, but do not quote variable references.
|
| double_quote_subst='s/\(["`\\]\)/\\\1/g'
|
|
|
| +# Sed substitution that turns a string into a regex matching for the
|
| +# string literally.
|
| +sed_make_literal_regex='s,[].[^$\\*\/],\\&,g'
|
| +
|
| +# Sed substitution that converts a w32 file name or path
|
| +# which contains forward slashes, into one that contains
|
| +# (escaped) backslashes. A very naive implementation.
|
| +lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
|
| +
|
| # Re-`\' parameter expansions in output of double_quote_subst that were
|
| # `\'-ed in input to the same. If an odd number of `\' preceded a '$'
|
| # in input to double_quote_subst, that '$' was protected from expansion.
|
| @@ -243,7 +439,7 @@ opt_warning=:
|
| # name if it has been set yet.
|
| func_echo ()
|
| {
|
| - $ECHO "$progname${mode+: }$mode: $*"
|
| + $ECHO "$progname: ${opt_mode+$opt_mode: }$*"
|
| }
|
|
|
| # func_verbose arg...
|
| @@ -258,18 +454,25 @@ func_verbose ()
|
| :
|
| }
|
|
|
| +# func_echo_all arg...
|
| +# Invoke $ECHO with all args, space-separated.
|
| +func_echo_all ()
|
| +{
|
| + $ECHO "$*"
|
| +}
|
| +
|
| # func_error arg...
|
| # Echo program name prefixed message to standard error.
|
| func_error ()
|
| {
|
| - $ECHO "$progname${mode+: }$mode: "${1+"$@"} 1>&2
|
| + $ECHO "$progname: ${opt_mode+$opt_mode: }"${1+"$@"} 1>&2
|
| }
|
|
|
| # func_warning arg...
|
| # Echo program name prefixed warning message to standard error.
|
| func_warning ()
|
| {
|
| - $opt_warning && $ECHO "$progname${mode+: }$mode: warning: "${1+"$@"} 1>&2
|
| + $opt_warning && $ECHO "$progname: ${opt_mode+$opt_mode: }warning: "${1+"$@"} 1>&2
|
|
|
| # bash bug again:
|
| :
|
| @@ -326,9 +529,9 @@ func_mkdir_p ()
|
| case $my_directory_path in */*) ;; *) break ;; esac
|
|
|
| # ...otherwise throw away the child directory and loop
|
| - my_directory_path=`$ECHO "X$my_directory_path" | $Xsed -e "$dirname"`
|
| + my_directory_path=`$ECHO "$my_directory_path" | $SED -e "$dirname"`
|
| done
|
| - my_dir_list=`$ECHO "X$my_dir_list" | $Xsed -e 's,:*$,,'`
|
| + my_dir_list=`$ECHO "$my_dir_list" | $SED 's,:*$,,'`
|
|
|
| save_mkdir_p_IFS="$IFS"; IFS=':'
|
| for my_dir in $my_dir_list; do
|
| @@ -378,7 +581,7 @@ func_mktempdir ()
|
| func_fatal_error "cannot create temporary directory \`$my_tmpdir'"
|
| fi
|
|
|
| - $ECHO "X$my_tmpdir" | $Xsed
|
| + $ECHO "$my_tmpdir"
|
| }
|
|
|
|
|
| @@ -392,7 +595,7 @@ func_quote_for_eval ()
|
| {
|
| case $1 in
|
| *[\\\`\"\$]*)
|
| - func_quote_for_eval_unquoted_result=`$ECHO "X$1" | $Xsed -e "$sed_quote_subst"` ;;
|
| + func_quote_for_eval_unquoted_result=`$ECHO "$1" | $SED "$sed_quote_subst"` ;;
|
| *)
|
| func_quote_for_eval_unquoted_result="$1" ;;
|
| esac
|
| @@ -419,7 +622,7 @@ func_quote_for_expand ()
|
| {
|
| case $1 in
|
| *[\\\`\"]*)
|
| - my_arg=`$ECHO "X$1" | $Xsed \
|
| + my_arg=`$ECHO "$1" | $SED \
|
| -e "$double_quote_subst" -e "$sed_double_backslash"` ;;
|
| *)
|
| my_arg="$1" ;;
|
| @@ -488,15 +691,39 @@ func_show_eval_locale ()
|
| fi
|
| }
|
|
|
| -
|
| -
|
| +# func_tr_sh
|
| +# Turn $1 into a string suitable for a shell variable name.
|
| +# Result is stored in $func_tr_sh_result. All characters
|
| +# not in the set a-zA-Z0-9_ are replaced with '_'. Further,
|
| +# if $1 begins with a digit, a '_' is prepended as well.
|
| +func_tr_sh ()
|
| +{
|
| + case $1 in
|
| + [0-9]* | *[!a-zA-Z0-9_]*)
|
| + func_tr_sh_result=`$ECHO "$1" | $SED 's/^\([0-9]\)/_\1/; s/[^a-zA-Z0-9_]/_/g'`
|
| + ;;
|
| + * )
|
| + func_tr_sh_result=$1
|
| + ;;
|
| + esac
|
| +}
|
|
|
|
|
| # func_version
|
| # Echo version message to standard output and exit.
|
| func_version ()
|
| {
|
| - $SED -n '/^# '$PROGRAM' (GNU /,/# warranty; / {
|
| + $opt_debug
|
| +
|
| + $SED -n '/(C)/!b go
|
| + :more
|
| + /\./!{
|
| + N
|
| + s/\n# / /
|
| + b more
|
| + }
|
| + :go
|
| + /^# '$PROGRAM' (GNU /,/# warranty; / {
|
| s/^# //
|
| s/^# *$//
|
| s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/
|
| @@ -509,22 +736,28 @@ func_version ()
|
| # Echo short help message to standard output and exit.
|
| func_usage ()
|
| {
|
| - $SED -n '/^# Usage:/,/# -h/ {
|
| + $opt_debug
|
| +
|
| + $SED -n '/^# Usage:/,/^# *.*--help/ {
|
| s/^# //
|
| s/^# *$//
|
| s/\$progname/'$progname'/
|
| p
|
| }' < "$progpath"
|
| - $ECHO
|
| + echo
|
| $ECHO "run \`$progname --help | more' for full usage"
|
| exit $?
|
| }
|
|
|
| -# func_help
|
| -# Echo long help message to standard output and exit.
|
| +# func_help [NOEXIT]
|
| +# Echo long help message to standard output and exit,
|
| +# unless 'noexit' is passed as argument.
|
| func_help ()
|
| {
|
| + $opt_debug
|
| +
|
| $SED -n '/^# Usage:/,/# Report bugs to/ {
|
| + :print
|
| s/^# //
|
| s/^# *$//
|
| s*\$progname*'$progname'*
|
| @@ -534,11 +767,18 @@ func_help ()
|
| s*\$LTCFLAGS*'"$LTCFLAGS"'*
|
| s*\$LD*'"$LD"'*
|
| s/\$with_gnu_ld/'"$with_gnu_ld"'/
|
| - s/\$automake_version/'"`(automake --version) 2>/dev/null |$SED 1q`"'/
|
| - s/\$autoconf_version/'"`(autoconf --version) 2>/dev/null |$SED 1q`"'/
|
| + s/\$automake_version/'"`(${AUTOMAKE-automake} --version) 2>/dev/null |$SED 1q`"'/
|
| + s/\$autoconf_version/'"`(${AUTOCONF-autoconf} --version) 2>/dev/null |$SED 1q`"'/
|
| p
|
| - }' < "$progpath"
|
| - exit $?
|
| + d
|
| + }
|
| + /^# .* home page:/b print
|
| + /^# General help using/b print
|
| + ' < "$progpath"
|
| + ret=$?
|
| + if test -z "$1"; then
|
| + exit $ret
|
| + fi
|
| }
|
|
|
| # func_missing_arg argname
|
| @@ -546,63 +786,106 @@ func_help ()
|
| # exit_cmd.
|
| func_missing_arg ()
|
| {
|
| - func_error "missing argument for $1"
|
| + $opt_debug
|
| +
|
| + func_error "missing argument for $1."
|
| exit_cmd=exit
|
| }
|
|
|
| -exit_cmd=:
|
|
|
| +# func_split_short_opt shortopt
|
| +# Set func_split_short_opt_name and func_split_short_opt_arg shell
|
| +# variables after splitting SHORTOPT after the 2nd character.
|
| +func_split_short_opt ()
|
| +{
|
| + my_sed_short_opt='1s/^\(..\).*$/\1/;q'
|
| + my_sed_short_rest='1s/^..\(.*\)$/\1/;q'
|
|
|
| + func_split_short_opt_name=`$ECHO "$1" | $SED "$my_sed_short_opt"`
|
| + func_split_short_opt_arg=`$ECHO "$1" | $SED "$my_sed_short_rest"`
|
| +} # func_split_short_opt may be replaced by extended shell implementation
|
| +
|
| +
|
| +# func_split_long_opt longopt
|
| +# Set func_split_long_opt_name and func_split_long_opt_arg shell
|
| +# variables after splitting LONGOPT at the `=' sign.
|
| +func_split_long_opt ()
|
| +{
|
| + my_sed_long_opt='1s/^\(--[^=]*\)=.*/\1/;q'
|
| + my_sed_long_arg='1s/^--[^=]*=//'
|
| +
|
| + func_split_long_opt_name=`$ECHO "$1" | $SED "$my_sed_long_opt"`
|
| + func_split_long_opt_arg=`$ECHO "$1" | $SED "$my_sed_long_arg"`
|
| +} # func_split_long_opt may be replaced by extended shell implementation
|
| +
|
| +exit_cmd=:
|
|
|
|
|
|
|
| -# Check that we have a working $ECHO.
|
| -if test "X$1" = X--no-reexec; then
|
| - # Discard the --no-reexec flag, and continue.
|
| - shift
|
| -elif test "X$1" = X--fallback-echo; then
|
| - # Avoid inline document here, it may be left over
|
| - :
|
| -elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t'; then
|
| - # Yippee, $ECHO works!
|
| - :
|
| -else
|
| - # Restart under the correct shell, and then maybe $ECHO will work.
|
| - exec $SHELL "$progpath" --no-reexec ${1+"$@"}
|
| -fi
|
|
|
| -if test "X$1" = X--fallback-echo; then
|
| - # used as fallback echo
|
| - shift
|
| - cat <<EOF
|
| -$*
|
| -EOF
|
| - exit $EXIT_SUCCESS
|
| -fi
|
|
|
| magic="%%%MAGIC variable%%%"
|
| magic_exe="%%%MAGIC EXE variable%%%"
|
|
|
| # Global variables.
|
| -# $mode is unset
|
| nonopt=
|
| -execute_dlfiles=
|
| preserve_args=
|
| lo2o="s/\\.lo\$/.${objext}/"
|
| o2lo="s/\\.${objext}\$/.lo/"
|
| extracted_archives=
|
| extracted_serial=0
|
|
|
| -opt_dry_run=false
|
| -opt_duplicate_deps=false
|
| -opt_silent=false
|
| -opt_debug=:
|
| -
|
| # If this variable is set in any of the actions, the command in it
|
| # will be execed at the end. This prevents here-documents from being
|
| # left over by shells.
|
| exec_cmd=
|
|
|
| +# func_append var value
|
| +# Append VALUE to the end of shell variable VAR.
|
| +func_append ()
|
| +{
|
| + eval "${1}=\$${1}\${2}"
|
| +} # func_append may be replaced by extended shell implementation
|
| +
|
| +# func_append_quoted var value
|
| +# Quote VALUE and append to the end of shell variable VAR, separated
|
| +# by a space.
|
| +func_append_quoted ()
|
| +{
|
| + func_quote_for_eval "${2}"
|
| + eval "${1}=\$${1}\\ \$func_quote_for_eval_result"
|
| +} # func_append_quoted may be replaced by extended shell implementation
|
| +
|
| +
|
| +# func_arith arithmetic-term...
|
| +func_arith ()
|
| +{
|
| + func_arith_result=`expr "${@}"`
|
| +} # func_arith may be replaced by extended shell implementation
|
| +
|
| +
|
| +# func_len string
|
| +# STRING may not start with a hyphen.
|
| +func_len ()
|
| +{
|
| + func_len_result=`expr "${1}" : ".*" 2>/dev/null || echo $max_cmd_len`
|
| +} # func_len may be replaced by extended shell implementation
|
| +
|
| +
|
| +# func_lo2o object
|
| +func_lo2o ()
|
| +{
|
| + func_lo2o_result=`$ECHO "${1}" | $SED "$lo2o"`
|
| +} # func_lo2o may be replaced by extended shell implementation
|
| +
|
| +
|
| +# func_xform libobj-or-source
|
| +func_xform ()
|
| +{
|
| + func_xform_result=`$ECHO "${1}" | $SED 's/\.[^.]*$/.lo/'`
|
| +} # func_xform may be replaced by extended shell implementation
|
| +
|
| +
|
| # func_fatal_configuration arg...
|
| # Echo program name prefixed message to standard error, followed by
|
| # a configuration failure hint, and exit.
|
| @@ -636,16 +919,16 @@ func_config ()
|
| # Display the features supported by this script.
|
| func_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 $?
|
| @@ -692,117 +975,209 @@ func_enable_tag ()
|
| esac
|
| }
|
|
|
| -# Parse options once, thoroughly. This comes as soon as possible in
|
| -# the script to make things like `libtool --version' happen quickly.
|
| +# func_check_version_match
|
| +# Ensure that we are using m4 macros, and libtool script from the same
|
| +# release of libtool.
|
| +func_check_version_match ()
|
| {
|
| + if test "$package_revision" != "$macro_revision"; then
|
| + if test "$VERSION" != "$macro_version"; then
|
| + if test -z "$macro_version"; then
|
| + cat >&2 <<_LT_EOF
|
| +$progname: Version mismatch error. This is $PACKAGE $VERSION, but the
|
| +$progname: definition of this LT_INIT comes from an older release.
|
| +$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
|
| +$progname: and run autoconf again.
|
| +_LT_EOF
|
| + else
|
| + cat >&2 <<_LT_EOF
|
| +$progname: Version mismatch error. This is $PACKAGE $VERSION, but the
|
| +$progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
|
| +$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
|
| +$progname: and run autoconf again.
|
| +_LT_EOF
|
| + fi
|
| + else
|
| + cat >&2 <<_LT_EOF
|
| +$progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision,
|
| +$progname: but the definition of this LT_INIT comes from revision $macro_revision.
|
| +$progname: You should recreate aclocal.m4 with macros from revision $package_revision
|
| +$progname: of $PACKAGE $VERSION and run autoconf again.
|
| +_LT_EOF
|
| + fi
|
| +
|
| + exit $EXIT_MISMATCH
|
| + fi
|
| +}
|
| +
|
| +
|
| +# Shorthand for --mode=foo, only valid as the first argument
|
| +case $1 in
|
| +clean|clea|cle|cl)
|
| + shift; set dummy --mode clean ${1+"$@"}; shift
|
| + ;;
|
| +compile|compil|compi|comp|com|co|c)
|
| + shift; set dummy --mode compile ${1+"$@"}; shift
|
| + ;;
|
| +execute|execut|execu|exec|exe|ex|e)
|
| + shift; set dummy --mode execute ${1+"$@"}; shift
|
| + ;;
|
| +finish|finis|fini|fin|fi|f)
|
| + shift; set dummy --mode finish ${1+"$@"}; shift
|
| + ;;
|
| +install|instal|insta|inst|ins|in|i)
|
| + shift; set dummy --mode install ${1+"$@"}; shift
|
| + ;;
|
| +link|lin|li|l)
|
| + shift; set dummy --mode link ${1+"$@"}; shift
|
| + ;;
|
| +uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
|
| + shift; set dummy --mode uninstall ${1+"$@"}; shift
|
| + ;;
|
| +esac
|
| +
|
| +
|
| +
|
| +# Option defaults:
|
| +opt_debug=:
|
| +opt_dry_run=false
|
| +opt_config=false
|
| +opt_preserve_dup_deps=false
|
| +opt_features=false
|
| +opt_finish=false
|
| +opt_help=false
|
| +opt_help_all=false
|
| +opt_silent=:
|
| +opt_warning=:
|
| +opt_verbose=:
|
| +opt_silent=false
|
| +opt_verbose=false
|
|
|
| - # Shorthand for --mode=foo, only valid as the first argument
|
| - case $1 in
|
| - clean|clea|cle|cl)
|
| - shift; set dummy --mode clean ${1+"$@"}; shift
|
| - ;;
|
| - compile|compil|compi|comp|com|co|c)
|
| - shift; set dummy --mode compile ${1+"$@"}; shift
|
| - ;;
|
| - execute|execut|execu|exec|exe|ex|e)
|
| - shift; set dummy --mode execute ${1+"$@"}; shift
|
| - ;;
|
| - finish|finis|fini|fin|fi|f)
|
| - shift; set dummy --mode finish ${1+"$@"}; shift
|
| - ;;
|
| - install|instal|insta|inst|ins|in|i)
|
| - shift; set dummy --mode install ${1+"$@"}; shift
|
| - ;;
|
| - link|lin|li|l)
|
| - shift; set dummy --mode link ${1+"$@"}; shift
|
| - ;;
|
| - uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
|
| - shift; set dummy --mode uninstall ${1+"$@"}; shift
|
| - ;;
|
| - esac
|
|
|
| - # Parse non-mode specific arguments:
|
| - while test "$#" -gt 0; do
|
| +# Parse options once, thoroughly. This comes as soon as possible in the
|
| +# script to make things like `--version' happen as quickly as we can.
|
| +{
|
| + # this just eases exit handling
|
| + while test $# -gt 0; do
|
| opt="$1"
|
| shift
|
| -
|
| case $opt in
|
| - --config) func_config ;;
|
| -
|
| - --debug) preserve_args="$preserve_args $opt"
|
| + --debug|-x) opt_debug='set -x'
|
| func_echo "enabling shell trace mode"
|
| - opt_debug='set -x'
|
| $opt_debug
|
| ;;
|
| -
|
| - -dlopen) test "$#" -eq 0 && func_missing_arg "$opt" && break
|
| - execute_dlfiles="$execute_dlfiles $1"
|
| - shift
|
| + --dry-run|--dryrun|-n)
|
| + opt_dry_run=:
|
| ;;
|
| -
|
| - --dry-run | -n) opt_dry_run=: ;;
|
| - --features) func_features ;;
|
| - --finish) mode="finish" ;;
|
| -
|
| - --mode) test "$#" -eq 0 && func_missing_arg "$opt" && break
|
| - case $1 in
|
| - # Valid mode arguments:
|
| - clean) ;;
|
| - compile) ;;
|
| - execute) ;;
|
| - finish) ;;
|
| - install) ;;
|
| - link) ;;
|
| - relink) ;;
|
| - uninstall) ;;
|
| -
|
| - # Catch anything else as an error
|
| - *) func_error "invalid argument for $opt"
|
| - exit_cmd=exit
|
| - break
|
| - ;;
|
| - esac
|
| -
|
| - mode="$1"
|
| + --config)
|
| + opt_config=:
|
| +func_config
|
| + ;;
|
| + --dlopen|-dlopen)
|
| + optarg="$1"
|
| + opt_dlopen="${opt_dlopen+$opt_dlopen
|
| +}$optarg"
|
| shift
|
| ;;
|
| -
|
| --preserve-dup-deps)
|
| - opt_duplicate_deps=: ;;
|
| -
|
| - --quiet|--silent) preserve_args="$preserve_args $opt"
|
| - opt_silent=:
|
| + opt_preserve_dup_deps=:
|
| ;;
|
| -
|
| - --verbose| -v) preserve_args="$preserve_args $opt"
|
| + --features)
|
| + opt_features=:
|
| +func_features
|
| + ;;
|
| + --finish)
|
| + opt_finish=:
|
| +set dummy --mode finish ${1+"$@"}; shift
|
| + ;;
|
| + --help)
|
| + opt_help=:
|
| + ;;
|
| + --help-all)
|
| + opt_help_all=:
|
| +opt_help=': help-all'
|
| + ;;
|
| + --mode)
|
| + test $# = 0 && func_missing_arg $opt && break
|
| + optarg="$1"
|
| + opt_mode="$optarg"
|
| +case $optarg in
|
| + # Valid mode arguments:
|
| + clean|compile|execute|finish|install|link|relink|uninstall) ;;
|
| +
|
| + # Catch anything else as an error
|
| + *) func_error "invalid argument for $opt"
|
| + exit_cmd=exit
|
| + break
|
| + ;;
|
| +esac
|
| + shift
|
| + ;;
|
| + --no-silent|--no-quiet)
|
| opt_silent=false
|
| +func_append preserve_args " $opt"
|
| ;;
|
| -
|
| - --tag) test "$#" -eq 0 && func_missing_arg "$opt" && break
|
| - preserve_args="$preserve_args $opt $1"
|
| - func_enable_tag "$1" # tagname is set here
|
| + --no-warning|--no-warn)
|
| + opt_warning=false
|
| +func_append preserve_args " $opt"
|
| + ;;
|
| + --no-verbose)
|
| + opt_verbose=false
|
| +func_append preserve_args " $opt"
|
| + ;;
|
| + --silent|--quiet)
|
| + opt_silent=:
|
| +func_append preserve_args " $opt"
|
| + opt_verbose=false
|
| + ;;
|
| + --verbose|-v)
|
| + opt_verbose=:
|
| +func_append preserve_args " $opt"
|
| +opt_silent=false
|
| + ;;
|
| + --tag)
|
| + test $# = 0 && func_missing_arg $opt && break
|
| + optarg="$1"
|
| + opt_tag="$optarg"
|
| +func_append preserve_args " $opt $optarg"
|
| +func_enable_tag "$optarg"
|
| shift
|
| ;;
|
|
|
| + -\?|-h) func_usage ;;
|
| + --help) func_help ;;
|
| + --version) func_version ;;
|
| +
|
| # Separate optargs to long options:
|
| - -dlopen=*|--mode=*|--tag=*)
|
| - func_opt_split "$opt"
|
| - set dummy "$func_opt_split_opt" "$func_opt_split_arg" ${1+"$@"}
|
| + --*=*)
|
| + func_split_long_opt "$opt"
|
| + set dummy "$func_split_long_opt_name" "$func_split_long_opt_arg" ${1+"$@"}
|
| shift
|
| ;;
|
|
|
| - -\?|-h) func_usage ;;
|
| - --help) opt_help=: ;;
|
| - --version) func_version ;;
|
| -
|
| - -*) func_fatal_help "unrecognized option \`$opt'" ;;
|
| -
|
| - *) nonopt="$opt"
|
| - break
|
| + # Separate non-argument short options:
|
| + -\?*|-h*|-n*|-v*)
|
| + func_split_short_opt "$opt"
|
| + set dummy "$func_split_short_opt_name" "-$func_split_short_opt_arg" ${1+"$@"}
|
| + shift
|
| ;;
|
| +
|
| + --) break ;;
|
| + -*) func_fatal_help "unrecognized option \`$opt'" ;;
|
| + *) set dummy "$opt" ${1+"$@"}; shift; break ;;
|
| esac
|
| done
|
|
|
| + # Validate options:
|
| +
|
| + # save first non-option argument
|
| + if test "$#" -gt 0; then
|
| + nonopt="$opt"
|
| + shift
|
| + fi
|
| +
|
| + # preserve --debug
|
| + test "$opt_debug" = : || func_append preserve_args " --debug"
|
|
|
| case $host in
|
| *cygwin* | *mingw* | *pw32* | *cegcc*)
|
| @@ -810,82 +1185,44 @@ func_enable_tag ()
|
| opt_duplicate_compiler_generated_deps=:
|
| ;;
|
| *)
|
| - opt_duplicate_compiler_generated_deps=$opt_duplicate_deps
|
| + opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
|
| ;;
|
| esac
|
|
|
| - # Having warned about all mis-specified options, bail out if
|
| - # anything was wrong.
|
| - $exit_cmd $EXIT_FAILURE
|
| -}
|
| + $opt_help || {
|
| + # Sanity checks first:
|
| + func_check_version_match
|
|
|
| -# func_check_version_match
|
| -# Ensure that we are using m4 macros, and libtool script from the same
|
| -# release of libtool.
|
| -func_check_version_match ()
|
| -{
|
| - if test "$package_revision" != "$macro_revision"; then
|
| - if test "$VERSION" != "$macro_version"; then
|
| - if test -z "$macro_version"; then
|
| - cat >&2 <<_LT_EOF
|
| -$progname: Version mismatch error. This is $PACKAGE $VERSION, but the
|
| -$progname: definition of this LT_INIT comes from an older release.
|
| -$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
|
| -$progname: and run autoconf again.
|
| -_LT_EOF
|
| - else
|
| - cat >&2 <<_LT_EOF
|
| -$progname: Version mismatch error. This is $PACKAGE $VERSION, but the
|
| -$progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
|
| -$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
|
| -$progname: and run autoconf again.
|
| -_LT_EOF
|
| - fi
|
| - else
|
| - cat >&2 <<_LT_EOF
|
| -$progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision,
|
| -$progname: but the definition of this LT_INIT comes from revision $macro_revision.
|
| -$progname: You should recreate aclocal.m4 with macros from revision $package_revision
|
| -$progname: of $PACKAGE $VERSION and run autoconf again.
|
| -_LT_EOF
|
| + if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
|
| + func_fatal_configuration "not configured to build any kind of library"
|
| fi
|
|
|
| - exit $EXIT_MISMATCH
|
| - fi
|
| -}
|
| -
|
| -
|
| -## ----------- ##
|
| -## Main. ##
|
| -## ----------- ##
|
| -
|
| -$opt_help || {
|
| - # Sanity checks first:
|
| - func_check_version_match
|
| + # Darwin sucks
|
| + eval std_shrext=\"$shrext_cmds\"
|
|
|
| - if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
|
| - func_fatal_configuration "not configured to build any kind of library"
|
| - fi
|
| + # Only execute mode is allowed to have -dlopen flags.
|
| + if test -n "$opt_dlopen" && test "$opt_mode" != execute; then
|
| + func_error "unrecognized option \`-dlopen'"
|
| + $ECHO "$help" 1>&2
|
| + exit $EXIT_FAILURE
|
| + fi
|
|
|
| - test -z "$mode" && func_fatal_error "error: you must specify a MODE."
|
| + # Change the help message to a mode-specific one.
|
| + generic_help="$help"
|
| + help="Try \`$progname --help --mode=$opt_mode' for more information."
|
| + }
|
|
|
|
|
| - # Darwin sucks
|
| - eval std_shrext=\"$shrext_cmds\"
|
| + # Bail if the options were screwed
|
| + $exit_cmd $EXIT_FAILURE
|
| +}
|
|
|
|
|
| - # Only execute mode is allowed to have -dlopen flags.
|
| - if test -n "$execute_dlfiles" && test "$mode" != execute; then
|
| - func_error "unrecognized option \`-dlopen'"
|
| - $ECHO "$help" 1>&2
|
| - exit $EXIT_FAILURE
|
| - fi
|
|
|
| - # Change the help message to a mode-specific one.
|
| - generic_help="$help"
|
| - help="Try \`$progname --help --mode=$mode' for more information."
|
| -}
|
|
|
| +## ----------- ##
|
| +## Main. ##
|
| +## ----------- ##
|
|
|
| # func_lalib_p file
|
| # True iff FILE is a libtool `.la' library or `.lo' object file.
|
| @@ -950,12 +1287,9 @@ func_ltwrapper_executable_p ()
|
| # temporary ltwrapper_script.
|
| func_ltwrapper_scriptname ()
|
| {
|
| - func_ltwrapper_scriptname_result=""
|
| - if func_ltwrapper_executable_p "$1"; then
|
| - func_dirname_and_basename "$1" "" "."
|
| - func_stripname '' '.exe' "$func_basename_result"
|
| - func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper"
|
| - fi
|
| + func_dirname_and_basename "$1" "" "."
|
| + func_stripname '' '.exe' "$func_basename_result"
|
| + func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper"
|
| }
|
|
|
| # func_ltwrapper_p file
|
| @@ -1001,6 +1335,37 @@ func_source ()
|
| }
|
|
|
|
|
| +# func_resolve_sysroot PATH
|
| +# Replace a leading = in PATH with a sysroot. Store the result into
|
| +# func_resolve_sysroot_result
|
| +func_resolve_sysroot ()
|
| +{
|
| + func_resolve_sysroot_result=$1
|
| + case $func_resolve_sysroot_result in
|
| + =*)
|
| + func_stripname '=' '' "$func_resolve_sysroot_result"
|
| + func_resolve_sysroot_result=$lt_sysroot$func_stripname_result
|
| + ;;
|
| + esac
|
| +}
|
| +
|
| +# func_replace_sysroot PATH
|
| +# If PATH begins with the sysroot, replace it with = and
|
| +# store the result into func_replace_sysroot_result.
|
| +func_replace_sysroot ()
|
| +{
|
| + case "$lt_sysroot:$1" in
|
| + ?*:"$lt_sysroot"*)
|
| + func_stripname "$lt_sysroot" '' "$1"
|
| + func_replace_sysroot_result="=$func_stripname_result"
|
| + ;;
|
| + *)
|
| + # Including no sysroot.
|
| + func_replace_sysroot_result=$1
|
| + ;;
|
| + esac
|
| +}
|
| +
|
| # 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.
|
| @@ -1013,13 +1378,15 @@ func_infer_tag ()
|
| if test -n "$available_tags" && test -z "$tagname"; then
|
| CC_quoted=
|
| for arg in $CC; do
|
| - func_quote_for_eval "$arg"
|
| - CC_quoted="$CC_quoted $func_quote_for_eval_result"
|
| + func_append_quoted CC_quoted "$arg"
|
| done
|
| + CC_expanded=`func_echo_all $CC`
|
| + CC_quoted_expanded=`func_echo_all $CC_quoted`
|
| 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` "*) ;;
|
| + " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
|
| + " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;;
|
| # Blanks at the start of $base_compile will cause this to fail
|
| # if we don't check for them as well.
|
| *)
|
| @@ -1030,11 +1397,13 @@ func_infer_tag ()
|
| CC_quoted=
|
| for arg in $CC; do
|
| # Double-quote args containing other shell metacharacters.
|
| - func_quote_for_eval "$arg"
|
| - CC_quoted="$CC_quoted $func_quote_for_eval_result"
|
| + func_append_quoted CC_quoted "$arg"
|
| done
|
| + CC_expanded=`func_echo_all $CC`
|
| + CC_quoted_expanded=`func_echo_all $CC_quoted`
|
| case "$@ " in
|
| - " $CC "* | "$CC "* | " `$ECHO $CC` "* | "`$ECHO $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$ECHO $CC_quoted` "* | "`$ECHO $CC_quoted` "*)
|
| + " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
|
| + " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*)
|
| # The compiler in the base compile command matches
|
| # the one in the tagged configuration.
|
| # Assume this is the tagged configuration we want.
|
| @@ -1097,6 +1466,486 @@ EOF
|
| }
|
| }
|
|
|
| +
|
| +##################################################
|
| +# FILE NAME AND PATH CONVERSION HELPER FUNCTIONS #
|
| +##################################################
|
| +
|
| +# func_convert_core_file_wine_to_w32 ARG
|
| +# Helper function used by file name conversion functions when $build is *nix,
|
| +# and $host is mingw, cygwin, or some other w32 environment. Relies on a
|
| +# correctly configured wine environment available, with the winepath program
|
| +# in $build's $PATH.
|
| +#
|
| +# ARG is the $build file name to be converted to w32 format.
|
| +# Result is available in $func_convert_core_file_wine_to_w32_result, and will
|
| +# be empty on error (or when ARG is empty)
|
| +func_convert_core_file_wine_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + func_convert_core_file_wine_to_w32_result="$1"
|
| + if test -n "$1"; then
|
| + # Unfortunately, winepath does not exit with a non-zero error code, so we
|
| + # are forced to check the contents of stdout. On the other hand, if the
|
| + # command is not found, the shell will set an exit code of 127 and print
|
| + # *an error message* to stdout. So we must check for both error code of
|
| + # zero AND non-empty stdout, which explains the odd construction:
|
| + func_convert_core_file_wine_to_w32_tmp=`winepath -w "$1" 2>/dev/null`
|
| + if test "$?" -eq 0 && test -n "${func_convert_core_file_wine_to_w32_tmp}"; then
|
| + func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" |
|
| + $SED -e "$lt_sed_naive_backslashify"`
|
| + else
|
| + func_convert_core_file_wine_to_w32_result=
|
| + fi
|
| + fi
|
| +}
|
| +# end: func_convert_core_file_wine_to_w32
|
| +
|
| +
|
| +# func_convert_core_path_wine_to_w32 ARG
|
| +# Helper function used by path conversion functions when $build is *nix, and
|
| +# $host is mingw, cygwin, or some other w32 environment. Relies on a correctly
|
| +# configured wine environment available, with the winepath program in $build's
|
| +# $PATH. Assumes ARG has no leading or trailing path separator characters.
|
| +#
|
| +# ARG is path to be converted from $build format to win32.
|
| +# Result is available in $func_convert_core_path_wine_to_w32_result.
|
| +# Unconvertible file (directory) names in ARG are skipped; if no directory names
|
| +# are convertible, then the result may be empty.
|
| +func_convert_core_path_wine_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + # unfortunately, winepath doesn't convert paths, only file names
|
| + func_convert_core_path_wine_to_w32_result=""
|
| + if test -n "$1"; then
|
| + oldIFS=$IFS
|
| + IFS=:
|
| + for func_convert_core_path_wine_to_w32_f in $1; do
|
| + IFS=$oldIFS
|
| + func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f"
|
| + if test -n "$func_convert_core_file_wine_to_w32_result" ; then
|
| + if test -z "$func_convert_core_path_wine_to_w32_result"; then
|
| + func_convert_core_path_wine_to_w32_result="$func_convert_core_file_wine_to_w32_result"
|
| + else
|
| + func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result"
|
| + fi
|
| + fi
|
| + done
|
| + IFS=$oldIFS
|
| + fi
|
| +}
|
| +# end: func_convert_core_path_wine_to_w32
|
| +
|
| +
|
| +# func_cygpath ARGS...
|
| +# Wrapper around calling the cygpath program via LT_CYGPATH. This is used when
|
| +# when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2)
|
| +# $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or
|
| +# (2), returns the Cygwin file name or path in func_cygpath_result (input
|
| +# file name or path is assumed to be in w32 format, as previously converted
|
| +# from $build's *nix or MSYS format). In case (3), returns the w32 file name
|
| +# or path in func_cygpath_result (input file name or path is assumed to be in
|
| +# Cygwin format). Returns an empty string on error.
|
| +#
|
| +# ARGS are passed to cygpath, with the last one being the file name or path to
|
| +# be converted.
|
| +#
|
| +# Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH
|
| +# environment variable; do not put it in $PATH.
|
| +func_cygpath ()
|
| +{
|
| + $opt_debug
|
| + if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then
|
| + func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null`
|
| + if test "$?" -ne 0; then
|
| + # on failure, ensure result is empty
|
| + func_cygpath_result=
|
| + fi
|
| + else
|
| + func_cygpath_result=
|
| + func_error "LT_CYGPATH is empty or specifies non-existent file: \`$LT_CYGPATH'"
|
| + fi
|
| +}
|
| +#end: func_cygpath
|
| +
|
| +
|
| +# func_convert_core_msys_to_w32 ARG
|
| +# Convert file name or path ARG from MSYS format to w32 format. Return
|
| +# result in func_convert_core_msys_to_w32_result.
|
| +func_convert_core_msys_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + # awkward: cmd appends spaces to result
|
| + func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null |
|
| + $SED -e 's/[ ]*$//' -e "$lt_sed_naive_backslashify"`
|
| +}
|
| +#end: func_convert_core_msys_to_w32
|
| +
|
| +
|
| +# func_convert_file_check ARG1 ARG2
|
| +# Verify that ARG1 (a file name in $build format) was converted to $host
|
| +# format in ARG2. Otherwise, emit an error message, but continue (resetting
|
| +# func_to_host_file_result to ARG1).
|
| +func_convert_file_check ()
|
| +{
|
| + $opt_debug
|
| + if test -z "$2" && test -n "$1" ; then
|
| + func_error "Could not determine host file name corresponding to"
|
| + func_error " \`$1'"
|
| + func_error "Continuing, but uninstalled executables may not work."
|
| + # Fallback:
|
| + func_to_host_file_result="$1"
|
| + fi
|
| +}
|
| +# end func_convert_file_check
|
| +
|
| +
|
| +# func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH
|
| +# Verify that FROM_PATH (a path in $build format) was converted to $host
|
| +# format in TO_PATH. Otherwise, emit an error message, but continue, resetting
|
| +# func_to_host_file_result to a simplistic fallback value (see below).
|
| +func_convert_path_check ()
|
| +{
|
| + $opt_debug
|
| + if test -z "$4" && test -n "$3"; then
|
| + func_error "Could not determine the host path corresponding to"
|
| + func_error " \`$3'"
|
| + func_error "Continuing, but uninstalled executables may not work."
|
| + # Fallback. This is a deliberately simplistic "conversion" and
|
| + # should not be "improved". See libtool.info.
|
| + if test "x$1" != "x$2"; then
|
| + lt_replace_pathsep_chars="s|$1|$2|g"
|
| + func_to_host_path_result=`echo "$3" |
|
| + $SED -e "$lt_replace_pathsep_chars"`
|
| + else
|
| + func_to_host_path_result="$3"
|
| + fi
|
| + fi
|
| +}
|
| +# end func_convert_path_check
|
| +
|
| +
|
| +# func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG
|
| +# Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT
|
| +# and appending REPL if ORIG matches BACKPAT.
|
| +func_convert_path_front_back_pathsep ()
|
| +{
|
| + $opt_debug
|
| + case $4 in
|
| + $1 ) func_to_host_path_result="$3$func_to_host_path_result"
|
| + ;;
|
| + esac
|
| + case $4 in
|
| + $2 ) func_append func_to_host_path_result "$3"
|
| + ;;
|
| + esac
|
| +}
|
| +# end func_convert_path_front_back_pathsep
|
| +
|
| +
|
| +##################################################
|
| +# $build to $host FILE NAME CONVERSION FUNCTIONS #
|
| +##################################################
|
| +# invoked via `$to_host_file_cmd ARG'
|
| +#
|
| +# In each case, ARG is the path to be converted from $build to $host format.
|
| +# Result will be available in $func_to_host_file_result.
|
| +
|
| +
|
| +# func_to_host_file ARG
|
| +# Converts the file name ARG from $build format to $host format. Return result
|
| +# in func_to_host_file_result.
|
| +func_to_host_file ()
|
| +{
|
| + $opt_debug
|
| + $to_host_file_cmd "$1"
|
| +}
|
| +# end func_to_host_file
|
| +
|
| +
|
| +# func_to_tool_file ARG LAZY
|
| +# converts the file name ARG from $build format to toolchain format. Return
|
| +# result in func_to_tool_file_result. If the conversion in use is listed
|
| +# in (the comma separated) LAZY, no conversion takes place.
|
| +func_to_tool_file ()
|
| +{
|
| + $opt_debug
|
| + case ,$2, in
|
| + *,"$to_tool_file_cmd",*)
|
| + func_to_tool_file_result=$1
|
| + ;;
|
| + *)
|
| + $to_tool_file_cmd "$1"
|
| + func_to_tool_file_result=$func_to_host_file_result
|
| + ;;
|
| + esac
|
| +}
|
| +# end func_to_tool_file
|
| +
|
| +
|
| +# func_convert_file_noop ARG
|
| +# Copy ARG to func_to_host_file_result.
|
| +func_convert_file_noop ()
|
| +{
|
| + func_to_host_file_result="$1"
|
| +}
|
| +# end func_convert_file_noop
|
| +
|
| +
|
| +# func_convert_file_msys_to_w32 ARG
|
| +# Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic
|
| +# conversion to w32 is not available inside the cwrapper. Returns result in
|
| +# func_to_host_file_result.
|
| +func_convert_file_msys_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_file_result="$1"
|
| + if test -n "$1"; then
|
| + func_convert_core_msys_to_w32 "$1"
|
| + func_to_host_file_result="$func_convert_core_msys_to_w32_result"
|
| + fi
|
| + func_convert_file_check "$1" "$func_to_host_file_result"
|
| +}
|
| +# end func_convert_file_msys_to_w32
|
| +
|
| +
|
| +# func_convert_file_cygwin_to_w32 ARG
|
| +# Convert file name ARG from Cygwin to w32 format. Returns result in
|
| +# func_to_host_file_result.
|
| +func_convert_file_cygwin_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_file_result="$1"
|
| + if test -n "$1"; then
|
| + # because $build is cygwin, we call "the" cygpath in $PATH; no need to use
|
| + # LT_CYGPATH in this case.
|
| + func_to_host_file_result=`cygpath -m "$1"`
|
| + fi
|
| + func_convert_file_check "$1" "$func_to_host_file_result"
|
| +}
|
| +# end func_convert_file_cygwin_to_w32
|
| +
|
| +
|
| +# func_convert_file_nix_to_w32 ARG
|
| +# Convert file name ARG from *nix to w32 format. Requires a wine environment
|
| +# and a working winepath. Returns result in func_to_host_file_result.
|
| +func_convert_file_nix_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_file_result="$1"
|
| + if test -n "$1"; then
|
| + func_convert_core_file_wine_to_w32 "$1"
|
| + func_to_host_file_result="$func_convert_core_file_wine_to_w32_result"
|
| + fi
|
| + func_convert_file_check "$1" "$func_to_host_file_result"
|
| +}
|
| +# end func_convert_file_nix_to_w32
|
| +
|
| +
|
| +# func_convert_file_msys_to_cygwin ARG
|
| +# Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set.
|
| +# Returns result in func_to_host_file_result.
|
| +func_convert_file_msys_to_cygwin ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_file_result="$1"
|
| + if test -n "$1"; then
|
| + func_convert_core_msys_to_w32 "$1"
|
| + func_cygpath -u "$func_convert_core_msys_to_w32_result"
|
| + func_to_host_file_result="$func_cygpath_result"
|
| + fi
|
| + func_convert_file_check "$1" "$func_to_host_file_result"
|
| +}
|
| +# end func_convert_file_msys_to_cygwin
|
| +
|
| +
|
| +# func_convert_file_nix_to_cygwin ARG
|
| +# Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed
|
| +# in a wine environment, working winepath, and LT_CYGPATH set. Returns result
|
| +# in func_to_host_file_result.
|
| +func_convert_file_nix_to_cygwin ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_file_result="$1"
|
| + if test -n "$1"; then
|
| + # convert from *nix to w32, then use cygpath to convert from w32 to cygwin.
|
| + func_convert_core_file_wine_to_w32 "$1"
|
| + func_cygpath -u "$func_convert_core_file_wine_to_w32_result"
|
| + func_to_host_file_result="$func_cygpath_result"
|
| + fi
|
| + func_convert_file_check "$1" "$func_to_host_file_result"
|
| +}
|
| +# end func_convert_file_nix_to_cygwin
|
| +
|
| +
|
| +#############################################
|
| +# $build to $host PATH CONVERSION FUNCTIONS #
|
| +#############################################
|
| +# invoked via `$to_host_path_cmd ARG'
|
| +#
|
| +# In each case, ARG is the path to be converted from $build to $host format.
|
| +# The result will be available in $func_to_host_path_result.
|
| +#
|
| +# Path separators are also converted from $build format to $host format. If
|
| +# ARG begins or ends with a path separator character, it is preserved (but
|
| +# converted to $host format) on output.
|
| +#
|
| +# All path conversion functions are named using the following convention:
|
| +# file name conversion function : func_convert_file_X_to_Y ()
|
| +# path conversion function : func_convert_path_X_to_Y ()
|
| +# where, for any given $build/$host combination the 'X_to_Y' value is the
|
| +# same. If conversion functions are added for new $build/$host combinations,
|
| +# the two new functions must follow this pattern, or func_init_to_host_path_cmd
|
| +# will break.
|
| +
|
| +
|
| +# func_init_to_host_path_cmd
|
| +# Ensures that function "pointer" variable $to_host_path_cmd is set to the
|
| +# appropriate value, based on the value of $to_host_file_cmd.
|
| +to_host_path_cmd=
|
| +func_init_to_host_path_cmd ()
|
| +{
|
| + $opt_debug
|
| + if test -z "$to_host_path_cmd"; then
|
| + func_stripname 'func_convert_file_' '' "$to_host_file_cmd"
|
| + to_host_path_cmd="func_convert_path_${func_stripname_result}"
|
| + fi
|
| +}
|
| +
|
| +
|
| +# func_to_host_path ARG
|
| +# Converts the path ARG from $build format to $host format. Return result
|
| +# in func_to_host_path_result.
|
| +func_to_host_path ()
|
| +{
|
| + $opt_debug
|
| + func_init_to_host_path_cmd
|
| + $to_host_path_cmd "$1"
|
| +}
|
| +# end func_to_host_path
|
| +
|
| +
|
| +# func_convert_path_noop ARG
|
| +# Copy ARG to func_to_host_path_result.
|
| +func_convert_path_noop ()
|
| +{
|
| + func_to_host_path_result="$1"
|
| +}
|
| +# end func_convert_path_noop
|
| +
|
| +
|
| +# func_convert_path_msys_to_w32 ARG
|
| +# Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic
|
| +# conversion to w32 is not available inside the cwrapper. Returns result in
|
| +# func_to_host_path_result.
|
| +func_convert_path_msys_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_path_result="$1"
|
| + if test -n "$1"; then
|
| + # Remove leading and trailing path separator characters from ARG. MSYS
|
| + # behavior is inconsistent here; cygpath turns them into '.;' and ';.';
|
| + # and winepath ignores them completely.
|
| + func_stripname : : "$1"
|
| + func_to_host_path_tmp1=$func_stripname_result
|
| + func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
|
| + func_to_host_path_result="$func_convert_core_msys_to_w32_result"
|
| + func_convert_path_check : ";" \
|
| + "$func_to_host_path_tmp1" "$func_to_host_path_result"
|
| + func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
|
| + fi
|
| +}
|
| +# end func_convert_path_msys_to_w32
|
| +
|
| +
|
| +# func_convert_path_cygwin_to_w32 ARG
|
| +# Convert path ARG from Cygwin to w32 format. Returns result in
|
| +# func_to_host_file_result.
|
| +func_convert_path_cygwin_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_path_result="$1"
|
| + if test -n "$1"; then
|
| + # See func_convert_path_msys_to_w32:
|
| + func_stripname : : "$1"
|
| + func_to_host_path_tmp1=$func_stripname_result
|
| + func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"`
|
| + func_convert_path_check : ";" \
|
| + "$func_to_host_path_tmp1" "$func_to_host_path_result"
|
| + func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
|
| + fi
|
| +}
|
| +# end func_convert_path_cygwin_to_w32
|
| +
|
| +
|
| +# func_convert_path_nix_to_w32 ARG
|
| +# Convert path ARG from *nix to w32 format. Requires a wine environment and
|
| +# a working winepath. Returns result in func_to_host_file_result.
|
| +func_convert_path_nix_to_w32 ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_path_result="$1"
|
| + if test -n "$1"; then
|
| + # See func_convert_path_msys_to_w32:
|
| + func_stripname : : "$1"
|
| + func_to_host_path_tmp1=$func_stripname_result
|
| + func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
|
| + func_to_host_path_result="$func_convert_core_path_wine_to_w32_result"
|
| + func_convert_path_check : ";" \
|
| + "$func_to_host_path_tmp1" "$func_to_host_path_result"
|
| + func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
|
| + fi
|
| +}
|
| +# end func_convert_path_nix_to_w32
|
| +
|
| +
|
| +# func_convert_path_msys_to_cygwin ARG
|
| +# Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set.
|
| +# Returns result in func_to_host_file_result.
|
| +func_convert_path_msys_to_cygwin ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_path_result="$1"
|
| + if test -n "$1"; then
|
| + # See func_convert_path_msys_to_w32:
|
| + func_stripname : : "$1"
|
| + func_to_host_path_tmp1=$func_stripname_result
|
| + func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
|
| + func_cygpath -u -p "$func_convert_core_msys_to_w32_result"
|
| + func_to_host_path_result="$func_cygpath_result"
|
| + func_convert_path_check : : \
|
| + "$func_to_host_path_tmp1" "$func_to_host_path_result"
|
| + func_convert_path_front_back_pathsep ":*" "*:" : "$1"
|
| + fi
|
| +}
|
| +# end func_convert_path_msys_to_cygwin
|
| +
|
| +
|
| +# func_convert_path_nix_to_cygwin ARG
|
| +# Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a
|
| +# a wine environment, working winepath, and LT_CYGPATH set. Returns result in
|
| +# func_to_host_file_result.
|
| +func_convert_path_nix_to_cygwin ()
|
| +{
|
| + $opt_debug
|
| + func_to_host_path_result="$1"
|
| + if test -n "$1"; then
|
| + # Remove leading and trailing path separator characters from
|
| + # ARG. msys behavior is inconsistent here, cygpath turns them
|
| + # into '.;' and ';.', and winepath ignores them completely.
|
| + func_stripname : : "$1"
|
| + func_to_host_path_tmp1=$func_stripname_result
|
| + func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
|
| + func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result"
|
| + func_to_host_path_result="$func_cygpath_result"
|
| + func_convert_path_check : : \
|
| + "$func_to_host_path_tmp1" "$func_to_host_path_result"
|
| + func_convert_path_front_back_pathsep ":*" "*:" : "$1"
|
| + fi
|
| +}
|
| +# end func_convert_path_nix_to_cygwin
|
| +
|
| +
|
| # func_mode_compile arg...
|
| func_mode_compile ()
|
| {
|
| @@ -1137,12 +1986,12 @@ func_mode_compile ()
|
| ;;
|
|
|
| -pie | -fpie | -fPIE)
|
| - pie_flag="$pie_flag $arg"
|
| + func_append pie_flag " $arg"
|
| continue
|
| ;;
|
|
|
| -shared | -static | -prefer-pic | -prefer-non-pic)
|
| - later="$later $arg"
|
| + func_append later " $arg"
|
| continue
|
| ;;
|
|
|
| @@ -1163,15 +2012,14 @@ func_mode_compile ()
|
| save_ifs="$IFS"; IFS=','
|
| for arg in $args; do
|
| IFS="$save_ifs"
|
| - func_quote_for_eval "$arg"
|
| - lastarg="$lastarg $func_quote_for_eval_result"
|
| + func_append_quoted lastarg "$arg"
|
| done
|
| IFS="$save_ifs"
|
| func_stripname ' ' '' "$lastarg"
|
| lastarg=$func_stripname_result
|
|
|
| # Add the arguments to base_compile.
|
| - base_compile="$base_compile $lastarg"
|
| + func_append base_compile " $lastarg"
|
| continue
|
| ;;
|
|
|
| @@ -1187,8 +2035,7 @@ func_mode_compile ()
|
| esac # case $arg_mode
|
|
|
| # Aesthetically quote the previous argument.
|
| - func_quote_for_eval "$lastarg"
|
| - base_compile="$base_compile $func_quote_for_eval_result"
|
| + func_append_quoted base_compile "$lastarg"
|
| done # for arg
|
|
|
| case $arg_mode in
|
| @@ -1213,7 +2060,7 @@ func_mode_compile ()
|
| *.[cCFSifmso] | \
|
| *.ada | *.adb | *.ads | *.asm | \
|
| *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \
|
| - *.[fF][09]? | *.for | *.java | *.obj | *.sx)
|
| + *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup)
|
| func_xform "$libobj"
|
| libobj=$func_xform_result
|
| ;;
|
| @@ -1288,7 +2135,7 @@ func_mode_compile ()
|
| # Calculate the filename of the output object if compiler does
|
| # not support -o with -c
|
| if test "$compiler_c_o" = no; then
|
| - output_obj=`$ECHO "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext}
|
| + output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.${objext}
|
| lockfile="$output_obj.lock"
|
| else
|
| output_obj=
|
| @@ -1319,17 +2166,16 @@ compiler."
|
| $opt_dry_run || $RM $removelist
|
| exit $EXIT_FAILURE
|
| fi
|
| - removelist="$removelist $output_obj"
|
| + func_append removelist " $output_obj"
|
| $ECHO "$srcfile" > "$lockfile"
|
| fi
|
|
|
| $opt_dry_run || $RM $removelist
|
| - removelist="$removelist $lockfile"
|
| + func_append removelist " $lockfile"
|
| trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15
|
|
|
| - if test -n "$fix_srcfile_path"; then
|
| - eval srcfile=\"$fix_srcfile_path\"
|
| - fi
|
| + func_to_tool_file "$srcfile" func_convert_file_msys_to_w32
|
| + srcfile=$func_to_tool_file_result
|
| func_quote_for_eval "$srcfile"
|
| qsrcfile=$func_quote_for_eval_result
|
|
|
| @@ -1349,7 +2195,7 @@ compiler."
|
|
|
| if test -z "$output_obj"; then
|
| # Place PIC objects in $objdir
|
| - command="$command -o $lobj"
|
| + func_append command " -o $lobj"
|
| fi
|
|
|
| func_show_eval_locale "$command" \
|
| @@ -1396,11 +2242,11 @@ compiler."
|
| command="$base_compile $qsrcfile $pic_flag"
|
| fi
|
| if test "$compiler_c_o" = yes; then
|
| - command="$command -o $obj"
|
| + func_append command " -o $obj"
|
| fi
|
|
|
| # Suppress compiler output if we already did a PIC compilation.
|
| - command="$command$suppress_output"
|
| + func_append command "$suppress_output"
|
| func_show_eval_locale "$command" \
|
| '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE'
|
|
|
| @@ -1445,13 +2291,13 @@ compiler."
|
| }
|
|
|
| $opt_help || {
|
| -test "$mode" = compile && func_mode_compile ${1+"$@"}
|
| + test "$opt_mode" = compile && func_mode_compile ${1+"$@"}
|
| }
|
|
|
| func_mode_help ()
|
| {
|
| # We need to display help for each of the modes.
|
| - case $mode in
|
| + case $opt_mode in
|
| "")
|
| # Generic help is extracted from the usage comments
|
| # at the start of this file.
|
| @@ -1482,10 +2328,11 @@ This mode accepts the following additional options:
|
|
|
| -o OUTPUT-FILE set the output file name to OUTPUT-FILE
|
| -no-suppress do not suppress compiler output for multiple passes
|
| - -prefer-pic try to building PIC objects only
|
| - -prefer-non-pic try to building non-PIC objects only
|
| + -prefer-pic try to build PIC objects only
|
| + -prefer-non-pic try to build non-PIC objects only
|
| -shared do not build a \`.o' file suitable for static linking
|
| -static only build a \`.o' file suitable for static linking
|
| + -Wc,FLAG pass FLAG directly to the compiler
|
|
|
| COMPILE-COMMAND is a command to be used in creating a \`standard' object file
|
| from the given SOURCEFILE.
|
| @@ -1538,7 +2385,7 @@ either the \`install' or \`cp' program.
|
|
|
| The following components of INSTALL-COMMAND are treated specially:
|
|
|
| - -inst-prefix PREFIX-DIR Use PREFIX-DIR as a staging area for installation
|
| + -inst-prefix-dir PREFIX-DIR Use PREFIX-DIR as a staging area for installation
|
|
|
| The rest of the components are interpreted as arguments to that command (only
|
| BSD-compatible install options are recognized)."
|
| @@ -1558,6 +2405,8 @@ The following components of LINK-COMMAND are treated specially:
|
|
|
| -all-static do not do any dynamic linking at all
|
| -avoid-version do not add a version suffix if possible
|
| + -bindir BINDIR specify path to binaries directory (for systems where
|
| + libraries must be found in the PATH setting at runtime)
|
| -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime
|
| -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols
|
| -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3)
|
| @@ -1586,6 +2435,11 @@ The following components of LINK-COMMAND are treated specially:
|
| -version-info CURRENT[:REVISION[:AGE]]
|
| specify library version info [each variable defaults to 0]
|
| -weak LIBNAME declare that the target provides the LIBNAME interface
|
| + -Wc,FLAG
|
| + -Xcompiler FLAG pass linker-specific FLAG directly to the compiler
|
| + -Wl,FLAG
|
| + -Xlinker FLAG pass linker-specific FLAG directly to the linker
|
| + -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC)
|
|
|
| All other options (arguments beginning with \`-') are ignored.
|
|
|
| @@ -1619,18 +2473,44 @@ Otherwise, only FILE itself is deleted using RM."
|
| ;;
|
|
|
| *)
|
| - func_fatal_help "invalid operation mode \`$mode'"
|
| + func_fatal_help "invalid operation mode \`$opt_mode'"
|
| ;;
|
| esac
|
|
|
| - $ECHO
|
| + echo
|
| $ECHO "Try \`$progname --help' for more information about other modes."
|
| -
|
| - exit $?
|
| }
|
|
|
| - # Now that we've collected a possible --mode arg, show help if necessary
|
| - $opt_help && func_mode_help
|
| +# Now that we've collected a possible --mode arg, show help if necessary
|
| +if $opt_help; then
|
| + if test "$opt_help" = :; then
|
| + func_mode_help
|
| + else
|
| + {
|
| + func_help noexit
|
| + for opt_mode in compile link execute install finish uninstall clean; do
|
| + func_mode_help
|
| + done
|
| + } | sed -n '1p; 2,$s/^Usage:/ or: /p'
|
| + {
|
| + func_help noexit
|
| + for opt_mode in compile link execute install finish uninstall clean; do
|
| + echo
|
| + func_mode_help
|
| + done
|
| + } |
|
| + sed '1d
|
| + /^When reporting/,/^Report/{
|
| + H
|
| + d
|
| + }
|
| + $x
|
| + /information about other modes/d
|
| + /more detailed .*MODE/d
|
| + s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/'
|
| + fi
|
| + exit $?
|
| +fi
|
|
|
|
|
| # func_mode_execute arg...
|
| @@ -1643,13 +2523,16 @@ func_mode_execute ()
|
| func_fatal_help "you must specify a COMMAND"
|
|
|
| # Handle -dlopen flags immediately.
|
| - for file in $execute_dlfiles; do
|
| + for file in $opt_dlopen; do
|
| test -f "$file" \
|
| || func_fatal_help "\`$file' is not a file"
|
|
|
| dir=
|
| case $file in
|
| *.la)
|
| + func_resolve_sysroot "$file"
|
| + file=$func_resolve_sysroot_result
|
| +
|
| # Check to see that this really is a libtool archive.
|
| func_lalib_unsafe_p "$file" \
|
| || func_fatal_help "\`$lib' is not a valid libtool archive"
|
| @@ -1671,7 +2554,7 @@ func_mode_execute ()
|
| dir="$func_dirname_result"
|
|
|
| if test -f "$dir/$objdir/$dlname"; then
|
| - dir="$dir/$objdir"
|
| + func_append dir "/$objdir"
|
| else
|
| if test ! -f "$dir/$dlname"; then
|
| func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'"
|
| @@ -1712,7 +2595,7 @@ func_mode_execute ()
|
| for file
|
| do
|
| case $file in
|
| - -*) ;;
|
| + -* | *.la | *.lo ) ;;
|
| *)
|
| # Do a test to see if this is really a libtool program.
|
| if func_ltwrapper_script_p "$file"; then
|
| @@ -1728,8 +2611,7 @@ func_mode_execute ()
|
| ;;
|
| esac
|
| # Quote arguments (to preserve shell metacharacters).
|
| - func_quote_for_eval "$file"
|
| - args="$args $func_quote_for_eval_result"
|
| + func_append_quoted args "$file"
|
| done
|
|
|
| if test "X$opt_dry_run" = Xfalse; then
|
| @@ -1754,29 +2636,66 @@ func_mode_execute ()
|
| # Display what would be done.
|
| if test -n "$shlibpath_var"; then
|
| eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\""
|
| - $ECHO "export $shlibpath_var"
|
| + echo "export $shlibpath_var"
|
| fi
|
| $ECHO "$cmd$args"
|
| exit $EXIT_SUCCESS
|
| fi
|
| }
|
|
|
| -test "$mode" = execute && func_mode_execute ${1+"$@"}
|
| +test "$opt_mode" = execute && func_mode_execute ${1+"$@"}
|
|
|
|
|
| # func_mode_finish arg...
|
| func_mode_finish ()
|
| {
|
| $opt_debug
|
| - libdirs="$nonopt"
|
| + libs=
|
| + libdirs=
|
| admincmds=
|
|
|
| - if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
|
| - for dir
|
| - do
|
| - libdirs="$libdirs $dir"
|
| - done
|
| + for opt in "$nonopt" ${1+"$@"}
|
| + do
|
| + if test -d "$opt"; then
|
| + func_append libdirs " $opt"
|
| +
|
| + elif test -f "$opt"; then
|
| + if func_lalib_unsafe_p "$opt"; then
|
| + func_append libs " $opt"
|
| + else
|
| + func_warning "\`$opt' is not a valid libtool archive"
|
| + fi
|
| +
|
| + else
|
| + func_fatal_error "invalid argument \`$opt'"
|
| + fi
|
| + done
|
| +
|
| + if test -n "$libs"; then
|
| + if test -n "$lt_sysroot"; then
|
| + sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"`
|
| + sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;"
|
| + else
|
| + sysroot_cmd=
|
| + fi
|
| +
|
| + # Remove sysroot references
|
| + if $opt_dry_run; then
|
| + for lib in $libs; do
|
| + echo "removing references to $lt_sysroot and \`=' prefixes from $lib"
|
| + done
|
| + else
|
| + tmpdir=`func_mktempdir`
|
| + for lib in $libs; do
|
| + sed -e "${sysroot_cmd} s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \
|
| + > $tmpdir/tmp-la
|
| + mv -f $tmpdir/tmp-la $lib
|
| + done
|
| + ${RM}r "$tmpdir"
|
| + fi
|
| + fi
|
|
|
| + if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
|
| for libdir in $libdirs; do
|
| if test -n "$finish_cmds"; then
|
| # Do each command in the finish commands.
|
| @@ -1786,7 +2705,7 @@ func_mode_finish ()
|
| if test -n "$finish_eval"; then
|
| # Do the single finish_eval.
|
| eval cmds=\"$finish_eval\"
|
| - $opt_dry_run || eval "$cmds" || admincmds="$admincmds
|
| + $opt_dry_run || eval "$cmds" || func_append admincmds "
|
| $cmds"
|
| fi
|
| done
|
| @@ -1795,53 +2714,55 @@ func_mode_finish ()
|
| # Exit here if they wanted silent mode.
|
| $opt_silent && exit $EXIT_SUCCESS
|
|
|
| - $ECHO "X----------------------------------------------------------------------" | $Xsed
|
| - $ECHO "Libraries have been installed in:"
|
| - for libdir in $libdirs; do
|
| - $ECHO " $libdir"
|
| - done
|
| - $ECHO
|
| - $ECHO "If you ever happen to want to link against installed libraries"
|
| - $ECHO "in a given directory, LIBDIR, you must either use libtool, and"
|
| - $ECHO "specify the full pathname of the library, or use the \`-LLIBDIR'"
|
| - $ECHO "flag during linking and do at least one of the following:"
|
| - if test -n "$shlibpath_var"; then
|
| - $ECHO " - add LIBDIR to the \`$shlibpath_var' environment variable"
|
| - $ECHO " during execution"
|
| - fi
|
| - if test -n "$runpath_var"; then
|
| - $ECHO " - add LIBDIR to the \`$runpath_var' environment variable"
|
| - $ECHO " during linking"
|
| - fi
|
| - if test -n "$hardcode_libdir_flag_spec"; then
|
| - libdir=LIBDIR
|
| - eval flag=\"$hardcode_libdir_flag_spec\"
|
| + if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
|
| + echo "----------------------------------------------------------------------"
|
| + echo "Libraries have been installed in:"
|
| + for libdir in $libdirs; do
|
| + $ECHO " $libdir"
|
| + done
|
| + echo
|
| + echo "If you ever happen to want to link against installed libraries"
|
| + echo "in a given directory, LIBDIR, you must either use libtool, and"
|
| + echo "specify the full pathname of the library, or use the \`-LLIBDIR'"
|
| + echo "flag during linking and do at least one of the following:"
|
| + if test -n "$shlibpath_var"; then
|
| + echo " - add LIBDIR to the \`$shlibpath_var' environment variable"
|
| + echo " during execution"
|
| + fi
|
| + if test -n "$runpath_var"; then
|
| + echo " - add LIBDIR to the \`$runpath_var' environment variable"
|
| + echo " during linking"
|
| + fi
|
| + if test -n "$hardcode_libdir_flag_spec"; then
|
| + libdir=LIBDIR
|
| + eval flag=\"$hardcode_libdir_flag_spec\"
|
|
|
| - $ECHO " - use the \`$flag' linker flag"
|
| - fi
|
| - if test -n "$admincmds"; then
|
| - $ECHO " - have your system administrator run these commands:$admincmds"
|
| - fi
|
| - if test -f /etc/ld.so.conf; then
|
| - $ECHO " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'"
|
| - fi
|
| - $ECHO
|
| + $ECHO " - use the \`$flag' linker flag"
|
| + fi
|
| + if test -n "$admincmds"; then
|
| + $ECHO " - have your system administrator run these commands:$admincmds"
|
| + fi
|
| + if test -f /etc/ld.so.conf; then
|
| + echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'"
|
| + fi
|
| + echo
|
|
|
| - $ECHO "See any operating system documentation about shared libraries for"
|
| - case $host in
|
| - solaris2.[6789]|solaris2.1[0-9])
|
| - $ECHO "more information, such as the ld(1), crle(1) and ld.so(8) manual"
|
| - $ECHO "pages."
|
| - ;;
|
| - *)
|
| - $ECHO "more information, such as the ld(1) and ld.so(8) manual pages."
|
| - ;;
|
| - esac
|
| - $ECHO "X----------------------------------------------------------------------" | $Xsed
|
| + echo "See any operating system documentation about shared libraries for"
|
| + case $host in
|
| + solaris2.[6789]|solaris2.1[0-9])
|
| + echo "more information, such as the ld(1), crle(1) and ld.so(8) manual"
|
| + echo "pages."
|
| + ;;
|
| + *)
|
| + echo "more information, such as the ld(1) and ld.so(8) manual pages."
|
| + ;;
|
| + esac
|
| + echo "----------------------------------------------------------------------"
|
| + fi
|
| exit $EXIT_SUCCESS
|
| }
|
|
|
| -test "$mode" = finish && func_mode_finish ${1+"$@"}
|
| +test "$opt_mode" = finish && func_mode_finish ${1+"$@"}
|
|
|
|
|
| # func_mode_install arg...
|
| @@ -1852,7 +2773,7 @@ func_mode_install ()
|
| # install_prog (especially on Windows NT).
|
| if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh ||
|
| # Allow the use of GNU shtool's install command.
|
| - $ECHO "X$nonopt" | $GREP shtool >/dev/null; then
|
| + case $nonopt in *shtool*) :;; *) false;; esac; then
|
| # Aesthetically quote it.
|
| func_quote_for_eval "$nonopt"
|
| install_prog="$func_quote_for_eval_result "
|
| @@ -1866,7 +2787,12 @@ func_mode_install ()
|
| # The real first argument should be the name of the installation program.
|
| # Aesthetically quote it.
|
| func_quote_for_eval "$arg"
|
| - install_prog="$install_prog$func_quote_for_eval_result"
|
| + func_append install_prog "$func_quote_for_eval_result"
|
| + install_shared_prog=$install_prog
|
| + case " $install_prog " in
|
| + *[\\\ /]cp\ *) install_cp=: ;;
|
| + *) install_cp=false ;;
|
| + esac
|
|
|
| # We need to accept at least all the BSD install flags.
|
| dest=
|
| @@ -1876,10 +2802,12 @@ func_mode_install ()
|
| install_type=
|
| isdir=no
|
| stripme=
|
| + no_mode=:
|
| for arg
|
| do
|
| + arg2=
|
| if test -n "$dest"; then
|
| - files="$files $dest"
|
| + func_append files " $dest"
|
| dest=$arg
|
| continue
|
| fi
|
| @@ -1887,10 +2815,9 @@ func_mode_install ()
|
| case $arg in
|
| -d) isdir=yes ;;
|
| -f)
|
| - case " $install_prog " in
|
| - *[\\\ /]cp\ *) ;;
|
| - *) prev=$arg ;;
|
| - esac
|
| + if $install_cp; then :; else
|
| + prev=$arg
|
| + fi
|
| ;;
|
| -g | -m | -o)
|
| prev=$arg
|
| @@ -1904,6 +2831,10 @@ func_mode_install ()
|
| *)
|
| # If the previous option needed an argument, then skip it.
|
| if test -n "$prev"; then
|
| + if test "x$prev" = x-m && test -n "$install_override_mode"; then
|
| + arg2=$install_override_mode
|
| + no_mode=false
|
| + fi
|
| prev=
|
| else
|
| dest=$arg
|
| @@ -1914,7 +2845,11 @@ func_mode_install ()
|
|
|
| # Aesthetically quote the argument.
|
| func_quote_for_eval "$arg"
|
| - install_prog="$install_prog $func_quote_for_eval_result"
|
| + func_append install_prog " $func_quote_for_eval_result"
|
| + if test -n "$arg2"; then
|
| + func_quote_for_eval "$arg2"
|
| + fi
|
| + func_append install_shared_prog " $func_quote_for_eval_result"
|
| done
|
|
|
| test -z "$install_prog" && \
|
| @@ -1923,6 +2858,13 @@ func_mode_install ()
|
| test -n "$prev" && \
|
| func_fatal_help "the \`$prev' option requires an argument"
|
|
|
| + if test -n "$install_override_mode" && $no_mode; then
|
| + if $install_cp; then :; else
|
| + func_quote_for_eval "$install_override_mode"
|
| + func_append install_shared_prog " -m $func_quote_for_eval_result"
|
| + fi
|
| + fi
|
| +
|
| if test -z "$files"; then
|
| if test -z "$dest"; then
|
| func_fatal_help "no file or destination specified"
|
| @@ -1977,10 +2919,13 @@ func_mode_install ()
|
| case $file in
|
| *.$libext)
|
| # Do the static libraries later.
|
| - staticlibs="$staticlibs $file"
|
| + func_append staticlibs " $file"
|
| ;;
|
|
|
| *.la)
|
| + func_resolve_sysroot "$file"
|
| + file=$func_resolve_sysroot_result
|
| +
|
| # Check to see that this really is a libtool archive.
|
| func_lalib_unsafe_p "$file" \
|
| || func_fatal_help "\`$file' is not a valid libtool archive"
|
| @@ -1994,23 +2939,23 @@ func_mode_install ()
|
| if test "X$destdir" = "X$libdir"; then
|
| case "$current_libdirs " in
|
| *" $libdir "*) ;;
|
| - *) current_libdirs="$current_libdirs $libdir" ;;
|
| + *) func_append current_libdirs " $libdir" ;;
|
| esac
|
| else
|
| # Note the libdir as a future libdir.
|
| case "$future_libdirs " in
|
| *" $libdir "*) ;;
|
| - *) future_libdirs="$future_libdirs $libdir" ;;
|
| + *) func_append future_libdirs " $libdir" ;;
|
| esac
|
| fi
|
|
|
| func_dirname "$file" "/" ""
|
| dir="$func_dirname_result"
|
| - dir="$dir$objdir"
|
| + func_append dir "$objdir"
|
|
|
| if test -n "$relink_command"; then
|
| # Determine the prefix the user has applied to our future dir.
|
| - inst_prefix_dir=`$ECHO "X$destdir" | $Xsed -e "s%$libdir\$%%"`
|
| + inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"`
|
|
|
| # Don't allow the user to place us outside of our expected
|
| # location b/c this prevents finding dependent libraries that
|
| @@ -2023,9 +2968,9 @@ func_mode_install ()
|
|
|
| if test -n "$inst_prefix_dir"; then
|
| # Stick the inst_prefix_dir data into the link command.
|
| - relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"`
|
| + relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"`
|
| else
|
| - relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%%"`
|
| + relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"`
|
| fi
|
|
|
| func_warning "relinking \`$file'"
|
| @@ -2043,7 +2988,7 @@ func_mode_install ()
|
| test -n "$relink_command" && srcname="$realname"T
|
|
|
| # Install the shared library and build the symlinks.
|
| - func_show_eval "$install_prog $dir/$srcname $destdir/$realname" \
|
| + func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \
|
| 'exit $?'
|
| tstripme="$stripme"
|
| case $host_os in
|
| @@ -2083,7 +3028,7 @@ func_mode_install ()
|
| func_show_eval "$install_prog $instname $destdir/$name" 'exit $?'
|
|
|
| # Maybe install the static library, too.
|
| - test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library"
|
| + test -n "$old_library" && func_append staticlibs " $dir/$old_library"
|
| ;;
|
|
|
| *.lo)
|
| @@ -2183,7 +3128,7 @@ func_mode_install ()
|
| if test -f "$lib"; then
|
| func_source "$lib"
|
| fi
|
| - libfile="$libdir/"`$ECHO "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test
|
| + libfile="$libdir/"`$ECHO "$lib" | $SED 's%^.*/%%g'` ### testsuite: skip nested quoting test
|
| if test -n "$libdir" && test ! -f "$libfile"; then
|
| func_warning "\`$lib' has not been installed in \`$libdir'"
|
| finalize=no
|
| @@ -2202,7 +3147,7 @@ func_mode_install ()
|
| file="$func_basename_result"
|
| outputname="$tmpdir/$file"
|
| # Replace the output file specification.
|
| - relink_command=`$ECHO "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'`
|
| + relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'`
|
|
|
| $opt_silent || {
|
| func_quote_for_expand "$relink_command"
|
| @@ -2221,7 +3166,7 @@ func_mode_install ()
|
| }
|
| else
|
| # Install the binary that we compiled earlier.
|
| - file=`$ECHO "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"`
|
| + file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"`
|
| fi
|
| fi
|
|
|
| @@ -2257,11 +3202,13 @@ func_mode_install ()
|
|
|
| # Set up the ranlib parameters.
|
| oldlib="$destdir/$name"
|
| + func_to_tool_file "$oldlib" func_convert_file_msys_to_w32
|
| + tool_oldlib=$func_to_tool_file_result
|
|
|
| func_show_eval "$install_prog \$file \$oldlib" 'exit $?'
|
|
|
| if test -n "$stripme" && test -n "$old_striplib"; then
|
| - func_show_eval "$old_striplib $oldlib" 'exit $?'
|
| + func_show_eval "$old_striplib $tool_oldlib" 'exit $?'
|
| fi
|
|
|
| # Do each command in the postinstall commands.
|
| @@ -2280,7 +3227,7 @@ func_mode_install ()
|
| fi
|
| }
|
|
|
| -test "$mode" = install && func_mode_install ${1+"$@"}
|
| +test "$opt_mode" = install && func_mode_install ${1+"$@"}
|
|
|
|
|
| # func_generate_dlsyms outputname originator pic_p
|
| @@ -2323,6 +3270,22 @@ func_generate_dlsyms ()
|
| extern \"C\" {
|
| #endif
|
|
|
| +#if defined(__GNUC__) && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4))
|
| +#pragma GCC diagnostic ignored \"-Wstrict-prototypes\"
|
| +#endif
|
| +
|
| +/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */
|
| +#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE)
|
| +/* DATA imports from DLLs on WIN32 con't be const, because runtime
|
| + relocations are performed -- see ld's documentation on pseudo-relocs. */
|
| +# define LT_DLSYM_CONST
|
| +#elif defined(__osf__)
|
| +/* This system does not cope well with relocations in const data. */
|
| +# define LT_DLSYM_CONST
|
| +#else
|
| +# define LT_DLSYM_CONST const
|
| +#endif
|
| +
|
| /* External symbol declarations for the compiler. */\
|
| "
|
|
|
| @@ -2332,10 +3295,11 @@ extern \"C\" {
|
| $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist"
|
|
|
| # Add our own program objects to the symbol list.
|
| - progfiles=`$ECHO "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
|
| + progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP`
|
| for progfile in $progfiles; do
|
| - func_verbose "extracting global C symbols from \`$progfile'"
|
| - $opt_dry_run || eval "$NM $progfile | $global_symbol_pipe >> '$nlist'"
|
| + func_to_tool_file "$progfile" func_convert_file_msys_to_w32
|
| + func_verbose "extracting global C symbols from \`$func_to_tool_file_result'"
|
| + $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'"
|
| done
|
|
|
| if test -n "$exclude_expsyms"; then
|
| @@ -2371,7 +3335,7 @@ extern \"C\" {
|
| eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T'
|
| eval '$MV "$nlist"T "$nlist"'
|
| case $host in
|
| - *cygwin | *mingw* | *cegcc* )
|
| + *cygwin* | *mingw* | *cegcc* )
|
| eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
|
| eval 'cat "$nlist" >> "$output_objdir/$outputname.def"'
|
| ;;
|
| @@ -2384,10 +3348,52 @@ extern \"C\" {
|
| func_verbose "extracting global C symbols from \`$dlprefile'"
|
| func_basename "$dlprefile"
|
| name="$func_basename_result"
|
| - $opt_dry_run || {
|
| - eval '$ECHO ": $name " >> "$nlist"'
|
| - eval "$NM $dlprefile 2>/dev/null | $global_symbol_pipe >> '$nlist'"
|
| - }
|
| + case $host in
|
| + *cygwin* | *mingw* | *cegcc* )
|
| + # if an import library, we need to obtain dlname
|
| + if func_win32_import_lib_p "$dlprefile"; then
|
| + func_tr_sh "$dlprefile"
|
| + eval "curr_lafile=\$libfile_$func_tr_sh_result"
|
| + dlprefile_dlbasename=""
|
| + if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then
|
| + # Use subshell, to avoid clobbering current variable values
|
| + dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"`
|
| + if test -n "$dlprefile_dlname" ; then
|
| + func_basename "$dlprefile_dlname"
|
| + dlprefile_dlbasename="$func_basename_result"
|
| + else
|
| + # no lafile. user explicitly requested -dlpreopen <import library>.
|
| + $sharedlib_from_linklib_cmd "$dlprefile"
|
| + dlprefile_dlbasename=$sharedlib_from_linklib_result
|
| + fi
|
| + fi
|
| + $opt_dry_run || {
|
| + if test -n "$dlprefile_dlbasename" ; then
|
| + eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"'
|
| + else
|
| + func_warning "Could not compute DLL name from $name"
|
| + eval '$ECHO ": $name " >> "$nlist"'
|
| + fi
|
| + func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32
|
| + eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe |
|
| + $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'"
|
| + }
|
| + else # not an import lib
|
| + $opt_dry_run || {
|
| + eval '$ECHO ": $name " >> "$nlist"'
|
| + func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32
|
| + eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'"
|
| + }
|
| + fi
|
| + ;;
|
| + *)
|
| + $opt_dry_run || {
|
| + eval '$ECHO ": $name " >> "$nlist"'
|
| + func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32
|
| + eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'"
|
| + }
|
| + ;;
|
| + esac
|
| done
|
|
|
| $opt_dry_run || {
|
| @@ -2415,36 +3421,19 @@ extern \"C\" {
|
| if test -f "$nlist"S; then
|
| eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"'
|
| else
|
| - $ECHO '/* NONE */' >> "$output_objdir/$my_dlsyms"
|
| + echo '/* NONE */' >> "$output_objdir/$my_dlsyms"
|
| fi
|
|
|
| - $ECHO >> "$output_objdir/$my_dlsyms" "\
|
| + echo >> "$output_objdir/$my_dlsyms" "\
|
|
|
| /* The mapping between symbol names and symbols. */
|
| typedef struct {
|
| const char *name;
|
| void *address;
|
| } lt_dlsymlist;
|
| -"
|
| - case $host in
|
| - *cygwin* | *mingw* | *cegcc* )
|
| - $ECHO >> "$output_objdir/$my_dlsyms" "\
|
| -/* DATA imports from DLLs on WIN32 con't be const, because
|
| - runtime relocations are performed -- see ld's documentation
|
| - on pseudo-relocs. */"
|
| - lt_dlsym_const= ;;
|
| - *osf5*)
|
| - echo >> "$output_objdir/$my_dlsyms" "\
|
| -/* This system does not cope well with relocations in const data */"
|
| - lt_dlsym_const= ;;
|
| - *)
|
| - lt_dlsym_const=const ;;
|
| - esac
|
| -
|
| - $ECHO >> "$output_objdir/$my_dlsyms" "\
|
| -extern $lt_dlsym_const lt_dlsymlist
|
| +extern LT_DLSYM_CONST lt_dlsymlist
|
| lt_${my_prefix}_LTX_preloaded_symbols[];
|
| -$lt_dlsym_const lt_dlsymlist
|
| +LT_DLSYM_CONST lt_dlsymlist
|
| lt_${my_prefix}_LTX_preloaded_symbols[] =
|
| {\
|
| { \"$my_originator\", (void *) 0 },"
|
| @@ -2457,7 +3446,7 @@ lt_${my_prefix}_LTX_preloaded_symbols[] =
|
| eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms"
|
| ;;
|
| esac
|
| - $ECHO >> "$output_objdir/$my_dlsyms" "\
|
| + echo >> "$output_objdir/$my_dlsyms" "\
|
| {0, (void *) 0}
|
| };
|
|
|
| @@ -2484,7 +3473,7 @@ static const void *lt_preloaded_setup() {
|
| # linked before any other PIC object. But we must not use
|
| # pic_flag when linking with -static. The problem exists in
|
| # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1.
|
| - *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*)
|
| + *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*)
|
| pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;;
|
| *-*-hpux*)
|
| pic_flag_for_symtable=" $pic_flag" ;;
|
| @@ -2500,7 +3489,7 @@ static const void *lt_preloaded_setup() {
|
| for arg in $LTCFLAGS; do
|
| case $arg in
|
| -pie | -fpie | -fPIE) ;;
|
| - *) symtab_cflags="$symtab_cflags $arg" ;;
|
| + *) func_append symtab_cflags " $arg" ;;
|
| esac
|
| done
|
|
|
| @@ -2515,16 +3504,16 @@ static const void *lt_preloaded_setup() {
|
| case $host in
|
| *cygwin* | *mingw* | *cegcc* )
|
| if test -f "$output_objdir/$my_outputname.def"; then
|
| - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
|
| - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
|
| + compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
|
| + finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
|
| else
|
| - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
|
| - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
|
| + compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"`
|
| + finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"`
|
| fi
|
| ;;
|
| *)
|
| - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
|
| - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
|
| + compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"`
|
| + finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"`
|
| ;;
|
| esac
|
| ;;
|
| @@ -2538,8 +3527,8 @@ static const void *lt_preloaded_setup() {
|
| # really was required.
|
|
|
| # Nullify the symbol file.
|
| - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"`
|
| - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"`
|
| + compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"`
|
| + finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"`
|
| fi
|
| }
|
|
|
| @@ -2549,6 +3538,7 @@ static const void *lt_preloaded_setup() {
|
| # 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.
|
| +# Despite the name, also deal with 64 bit binaries.
|
| func_win32_libid ()
|
| {
|
| $opt_debug
|
| @@ -2559,9 +3549,11 @@ func_win32_libid ()
|
| win32_libid_type="x86 archive import"
|
| ;;
|
| *ar\ archive*) # could be an import, or static
|
| + # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD.
|
| if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null |
|
| - $EGREP 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then
|
| - win32_nmres=`eval $NM -f posix -A $1 |
|
| + $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then
|
| + func_to_tool_file "$1" func_convert_file_msys_to_w32
|
| + win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" |
|
| $SED -n -e '
|
| 1,100{
|
| / I /{
|
| @@ -2590,6 +3582,131 @@ func_win32_libid ()
|
| $ECHO "$win32_libid_type"
|
| }
|
|
|
| +# func_cygming_dll_for_implib ARG
|
| +#
|
| +# Platform-specific function to extract the
|
| +# name of the DLL associated with the specified
|
| +# import library ARG.
|
| +# Invoked by eval'ing the libtool variable
|
| +# $sharedlib_from_linklib_cmd
|
| +# Result is available in the variable
|
| +# $sharedlib_from_linklib_result
|
| +func_cygming_dll_for_implib ()
|
| +{
|
| + $opt_debug
|
| + sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"`
|
| +}
|
| +
|
| +# func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs
|
| +#
|
| +# The is the core of a fallback implementation of a
|
| +# platform-specific function to extract the name of the
|
| +# DLL associated with the specified import library LIBNAME.
|
| +#
|
| +# SECTION_NAME is either .idata$6 or .idata$7, depending
|
| +# on the platform and compiler that created the implib.
|
| +#
|
| +# Echos the name of the DLL associated with the
|
| +# specified import library.
|
| +func_cygming_dll_for_implib_fallback_core ()
|
| +{
|
| + $opt_debug
|
| + match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"`
|
| + $OBJDUMP -s --section "$1" "$2" 2>/dev/null |
|
| + $SED '/^Contents of section '"$match_literal"':/{
|
| + # Place marker at beginning of archive member dllname section
|
| + s/.*/====MARK====/
|
| + p
|
| + d
|
| + }
|
| + # These lines can sometimes be longer than 43 characters, but
|
| + # are always uninteresting
|
| + /:[ ]*file format pe[i]\{,1\}-/d
|
| + /^In archive [^:]*:/d
|
| + # Ensure marker is printed
|
| + /^====MARK====/p
|
| + # Remove all lines with less than 43 characters
|
| + /^.\{43\}/!d
|
| + # From remaining lines, remove first 43 characters
|
| + s/^.\{43\}//' |
|
| + $SED -n '
|
| + # Join marker and all lines until next marker into a single line
|
| + /^====MARK====/ b para
|
| + H
|
| + $ b para
|
| + b
|
| + :para
|
| + x
|
| + s/\n//g
|
| + # Remove the marker
|
| + s/^====MARK====//
|
| + # Remove trailing dots and whitespace
|
| + s/[\. \t]*$//
|
| + # Print
|
| + /./p' |
|
| + # we now have a list, one entry per line, of the stringified
|
| + # contents of the appropriate section of all members of the
|
| + # archive which possess that section. Heuristic: eliminate
|
| + # all those which have a first or second character that is
|
| + # a '.' (that is, objdump's representation of an unprintable
|
| + # character.) This should work for all archives with less than
|
| + # 0x302f exports -- but will fail for DLLs whose name actually
|
| + # begins with a literal '.' or a single character followed by
|
| + # a '.'.
|
| + #
|
| + # Of those that remain, print the first one.
|
| + $SED -e '/^\./d;/^.\./d;q'
|
| +}
|
| +
|
| +# func_cygming_gnu_implib_p ARG
|
| +# This predicate returns with zero status (TRUE) if
|
| +# ARG is a GNU/binutils-style import library. Returns
|
| +# with nonzero status (FALSE) otherwise.
|
| +func_cygming_gnu_implib_p ()
|
| +{
|
| + $opt_debug
|
| + func_to_tool_file "$1" func_convert_file_msys_to_w32
|
| + func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'`
|
| + test -n "$func_cygming_gnu_implib_tmp"
|
| +}
|
| +
|
| +# func_cygming_ms_implib_p ARG
|
| +# This predicate returns with zero status (TRUE) if
|
| +# ARG is an MS-style import library. Returns
|
| +# with nonzero status (FALSE) otherwise.
|
| +func_cygming_ms_implib_p ()
|
| +{
|
| + $opt_debug
|
| + func_to_tool_file "$1" func_convert_file_msys_to_w32
|
| + func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
|
| + test -n "$func_cygming_ms_implib_tmp"
|
| +}
|
| +
|
| +# func_cygming_dll_for_implib_fallback ARG
|
| +# Platform-specific function to extract the
|
| +# name of the DLL associated with the specified
|
| +# import library ARG.
|
| +#
|
| +# This fallback implementation is for use when $DLLTOOL
|
| +# does not support the --identify-strict option.
|
| +# Invoked by eval'ing the libtool variable
|
| +# $sharedlib_from_linklib_cmd
|
| +# Result is available in the variable
|
| +# $sharedlib_from_linklib_result
|
| +func_cygming_dll_for_implib_fallback ()
|
| +{
|
| + $opt_debug
|
| + if func_cygming_gnu_implib_p "$1" ; then
|
| + # binutils import library
|
| + sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"`
|
| + elif func_cygming_ms_implib_p "$1" ; then
|
| + # ms-generated import library
|
| + sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"`
|
| + else
|
| + # unknown
|
| + sharedlib_from_linklib_result=""
|
| + fi
|
| +}
|
|
|
|
|
| # func_extract_an_archive dir oldlib
|
| @@ -2598,7 +3715,18 @@ func_extract_an_archive ()
|
| $opt_debug
|
| f_ex_an_ar_dir="$1"; shift
|
| f_ex_an_ar_oldlib="$1"
|
| - func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" 'exit $?'
|
| + if test "$lock_old_archive_extraction" = yes; then
|
| + lockfile=$f_ex_an_ar_oldlib.lock
|
| + until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
|
| + func_echo "Waiting for $lockfile to be removed"
|
| + sleep 2
|
| + done
|
| + fi
|
| + func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \
|
| + 'stat=$?; rm -f "$lockfile"; exit $stat'
|
| + if test "$lock_old_archive_extraction" = yes; then
|
| + $opt_dry_run || rm -f "$lockfile"
|
| + fi
|
| if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
|
| :
|
| else
|
| @@ -2669,7 +3797,7 @@ func_extract_archives ()
|
| darwin_file=
|
| darwin_files=
|
| for darwin_file in $darwin_filelist; do
|
| - darwin_files=`find unfat-$$ -name $darwin_file -print | $NL2SP`
|
| + darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP`
|
| $LIPO -create -output "$darwin_file" $darwin_files
|
| done # $darwin_filelist
|
| $RM -rf unfat-$$
|
| @@ -2684,25 +3812,30 @@ func_extract_archives ()
|
| func_extract_an_archive "$my_xdir" "$my_xabs"
|
| ;;
|
| esac
|
| - my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP`
|
| + my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP`
|
| done
|
|
|
| func_extract_archives_result="$my_oldobjs"
|
| }
|
|
|
|
|
| -
|
| -# func_emit_wrapper_part1 [arg=no]
|
| +# func_emit_wrapper [arg=no]
|
| +#
|
| +# Emit a libtool wrapper script on stdout.
|
| +# Don't directly open a file because we may want to
|
| +# incorporate the script contents within a cygwin/mingw
|
| +# wrapper executable. Must ONLY be called from within
|
| +# func_mode_link because it depends on a number of variables
|
| +# set therein.
|
| #
|
| -# Emit the first part of a libtool wrapper script on stdout.
|
| -# For more information, see the description associated with
|
| -# func_emit_wrapper(), below.
|
| -func_emit_wrapper_part1 ()
|
| +# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR
|
| +# variable will take. If 'yes', then the emitted script
|
| +# will assume that the directory in which it is stored is
|
| +# the $objdir directory. This is a cygwin/mingw-specific
|
| +# behavior.
|
| +func_emit_wrapper ()
|
| {
|
| - func_emit_wrapper_part1_arg1=no
|
| - if test -n "$1" ; then
|
| - func_emit_wrapper_part1_arg1=$1
|
| - fi
|
| + func_emit_wrapper_arg1=${1-no}
|
|
|
| $ECHO "\
|
| #! $SHELL
|
| @@ -2718,7 +3851,6 @@ func_emit_wrapper_part1 ()
|
|
|
| # Sed substitution that helps us do robust quoting. It backslashifies
|
| # metacharacters that are still active within double-quoted strings.
|
| -Xsed='${SED} -e 1s/^X//'
|
| sed_quote_subst='$sed_quote_subst'
|
|
|
| # Be Bourne compatible
|
| @@ -2749,31 +3881,135 @@ if test \"\$libtool_install_magic\" = \"$magic\"; then
|
| else
|
| # When we are sourced in execute mode, \$file and \$ECHO are already set.
|
| if test \"\$libtool_execute_magic\" != \"$magic\"; then
|
| - ECHO=\"$qecho\"
|
| - file=\"\$0\"
|
| - # Make sure echo works.
|
| - if test \"X\$1\" = X--no-reexec; then
|
| - # Discard the --no-reexec flag, and continue.
|
| - shift
|
| - elif test \"X\`{ \$ECHO '\t'; } 2>/dev/null\`\" = 'X\t'; then
|
| - # Yippee, \$ECHO works!
|
| - :
|
| - else
|
| - # Restart under the correct shell, and then maybe \$ECHO will work.
|
| - exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"}
|
| - fi
|
| - fi\
|
| + file=\"\$0\""
|
| +
|
| + qECHO=`$ECHO "$ECHO" | $SED "$sed_quote_subst"`
|
| + $ECHO "\
|
| +
|
| +# A function that is used when there is no print builtin or printf.
|
| +func_fallback_echo ()
|
| +{
|
| + eval 'cat <<_LTECHO_EOF
|
| +\$1
|
| +_LTECHO_EOF'
|
| +}
|
| + ECHO=\"$qECHO\"
|
| + fi
|
| +
|
| +# Very basic option parsing. These options are (a) specific to
|
| +# the libtool wrapper, (b) are identical between the wrapper
|
| +# /script/ and the wrapper /executable/ which is used only on
|
| +# windows platforms, and (c) all begin with the string "--lt-"
|
| +# (application programs are unlikely to have options which match
|
| +# this pattern).
|
| +#
|
| +# There are only two supported options: --lt-debug and
|
| +# --lt-dump-script. There is, deliberately, no --lt-help.
|
| +#
|
| +# The first argument to this parsing function should be the
|
| +# script's $0 value, followed by "$@".
|
| +lt_option_debug=
|
| +func_parse_lt_options ()
|
| +{
|
| + lt_script_arg0=\$0
|
| + shift
|
| + for lt_opt
|
| + do
|
| + case \"\$lt_opt\" in
|
| + --lt-debug) lt_option_debug=1 ;;
|
| + --lt-dump-script)
|
| + lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\`
|
| + test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=.
|
| + lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\`
|
| + cat \"\$lt_dump_D/\$lt_dump_F\"
|
| + exit 0
|
| + ;;
|
| + --lt-*)
|
| + \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2
|
| + exit 1
|
| + ;;
|
| + esac
|
| + done
|
| +
|
| + # Print the debug banner immediately:
|
| + if test -n \"\$lt_option_debug\"; then
|
| + echo \"${outputname}:${output}:\${LINENO}: libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\" 1>&2
|
| + fi
|
| +}
|
| +
|
| +# Used when --lt-debug. Prints its arguments to stdout
|
| +# (redirection is the responsibility of the caller)
|
| +func_lt_dump_args ()
|
| +{
|
| + lt_dump_args_N=1;
|
| + for lt_arg
|
| + do
|
| + \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[\$lt_dump_args_N]: \$lt_arg\"
|
| + lt_dump_args_N=\`expr \$lt_dump_args_N + 1\`
|
| + done
|
| +}
|
| +
|
| +# Core function for launching the target application
|
| +func_exec_program_core ()
|
| +{
|
| "
|
| - $ECHO "\
|
| + case $host in
|
| + # Backslashes separate directories on plain windows
|
| + *-*-mingw | *-*-os2* | *-cegcc*)
|
| + $ECHO "\
|
| + if test -n \"\$lt_option_debug\"; then
|
| + \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir\\\\\$program\" 1>&2
|
| + func_lt_dump_args \${1+\"\$@\"} 1>&2
|
| + fi
|
| + exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
|
| +"
|
| + ;;
|
| +
|
| + *)
|
| + $ECHO "\
|
| + if test -n \"\$lt_option_debug\"; then
|
| + \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir/\$program\" 1>&2
|
| + func_lt_dump_args \${1+\"\$@\"} 1>&2
|
| + fi
|
| + exec \"\$progdir/\$program\" \${1+\"\$@\"}
|
| +"
|
| + ;;
|
| + esac
|
| + $ECHO "\
|
| + \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2
|
| + exit 1
|
| +}
|
| +
|
| +# A function to encapsulate launching the target application
|
| +# Strips options in the --lt-* namespace from \$@ and
|
| +# launches target application with the remaining arguments.
|
| +func_exec_program ()
|
| +{
|
| + case \" \$* \" in
|
| + *\\ --lt-*)
|
| + for lt_wr_arg
|
| + do
|
| + case \$lt_wr_arg in
|
| + --lt-*) ;;
|
| + *) set x \"\$@\" \"\$lt_wr_arg\"; shift;;
|
| + esac
|
| + shift
|
| + done ;;
|
| + esac
|
| + func_exec_program_core \${1+\"\$@\"}
|
| +}
|
| +
|
| + # Parse options
|
| + func_parse_lt_options \"\$0\" \${1+\"\$@\"}
|
|
|
| # Find the directory that this script lives in.
|
| - thisdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\`
|
| + thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\`
|
| test \"x\$thisdir\" = \"x\$file\" && thisdir=.
|
|
|
| # Follow symbolic links until we get to the real thisdir.
|
| - file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\`
|
| + file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\`
|
| while test -n \"\$file\"; do
|
| - destdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\`
|
| + destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\`
|
|
|
| # If there was a directory component, then change thisdir.
|
| if test \"x\$destdir\" != \"x\$file\"; then
|
| @@ -2783,30 +4019,13 @@ else
|
| esac
|
| fi
|
|
|
| - file=\`\$ECHO \"X\$file\" | \$Xsed -e 's%^.*/%%'\`
|
| - file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\`
|
| + file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\`
|
| + file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\`
|
| done
|
| -"
|
| -}
|
| -# end: func_emit_wrapper_part1
|
| -
|
| -# func_emit_wrapper_part2 [arg=no]
|
| -#
|
| -# Emit the second part of a libtool wrapper script on stdout.
|
| -# For more information, see the description associated with
|
| -# func_emit_wrapper(), below.
|
| -func_emit_wrapper_part2 ()
|
| -{
|
| - func_emit_wrapper_part2_arg1=no
|
| - if test -n "$1" ; then
|
| - func_emit_wrapper_part2_arg1=$1
|
| - fi
|
| -
|
| - $ECHO "\
|
|
|
| # Usually 'no', except on cygwin/mingw when embedded into
|
| # the cwrapper.
|
| - WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_part2_arg1
|
| + WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1
|
| if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then
|
| # special case for '.'
|
| if test \"\$thisdir\" = \".\"; then
|
| @@ -2814,7 +4033,7 @@ func_emit_wrapper_part2 ()
|
| fi
|
| # remove .libs from thisdir
|
| case \"\$thisdir\" in
|
| - *[\\\\/]$objdir ) thisdir=\`\$ECHO \"X\$thisdir\" | \$Xsed -e 's%[\\\\/][^\\\\/]*$%%'\` ;;
|
| + *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;;
|
| $objdir ) thisdir=. ;;
|
| esac
|
| fi
|
| @@ -2869,6 +4088,18 @@ func_emit_wrapper_part2 ()
|
|
|
| if test -f \"\$progdir/\$program\"; then"
|
|
|
| + # fixup the dll searchpath if we need to.
|
| + #
|
| + # Fix the DLL searchpath if we need to. Do this before prepending
|
| + # to shlibpath, because on Windows, both are PATH and uninstalled
|
| + # libraries must come first.
|
| + if test -n "$dllsearchpath"; then
|
| + $ECHO "\
|
| + # Add the dll search path components to the executable PATH
|
| + PATH=$dllsearchpath:\$PATH
|
| +"
|
| + fi
|
| +
|
| # Export our shlibpath_var if we have one.
|
| if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
|
| $ECHO "\
|
| @@ -2877,253 +4108,28 @@ func_emit_wrapper_part2 ()
|
|
|
| # Some systems cannot cope with colon-terminated $shlibpath_var
|
| # The second colon is a workaround for a bug in BeOS R4 sed
|
| - $shlibpath_var=\`\$ECHO \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\`
|
| + $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\`
|
|
|
| export $shlibpath_var
|
| "
|
| fi
|
|
|
| - # fixup the dll searchpath if we need to.
|
| - if test -n "$dllsearchpath"; then
|
| - $ECHO "\
|
| - # Add the dll search path components to the executable PATH
|
| - PATH=$dllsearchpath:\$PATH
|
| -"
|
| - fi
|
| -
|
| $ECHO "\
|
| if test \"\$libtool_execute_magic\" != \"$magic\"; then
|
| # Run the actual program with our arguments.
|
| -"
|
| - case $host in
|
| - # Backslashes separate directories on plain windows
|
| - *-*-mingw | *-*-os2* | *-cegcc*)
|
| - $ECHO "\
|
| - exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
|
| -"
|
| - ;;
|
| -
|
| - *)
|
| - $ECHO "\
|
| - exec \"\$progdir/\$program\" \${1+\"\$@\"}
|
| -"
|
| - ;;
|
| - esac
|
| - $ECHO "\
|
| - \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2
|
| - exit 1
|
| + func_exec_program \${1+\"\$@\"}
|
| 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
|
| + \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2
|
| exit 1
|
| fi
|
| fi\
|
| "
|
| }
|
| -# end: func_emit_wrapper_part2
|
| -
|
| -
|
| -# func_emit_wrapper [arg=no]
|
| -#
|
| -# Emit a libtool wrapper script on stdout.
|
| -# Don't directly open a file because we may want to
|
| -# incorporate the script contents within a cygwin/mingw
|
| -# wrapper executable. Must ONLY be called from within
|
| -# func_mode_link because it depends on a number of variables
|
| -# set therein.
|
| -#
|
| -# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR
|
| -# variable will take. If 'yes', then the emitted script
|
| -# will assume that the directory in which it is stored is
|
| -# the $objdir directory. This is a cygwin/mingw-specific
|
| -# behavior.
|
| -func_emit_wrapper ()
|
| -{
|
| - func_emit_wrapper_arg1=no
|
| - if test -n "$1" ; then
|
| - func_emit_wrapper_arg1=$1
|
| - fi
|
| -
|
| - # split this up so that func_emit_cwrapperexe_src
|
| - # can call each part independently.
|
| - func_emit_wrapper_part1 "${func_emit_wrapper_arg1}"
|
| - func_emit_wrapper_part2 "${func_emit_wrapper_arg1}"
|
| -}
|
| -
|
| -
|
| -# func_to_host_path arg
|
| -#
|
| -# Convert paths to host format when used with build tools.
|
| -# Intended for use with "native" mingw (where libtool itself
|
| -# is running under the msys shell), or in the following cross-
|
| -# build environments:
|
| -# $build $host
|
| -# mingw (msys) mingw [e.g. native]
|
| -# cygwin mingw
|
| -# *nix + wine mingw
|
| -# where wine is equipped with the `winepath' executable.
|
| -# In the native mingw case, the (msys) shell automatically
|
| -# converts paths for any non-msys applications it launches,
|
| -# but that facility isn't available from inside the cwrapper.
|
| -# Similar accommodations are necessary for $host mingw and
|
| -# $build cygwin. Calling this function does no harm for other
|
| -# $host/$build combinations not listed above.
|
| -#
|
| -# ARG is the path (on $build) that should be converted to
|
| -# the proper representation for $host. The result is stored
|
| -# in $func_to_host_path_result.
|
| -func_to_host_path ()
|
| -{
|
| - func_to_host_path_result="$1"
|
| - if test -n "$1" ; then
|
| - case $host in
|
| - *mingw* )
|
| - lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
|
| - case $build in
|
| - *mingw* ) # actually, msys
|
| - # awkward: cmd appends spaces to result
|
| - lt_sed_strip_trailing_spaces="s/[ ]*\$//"
|
| - func_to_host_path_tmp1=`( cmd //c echo "$1" |\
|
| - $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""`
|
| - func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\
|
| - $SED -e "$lt_sed_naive_backslashify"`
|
| - ;;
|
| - *cygwin* )
|
| - func_to_host_path_tmp1=`cygpath -w "$1"`
|
| - func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\
|
| - $SED -e "$lt_sed_naive_backslashify"`
|
| - ;;
|
| - * )
|
| - # Unfortunately, winepath does not exit with a non-zero
|
| - # error code, so we are forced to check the contents of
|
| - # stdout. On the other hand, if the command is not
|
| - # found, the shell will set an exit code of 127 and print
|
| - # *an error message* to stdout. So we must check for both
|
| - # error code of zero AND non-empty stdout, which explains
|
| - # the odd construction:
|
| - func_to_host_path_tmp1=`winepath -w "$1" 2>/dev/null`
|
| - if test "$?" -eq 0 && test -n "${func_to_host_path_tmp1}"; then
|
| - func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\
|
| - $SED -e "$lt_sed_naive_backslashify"`
|
| - else
|
| - # Allow warning below.
|
| - func_to_host_path_result=""
|
| - fi
|
| - ;;
|
| - esac
|
| - if test -z "$func_to_host_path_result" ; then
|
| - func_error "Could not determine host path corresponding to"
|
| - func_error " '$1'"
|
| - func_error "Continuing, but uninstalled executables may not work."
|
| - # Fallback:
|
| - func_to_host_path_result="$1"
|
| - fi
|
| - ;;
|
| - esac
|
| - fi
|
| -}
|
| -# end: func_to_host_path
|
|
|
| -# func_to_host_pathlist arg
|
| -#
|
| -# Convert pathlists to host format when used with build tools.
|
| -# See func_to_host_path(), above. This function supports the
|
| -# following $build/$host combinations (but does no harm for
|
| -# combinations not listed here):
|
| -# $build $host
|
| -# mingw (msys) mingw [e.g. native]
|
| -# cygwin mingw
|
| -# *nix + wine mingw
|
| -#
|
| -# Path separators are also converted from $build format to
|
| -# $host format. If ARG begins or ends with a path separator
|
| -# character, it is preserved (but converted to $host format)
|
| -# on output.
|
| -#
|
| -# ARG is a pathlist (on $build) that should be converted to
|
| -# the proper representation on $host. The result is stored
|
| -# in $func_to_host_pathlist_result.
|
| -func_to_host_pathlist ()
|
| -{
|
| - func_to_host_pathlist_result="$1"
|
| - if test -n "$1" ; then
|
| - case $host in
|
| - *mingw* )
|
| - lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
|
| - # Remove leading and trailing path separator characters from
|
| - # ARG. msys behavior is inconsistent here, cygpath turns them
|
| - # into '.;' and ';.', and winepath ignores them completely.
|
| - func_to_host_pathlist_tmp2="$1"
|
| - # Once set for this call, this variable should not be
|
| - # reassigned. It is used in tha fallback case.
|
| - func_to_host_pathlist_tmp1=`echo "$func_to_host_pathlist_tmp2" |\
|
| - $SED -e 's|^:*||' -e 's|:*$||'`
|
| - case $build in
|
| - *mingw* ) # Actually, msys.
|
| - # Awkward: cmd appends spaces to result.
|
| - lt_sed_strip_trailing_spaces="s/[ ]*\$//"
|
| - func_to_host_pathlist_tmp2=`( cmd //c echo "$func_to_host_pathlist_tmp1" |\
|
| - $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""`
|
| - func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\
|
| - $SED -e "$lt_sed_naive_backslashify"`
|
| - ;;
|
| - *cygwin* )
|
| - func_to_host_pathlist_tmp2=`cygpath -w -p "$func_to_host_pathlist_tmp1"`
|
| - func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\
|
| - $SED -e "$lt_sed_naive_backslashify"`
|
| - ;;
|
| - * )
|
| - # unfortunately, winepath doesn't convert pathlists
|
| - func_to_host_pathlist_result=""
|
| - func_to_host_pathlist_oldIFS=$IFS
|
| - IFS=:
|
| - for func_to_host_pathlist_f in $func_to_host_pathlist_tmp1 ; do
|
| - IFS=$func_to_host_pathlist_oldIFS
|
| - if test -n "$func_to_host_pathlist_f" ; then
|
| - func_to_host_path "$func_to_host_pathlist_f"
|
| - if test -n "$func_to_host_path_result" ; then
|
| - if test -z "$func_to_host_pathlist_result" ; then
|
| - func_to_host_pathlist_result="$func_to_host_path_result"
|
| - else
|
| - func_to_host_pathlist_result="$func_to_host_pathlist_result;$func_to_host_path_result"
|
| - fi
|
| - fi
|
| - fi
|
| - IFS=:
|
| - done
|
| - IFS=$func_to_host_pathlist_oldIFS
|
| - ;;
|
| - esac
|
| - if test -z "$func_to_host_pathlist_result" ; then
|
| - func_error "Could not determine the host path(s) corresponding to"
|
| - func_error " '$1'"
|
| - func_error "Continuing, but uninstalled executables may not work."
|
| - # Fallback. This may break if $1 contains DOS-style drive
|
| - # specifications. The fix is not to complicate the expression
|
| - # below, but for the user to provide a working wine installation
|
| - # with winepath so that path translation in the cross-to-mingw
|
| - # case works properly.
|
| - lt_replace_pathsep_nix_to_dos="s|:|;|g"
|
| - func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp1" |\
|
| - $SED -e "$lt_replace_pathsep_nix_to_dos"`
|
| - fi
|
| - # Now, add the leading and trailing path separators back
|
| - case "$1" in
|
| - :* ) func_to_host_pathlist_result=";$func_to_host_pathlist_result"
|
| - ;;
|
| - esac
|
| - case "$1" in
|
| - *: ) func_to_host_pathlist_result="$func_to_host_pathlist_result;"
|
| - ;;
|
| - esac
|
| - ;;
|
| - esac
|
| - fi
|
| -}
|
| -# end: func_to_host_pathlist
|
|
|
| # func_emit_cwrapperexe_src
|
| # emit the source code for a wrapper executable on stdout
|
| @@ -3141,31 +4147,23 @@ func_emit_cwrapperexe_src ()
|
|
|
| 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* "$SHELL $output",
|
| - but could eventually absorb all of the scripts functionality and
|
| - exec $objdir/$outputname directly.
|
| */
|
| EOF
|
| cat <<"EOF"
|
| +#ifdef _MSC_VER
|
| +# define _CRT_SECURE_NO_DEPRECATE 1
|
| +#endif
|
| #include <stdio.h>
|
| #include <stdlib.h>
|
| #ifdef _MSC_VER
|
| # include <direct.h>
|
| # include <process.h>
|
| # include <io.h>
|
| -# define setmode _setmode
|
| #else
|
| # include <unistd.h>
|
| # include <stdint.h>
|
| # ifdef __CYGWIN__
|
| # include <io.h>
|
| -# define HAVE_SETENV
|
| -# ifdef __STRICT_ANSI__
|
| -char *realpath (const char *, char *);
|
| -int putenv (char *);
|
| -int setenv (const char *, const char *, int);
|
| -# endif
|
| # endif
|
| #endif
|
| #include <malloc.h>
|
| @@ -3177,6 +4175,44 @@ int setenv (const char *, const char *, int);
|
| #include <fcntl.h>
|
| #include <sys/stat.h>
|
|
|
| +/* declarations of non-ANSI functions */
|
| +#if defined(__MINGW32__)
|
| +# ifdef __STRICT_ANSI__
|
| +int _putenv (const char *);
|
| +# endif
|
| +#elif defined(__CYGWIN__)
|
| +# ifdef __STRICT_ANSI__
|
| +char *realpath (const char *, char *);
|
| +int putenv (char *);
|
| +int setenv (const char *, const char *, int);
|
| +# endif
|
| +/* #elif defined (other platforms) ... */
|
| +#endif
|
| +
|
| +/* portability defines, excluding path handling macros */
|
| +#if defined(_MSC_VER)
|
| +# define setmode _setmode
|
| +# define stat _stat
|
| +# define chmod _chmod
|
| +# define getcwd _getcwd
|
| +# define putenv _putenv
|
| +# define S_IXUSR _S_IEXEC
|
| +# ifndef _INTPTR_T_DEFINED
|
| +# define _INTPTR_T_DEFINED
|
| +# define intptr_t int
|
| +# endif
|
| +#elif defined(__MINGW32__)
|
| +# define setmode _setmode
|
| +# define stat _stat
|
| +# define chmod _chmod
|
| +# define getcwd _getcwd
|
| +# define putenv _putenv
|
| +#elif defined(__CYGWIN__)
|
| +# define HAVE_SETENV
|
| +# define FOPEN_WB "wb"
|
| +/* #elif defined (other platforms) ... */
|
| +#endif
|
| +
|
| #if defined(PATH_MAX)
|
| # define LT_PATHMAX PATH_MAX
|
| #elif defined(MAXPATHLEN)
|
| @@ -3192,14 +4228,7 @@ int setenv (const char *, const char *, int);
|
| # define S_IXGRP 0
|
| #endif
|
|
|
| -#ifdef _MSC_VER
|
| -# define S_IXUSR _S_IEXEC
|
| -# define stat _stat
|
| -# ifndef _INTPTR_T_DEFINED
|
| -# define intptr_t int
|
| -# endif
|
| -#endif
|
| -
|
| +/* path handling portability macros */
|
| #ifndef DIR_SEPARATOR
|
| # define DIR_SEPARATOR '/'
|
| # define PATH_SEPARATOR ':'
|
| @@ -3230,10 +4259,6 @@ int setenv (const char *, const char *, int);
|
| # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2)
|
| #endif /* PATH_SEPARATOR_2 */
|
|
|
| -#ifdef __CYGWIN__
|
| -# define FOPEN_WB "wb"
|
| -#endif
|
| -
|
| #ifndef FOPEN_WB
|
| # define FOPEN_WB "w"
|
| #endif
|
| @@ -3246,22 +4271,13 @@ int setenv (const char *, const char *, int);
|
| if (stale) { free ((void *) stale); stale = 0; } \
|
| } while (0)
|
|
|
| -#undef LTWRAPPER_DEBUGPRINTF
|
| -#if defined DEBUGWRAPPER
|
| -# define LTWRAPPER_DEBUGPRINTF(args) ltwrapper_debugprintf args
|
| -static void
|
| -ltwrapper_debugprintf (const char *fmt, ...)
|
| -{
|
| - va_list args;
|
| - va_start (args, fmt);
|
| - (void) vfprintf (stderr, fmt, args);
|
| - va_end (args);
|
| -}
|
| +#if defined(LT_DEBUGWRAPPER)
|
| +static int lt_debug = 1;
|
| #else
|
| -# define LTWRAPPER_DEBUGPRINTF(args)
|
| +static int lt_debug = 0;
|
| #endif
|
|
|
| -const char *program_name = NULL;
|
| +const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */
|
|
|
| void *xmalloc (size_t num);
|
| char *xstrdup (const char *string);
|
| @@ -3271,41 +4287,27 @@ char *chase_symlinks (const char *pathspec);
|
| int make_executable (const char *path);
|
| int check_executable (const char *path);
|
| char *strendzap (char *str, const char *pat);
|
| -void lt_fatal (const char *message, ...);
|
| +void lt_debugprintf (const char *file, int line, const char *fmt, ...);
|
| +void lt_fatal (const char *file, int line, const char *message, ...);
|
| +static const char *nonnull (const char *s);
|
| +static const char *nonempty (const char *s);
|
| void lt_setenv (const char *name, const char *value);
|
| char *lt_extend_str (const char *orig_value, const char *add, int to_end);
|
| -void lt_opt_process_env_set (const char *arg);
|
| -void lt_opt_process_env_prepend (const char *arg);
|
| -void lt_opt_process_env_append (const char *arg);
|
| -int lt_split_name_value (const char *arg, char** name, char** value);
|
| void lt_update_exe_path (const char *name, const char *value);
|
| void lt_update_lib_path (const char *name, const char *value);
|
| -
|
| -static const char *script_text_part1 =
|
| -EOF
|
| -
|
| - func_emit_wrapper_part1 yes |
|
| - $SED -e 's/\([\\"]\)/\\\1/g' \
|
| - -e 's/^/ "/' -e 's/$/\\n"/'
|
| - echo ";"
|
| - cat <<EOF
|
| -
|
| -static const char *script_text_part2 =
|
| +char **prepare_spawn (char **argv);
|
| +void lt_dump_script (FILE *f);
|
| EOF
|
| - func_emit_wrapper_part2 yes |
|
| - $SED -e 's/\([\\"]\)/\\\1/g' \
|
| - -e 's/^/ "/' -e 's/$/\\n"/'
|
| - echo ";"
|
|
|
| cat <<EOF
|
| -const char * MAGIC_EXE = "$magic_exe";
|
| +volatile const char * MAGIC_EXE = "$magic_exe";
|
| const char * LIB_PATH_VARNAME = "$shlibpath_var";
|
| EOF
|
|
|
| if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
|
| - func_to_host_pathlist "$temp_rpath"
|
| + func_to_host_path "$temp_rpath"
|
| cat <<EOF
|
| -const char * LIB_PATH_VALUE = "$func_to_host_pathlist_result";
|
| +const char * LIB_PATH_VALUE = "$func_to_host_path_result";
|
| EOF
|
| else
|
| cat <<"EOF"
|
| @@ -3314,10 +4316,10 @@ EOF
|
| fi
|
|
|
| if test -n "$dllsearchpath"; then
|
| - func_to_host_pathlist "$dllsearchpath:"
|
| + func_to_host_path "$dllsearchpath:"
|
| cat <<EOF
|
| const char * EXE_PATH_VARNAME = "PATH";
|
| -const char * EXE_PATH_VALUE = "$func_to_host_pathlist_result";
|
| +const char * EXE_PATH_VALUE = "$func_to_host_path_result";
|
| EOF
|
| else
|
| cat <<"EOF"
|
| @@ -3340,24 +4342,10 @@ EOF
|
| cat <<"EOF"
|
|
|
| #define LTWRAPPER_OPTION_PREFIX "--lt-"
|
| -#define LTWRAPPER_OPTION_PREFIX_LENGTH 5
|
|
|
| -static const size_t opt_prefix_len = LTWRAPPER_OPTION_PREFIX_LENGTH;
|
| static const char *ltwrapper_option_prefix = LTWRAPPER_OPTION_PREFIX;
|
| -
|
| static const char *dumpscript_opt = LTWRAPPER_OPTION_PREFIX "dump-script";
|
| -
|
| -static const size_t env_set_opt_len = LTWRAPPER_OPTION_PREFIX_LENGTH + 7;
|
| -static const char *env_set_opt = LTWRAPPER_OPTION_PREFIX "env-set";
|
| - /* argument is putenv-style "foo=bar", value of foo is set to bar */
|
| -
|
| -static const size_t env_prepend_opt_len = LTWRAPPER_OPTION_PREFIX_LENGTH + 11;
|
| -static const char *env_prepend_opt = LTWRAPPER_OPTION_PREFIX "env-prepend";
|
| - /* argument is putenv-style "foo=bar", new value of foo is bar${foo} */
|
| -
|
| -static const size_t env_append_opt_len = LTWRAPPER_OPTION_PREFIX_LENGTH + 10;
|
| -static const char *env_append_opt = LTWRAPPER_OPTION_PREFIX "env-append";
|
| - /* argument is putenv-style "foo=bar", new value of foo is ${foo}bar */
|
| +static const char *debug_opt = LTWRAPPER_OPTION_PREFIX "debug";
|
|
|
| int
|
| main (int argc, char *argv[])
|
| @@ -3374,10 +4362,13 @@ main (int argc, char *argv[])
|
| int i;
|
|
|
| program_name = (char *) xstrdup (base_name (argv[0]));
|
| - LTWRAPPER_DEBUGPRINTF (("(main) argv[0] : %s\n", argv[0]));
|
| - LTWRAPPER_DEBUGPRINTF (("(main) program_name : %s\n", program_name));
|
| + newargz = XMALLOC (char *, argc + 1);
|
|
|
| - /* very simple arg parsing; don't want to rely on getopt */
|
| + /* very simple arg parsing; don't want to rely on getopt
|
| + * also, copy all non cwrapper options to newargz, except
|
| + * argz[0], which is handled differently
|
| + */
|
| + newargc=0;
|
| for (i = 1; i < argc; i++)
|
| {
|
| if (strcmp (argv[i], dumpscript_opt) == 0)
|
| @@ -3391,25 +4382,57 @@ EOF
|
| esac
|
|
|
| cat <<"EOF"
|
| - printf ("%s", script_text_part1);
|
| - printf ("%s", script_text_part2);
|
| + lt_dump_script (stdout);
|
| return 0;
|
| }
|
| + if (strcmp (argv[i], debug_opt) == 0)
|
| + {
|
| + lt_debug = 1;
|
| + continue;
|
| + }
|
| + if (strcmp (argv[i], ltwrapper_option_prefix) == 0)
|
| + {
|
| + /* however, if there is an option in the LTWRAPPER_OPTION_PREFIX
|
| + namespace, but it is not one of the ones we know about and
|
| + have already dealt with, above (inluding dump-script), then
|
| + report an error. Otherwise, targets might begin to believe
|
| + they are allowed to use options in the LTWRAPPER_OPTION_PREFIX
|
| + namespace. The first time any user complains about this, we'll
|
| + need to make LTWRAPPER_OPTION_PREFIX a configure-time option
|
| + or a configure.ac-settable value.
|
| + */
|
| + lt_fatal (__FILE__, __LINE__,
|
| + "unrecognized %s option: '%s'",
|
| + ltwrapper_option_prefix, argv[i]);
|
| + }
|
| + /* otherwise ... */
|
| + newargz[++newargc] = xstrdup (argv[i]);
|
| }
|
| + newargz[++newargc] = NULL;
|
| +
|
| +EOF
|
| + cat <<EOF
|
| + /* The GNU banner must be the first non-error debug message */
|
| + lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\n");
|
| +EOF
|
| + cat <<"EOF"
|
| + lt_debugprintf (__FILE__, __LINE__, "(main) argv[0]: %s\n", argv[0]);
|
| + lt_debugprintf (__FILE__, __LINE__, "(main) program_name: %s\n", program_name);
|
|
|
| - newargz = XMALLOC (char *, argc + 1);
|
| tmp_pathspec = find_executable (argv[0]);
|
| if (tmp_pathspec == NULL)
|
| - lt_fatal ("Couldn't find %s", argv[0]);
|
| - LTWRAPPER_DEBUGPRINTF (("(main) found exe (before symlink chase) at : %s\n",
|
| - tmp_pathspec));
|
| + lt_fatal (__FILE__, __LINE__, "couldn't find %s", argv[0]);
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "(main) found exe (before symlink chase) at: %s\n",
|
| + tmp_pathspec);
|
|
|
| actual_cwrapper_path = chase_symlinks (tmp_pathspec);
|
| - LTWRAPPER_DEBUGPRINTF (("(main) found exe (after symlink chase) at : %s\n",
|
| - actual_cwrapper_path));
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "(main) found exe (after symlink chase) at: %s\n",
|
| + actual_cwrapper_path);
|
| XFREE (tmp_pathspec);
|
|
|
| - actual_cwrapper_name = xstrdup( base_name (actual_cwrapper_path));
|
| + actual_cwrapper_name = xstrdup (base_name (actual_cwrapper_path));
|
| strendzap (actual_cwrapper_path, actual_cwrapper_name);
|
|
|
| /* wrapper name transforms */
|
| @@ -3427,8 +4450,9 @@ EOF
|
| target_name = tmp_pathspec;
|
| tmp_pathspec = 0;
|
|
|
| - LTWRAPPER_DEBUGPRINTF (("(main) libtool target name: %s\n",
|
| - target_name));
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "(main) libtool target name: %s\n",
|
| + target_name);
|
| EOF
|
|
|
| cat <<EOF
|
| @@ -3478,80 +4502,19 @@ EOF
|
|
|
| lt_setenv ("BIN_SH", "xpg4"); /* for Tru64 */
|
| lt_setenv ("DUALCASE", "1"); /* for MSK sh */
|
| - lt_update_lib_path (LIB_PATH_VARNAME, LIB_PATH_VALUE);
|
| + /* Update the DLL searchpath. EXE_PATH_VALUE ($dllsearchpath) must
|
| + be prepended before (that is, appear after) LIB_PATH_VALUE ($temp_rpath)
|
| + because on Windows, both *_VARNAMEs are PATH but uninstalled
|
| + libraries must come first. */
|
| lt_update_exe_path (EXE_PATH_VARNAME, EXE_PATH_VALUE);
|
| + lt_update_lib_path (LIB_PATH_VARNAME, LIB_PATH_VALUE);
|
|
|
| - newargc=0;
|
| - for (i = 1; i < argc; i++)
|
| - {
|
| - if (strncmp (argv[i], env_set_opt, env_set_opt_len) == 0)
|
| - {
|
| - if (argv[i][env_set_opt_len] == '=')
|
| - {
|
| - const char *p = argv[i] + env_set_opt_len + 1;
|
| - lt_opt_process_env_set (p);
|
| - }
|
| - else if (argv[i][env_set_opt_len] == '\0' && i + 1 < argc)
|
| - {
|
| - lt_opt_process_env_set (argv[++i]); /* don't copy */
|
| - }
|
| - else
|
| - lt_fatal ("%s missing required argument", env_set_opt);
|
| - continue;
|
| - }
|
| - if (strncmp (argv[i], env_prepend_opt, env_prepend_opt_len) == 0)
|
| - {
|
| - if (argv[i][env_prepend_opt_len] == '=')
|
| - {
|
| - const char *p = argv[i] + env_prepend_opt_len + 1;
|
| - lt_opt_process_env_prepend (p);
|
| - }
|
| - else if (argv[i][env_prepend_opt_len] == '\0' && i + 1 < argc)
|
| - {
|
| - lt_opt_process_env_prepend (argv[++i]); /* don't copy */
|
| - }
|
| - else
|
| - lt_fatal ("%s missing required argument", env_prepend_opt);
|
| - continue;
|
| - }
|
| - if (strncmp (argv[i], env_append_opt, env_append_opt_len) == 0)
|
| - {
|
| - if (argv[i][env_append_opt_len] == '=')
|
| - {
|
| - const char *p = argv[i] + env_append_opt_len + 1;
|
| - lt_opt_process_env_append (p);
|
| - }
|
| - else if (argv[i][env_append_opt_len] == '\0' && i + 1 < argc)
|
| - {
|
| - lt_opt_process_env_append (argv[++i]); /* don't copy */
|
| - }
|
| - else
|
| - lt_fatal ("%s missing required argument", env_append_opt);
|
| - continue;
|
| - }
|
| - if (strncmp (argv[i], ltwrapper_option_prefix, opt_prefix_len) == 0)
|
| - {
|
| - /* however, if there is an option in the LTWRAPPER_OPTION_PREFIX
|
| - namespace, but it is not one of the ones we know about and
|
| - have already dealt with, above (inluding dump-script), then
|
| - report an error. Otherwise, targets might begin to believe
|
| - they are allowed to use options in the LTWRAPPER_OPTION_PREFIX
|
| - namespace. The first time any user complains about this, we'll
|
| - need to make LTWRAPPER_OPTION_PREFIX a configure-time option
|
| - or a configure.ac-settable value.
|
| - */
|
| - lt_fatal ("Unrecognized option in %s namespace: '%s'",
|
| - ltwrapper_option_prefix, argv[i]);
|
| - }
|
| - /* otherwise ... */
|
| - newargz[++newargc] = xstrdup (argv[i]);
|
| - }
|
| - newargz[++newargc] = NULL;
|
| -
|
| - LTWRAPPER_DEBUGPRINTF (("(main) lt_argv_zero : %s\n", (lt_argv_zero ? lt_argv_zero : "<NULL>")));
|
| + lt_debugprintf (__FILE__, __LINE__, "(main) lt_argv_zero: %s\n",
|
| + nonnull (lt_argv_zero));
|
| for (i = 0; i < newargc; i++)
|
| {
|
| - LTWRAPPER_DEBUGPRINTF (("(main) newargz[%d] : %s\n", i, (newargz[i] ? newargz[i] : "<NULL>")));
|
| + lt_debugprintf (__FILE__, __LINE__, "(main) newargz[%d]: %s\n",
|
| + i, nonnull (newargz[i]));
|
| }
|
|
|
| EOF
|
| @@ -3560,11 +4523,14 @@ EOF
|
| mingw*)
|
| cat <<"EOF"
|
| /* execv doesn't actually work on mingw as expected on unix */
|
| + newargz = prepare_spawn (newargz);
|
| rval = _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
|
| if (rval == -1)
|
| {
|
| /* failed to start process */
|
| - LTWRAPPER_DEBUGPRINTF (("(main) failed to launch target \"%s\": errno = %d\n", lt_argv_zero, errno));
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "(main) failed to launch target \"%s\": %s\n",
|
| + lt_argv_zero, nonnull (strerror (errno)));
|
| return 127;
|
| }
|
| return rval;
|
| @@ -3586,7 +4552,7 @@ xmalloc (size_t num)
|
| {
|
| void *p = (void *) malloc (num);
|
| if (!p)
|
| - lt_fatal ("Memory exhausted");
|
| + lt_fatal (__FILE__, __LINE__, "memory exhausted");
|
|
|
| return p;
|
| }
|
| @@ -3620,8 +4586,8 @@ check_executable (const char *path)
|
| {
|
| struct stat st;
|
|
|
| - LTWRAPPER_DEBUGPRINTF (("(check_executable) : %s\n",
|
| - path ? (*path ? path : "EMPTY!") : "NULL!"));
|
| + lt_debugprintf (__FILE__, __LINE__, "(check_executable): %s\n",
|
| + nonempty (path));
|
| if ((!path) || (!*path))
|
| return 0;
|
|
|
| @@ -3638,8 +4604,8 @@ make_executable (const char *path)
|
| int rval = 0;
|
| struct stat st;
|
|
|
| - LTWRAPPER_DEBUGPRINTF (("(make_executable) : %s\n",
|
| - path ? (*path ? path : "EMPTY!") : "NULL!"));
|
| + lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n",
|
| + nonempty (path));
|
| if ((!path) || (!*path))
|
| return 0;
|
|
|
| @@ -3665,8 +4631,8 @@ find_executable (const char *wrapper)
|
| int tmp_len;
|
| char *concat_name;
|
|
|
| - LTWRAPPER_DEBUGPRINTF (("(find_executable) : %s\n",
|
| - wrapper ? (*wrapper ? wrapper : "EMPTY!") : "NULL!"));
|
| + lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n",
|
| + nonempty (wrapper));
|
|
|
| if ((wrapper == NULL) || (*wrapper == '\0'))
|
| return NULL;
|
| @@ -3719,7 +4685,8 @@ find_executable (const char *wrapper)
|
| {
|
| /* empty path: current directory */
|
| if (getcwd (tmp, LT_PATHMAX) == NULL)
|
| - lt_fatal ("getcwd failed");
|
| + lt_fatal (__FILE__, __LINE__, "getcwd failed: %s",
|
| + nonnull (strerror (errno)));
|
| tmp_len = strlen (tmp);
|
| concat_name =
|
| XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1);
|
| @@ -3744,7 +4711,8 @@ find_executable (const char *wrapper)
|
| }
|
| /* Relative path | not found in path: prepend cwd */
|
| if (getcwd (tmp, LT_PATHMAX) == NULL)
|
| - lt_fatal ("getcwd failed");
|
| + lt_fatal (__FILE__, __LINE__, "getcwd failed: %s",
|
| + nonnull (strerror (errno)));
|
| tmp_len = strlen (tmp);
|
| concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1);
|
| memcpy (concat_name, tmp, tmp_len);
|
| @@ -3770,8 +4738,9 @@ chase_symlinks (const char *pathspec)
|
| int has_symlinks = 0;
|
| while (strlen (tmp_pathspec) && !has_symlinks)
|
| {
|
| - LTWRAPPER_DEBUGPRINTF (("checking path component for symlinks: %s\n",
|
| - tmp_pathspec));
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "checking path component for symlinks: %s\n",
|
| + tmp_pathspec);
|
| if (lstat (tmp_pathspec, &s) == 0)
|
| {
|
| if (S_ISLNK (s.st_mode) != 0)
|
| @@ -3793,8 +4762,9 @@ chase_symlinks (const char *pathspec)
|
| }
|
| else
|
| {
|
| - char *errstr = strerror (errno);
|
| - lt_fatal ("Error accessing file %s (%s)", tmp_pathspec, errstr);
|
| + lt_fatal (__FILE__, __LINE__,
|
| + "error accessing file \"%s\": %s",
|
| + tmp_pathspec, nonnull (strerror (errno)));
|
| }
|
| }
|
| XFREE (tmp_pathspec);
|
| @@ -3807,7 +4777,8 @@ chase_symlinks (const char *pathspec)
|
| tmp_pathspec = realpath (pathspec, buf);
|
| if (tmp_pathspec == 0)
|
| {
|
| - lt_fatal ("Could not follow symlinks for %s", pathspec);
|
| + lt_fatal (__FILE__, __LINE__,
|
| + "could not follow symlinks for %s", pathspec);
|
| }
|
| return xstrdup (tmp_pathspec);
|
| #endif
|
| @@ -3833,11 +4804,25 @@ strendzap (char *str, const char *pat)
|
| return str;
|
| }
|
|
|
| +void
|
| +lt_debugprintf (const char *file, int line, const char *fmt, ...)
|
| +{
|
| + va_list args;
|
| + if (lt_debug)
|
| + {
|
| + (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line);
|
| + va_start (args, fmt);
|
| + (void) vfprintf (stderr, fmt, args);
|
| + va_end (args);
|
| + }
|
| +}
|
| +
|
| static void
|
| -lt_error_core (int exit_status, const char *mode,
|
| +lt_error_core (int exit_status, const char *file,
|
| + int line, const char *mode,
|
| const char *message, va_list ap)
|
| {
|
| - fprintf (stderr, "%s: %s: ", program_name, mode);
|
| + fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode);
|
| vfprintf (stderr, message, ap);
|
| fprintf (stderr, ".\n");
|
|
|
| @@ -3846,20 +4831,32 @@ lt_error_core (int exit_status, const char *mode,
|
| }
|
|
|
| void
|
| -lt_fatal (const char *message, ...)
|
| +lt_fatal (const char *file, int line, const char *message, ...)
|
| {
|
| va_list ap;
|
| va_start (ap, message);
|
| - lt_error_core (EXIT_FAILURE, "FATAL", message, ap);
|
| + lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap);
|
| va_end (ap);
|
| }
|
|
|
| +static const char *
|
| +nonnull (const char *s)
|
| +{
|
| + return s ? s : "(null)";
|
| +}
|
| +
|
| +static const char *
|
| +nonempty (const char *s)
|
| +{
|
| + return (s && !*s) ? "(empty)" : nonnull (s);
|
| +}
|
| +
|
| void
|
| lt_setenv (const char *name, const char *value)
|
| {
|
| - LTWRAPPER_DEBUGPRINTF (("(lt_setenv) setting '%s' to '%s'\n",
|
| - (name ? name : "<NULL>"),
|
| - (value ? value : "<NULL>")));
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "(lt_setenv) setting '%s' to '%s'\n",
|
| + nonnull (name), nonnull (value));
|
| {
|
| #ifdef HAVE_SETENV
|
| /* always make a copy, for consistency with !HAVE_SETENV */
|
| @@ -3904,95 +4901,12 @@ lt_extend_str (const char *orig_value, const char *add, int to_end)
|
| return new_value;
|
| }
|
|
|
| -int
|
| -lt_split_name_value (const char *arg, char** name, char** value)
|
| -{
|
| - const char *p;
|
| - int len;
|
| - if (!arg || !*arg)
|
| - return 1;
|
| -
|
| - p = strchr (arg, (int)'=');
|
| -
|
| - if (!p)
|
| - return 1;
|
| -
|
| - *value = xstrdup (++p);
|
| -
|
| - len = strlen (arg) - strlen (*value);
|
| - *name = XMALLOC (char, len);
|
| - strncpy (*name, arg, len-1);
|
| - (*name)[len - 1] = '\0';
|
| -
|
| - return 0;
|
| -}
|
| -
|
| -void
|
| -lt_opt_process_env_set (const char *arg)
|
| -{
|
| - char *name = NULL;
|
| - char *value = NULL;
|
| -
|
| - if (lt_split_name_value (arg, &name, &value) != 0)
|
| - {
|
| - XFREE (name);
|
| - XFREE (value);
|
| - lt_fatal ("bad argument for %s: '%s'", env_set_opt, arg);
|
| - }
|
| -
|
| - lt_setenv (name, value);
|
| - XFREE (name);
|
| - XFREE (value);
|
| -}
|
| -
|
| -void
|
| -lt_opt_process_env_prepend (const char *arg)
|
| -{
|
| - char *name = NULL;
|
| - char *value = NULL;
|
| - char *new_value = NULL;
|
| -
|
| - if (lt_split_name_value (arg, &name, &value) != 0)
|
| - {
|
| - XFREE (name);
|
| - XFREE (value);
|
| - lt_fatal ("bad argument for %s: '%s'", env_prepend_opt, arg);
|
| - }
|
| -
|
| - new_value = lt_extend_str (getenv (name), value, 0);
|
| - lt_setenv (name, new_value);
|
| - XFREE (new_value);
|
| - XFREE (name);
|
| - XFREE (value);
|
| -}
|
| -
|
| -void
|
| -lt_opt_process_env_append (const char *arg)
|
| -{
|
| - char *name = NULL;
|
| - char *value = NULL;
|
| - char *new_value = NULL;
|
| -
|
| - if (lt_split_name_value (arg, &name, &value) != 0)
|
| - {
|
| - XFREE (name);
|
| - XFREE (value);
|
| - lt_fatal ("bad argument for %s: '%s'", env_append_opt, arg);
|
| - }
|
| -
|
| - new_value = lt_extend_str (getenv (name), value, 1);
|
| - lt_setenv (name, new_value);
|
| - XFREE (new_value);
|
| - XFREE (name);
|
| - XFREE (value);
|
| -}
|
| -
|
| void
|
| lt_update_exe_path (const char *name, const char *value)
|
| {
|
| - LTWRAPPER_DEBUGPRINTF (("(lt_update_exe_path) modifying '%s' by prepending '%s'\n",
|
| - (name ? name : "<NULL>"),
|
| - (value ? value : "<NULL>")));
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "(lt_update_exe_path) modifying '%s' by prepending '%s'\n",
|
| + nonnull (name), nonnull (value));
|
|
|
| if (name && *name && value && *value)
|
| {
|
| @@ -4011,9 +4925,9 @@ lt_update_exe_path (const char *name, const char *value)
|
| void
|
| lt_update_lib_path (const char *name, const char *value)
|
| {
|
| - LTWRAPPER_DEBUGPRINTF (("(lt_update_lib_path) modifying '%s' by prepending '%s'\n",
|
| - (name ? name : "<NULL>"),
|
| - (value ? value : "<NULL>")));
|
| + lt_debugprintf (__FILE__, __LINE__,
|
| + "(lt_update_lib_path) modifying '%s' by prepending '%s'\n",
|
| + nonnull (name), nonnull (value));
|
|
|
| if (name && *name && value && *value)
|
| {
|
| @@ -4023,11 +4937,158 @@ lt_update_lib_path (const char *name, const char *value)
|
| }
|
| }
|
|
|
| +EOF
|
| + case $host_os in
|
| + mingw*)
|
| + cat <<"EOF"
|
| +
|
| +/* Prepares an argument vector before calling spawn().
|
| + Note that spawn() does not by itself call the command interpreter
|
| + (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") :
|
| + ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
|
| + GetVersionEx(&v);
|
| + v.dwPlatformId == VER_PLATFORM_WIN32_NT;
|
| + }) ? "cmd.exe" : "command.com").
|
| + Instead it simply concatenates the arguments, separated by ' ', and calls
|
| + CreateProcess(). We must quote the arguments since Win32 CreateProcess()
|
| + interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a
|
| + special way:
|
| + - Space and tab are interpreted as delimiters. They are not treated as
|
| + delimiters if they are surrounded by double quotes: "...".
|
| + - Unescaped double quotes are removed from the input. Their only effect is
|
| + that within double quotes, space and tab are treated like normal
|
| + characters.
|
| + - Backslashes not followed by double quotes are not special.
|
| + - But 2*n+1 backslashes followed by a double quote become
|
| + n backslashes followed by a double quote (n >= 0):
|
| + \" -> "
|
| + \\\" -> \"
|
| + \\\\\" -> \\"
|
| + */
|
| +#define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037"
|
| +#define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037"
|
| +char **
|
| +prepare_spawn (char **argv)
|
| +{
|
| + size_t argc;
|
| + char **new_argv;
|
| + size_t i;
|
| +
|
| + /* Count number of arguments. */
|
| + for (argc = 0; argv[argc] != NULL; argc++)
|
| + ;
|
| +
|
| + /* Allocate new argument vector. */
|
| + new_argv = XMALLOC (char *, argc + 1);
|
| +
|
| + /* Put quoted arguments into the new argument vector. */
|
| + for (i = 0; i < argc; i++)
|
| + {
|
| + const char *string = argv[i];
|
| +
|
| + if (string[0] == '\0')
|
| + new_argv[i] = xstrdup ("\"\"");
|
| + else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL)
|
| + {
|
| + int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL);
|
| + size_t length;
|
| + unsigned int backslashes;
|
| + const char *s;
|
| + char *quoted_string;
|
| + char *p;
|
| +
|
| + length = 0;
|
| + backslashes = 0;
|
| + if (quote_around)
|
| + length++;
|
| + for (s = string; *s != '\0'; s++)
|
| + {
|
| + char c = *s;
|
| + if (c == '"')
|
| + length += backslashes + 1;
|
| + length++;
|
| + if (c == '\\')
|
| + backslashes++;
|
| + else
|
| + backslashes = 0;
|
| + }
|
| + if (quote_around)
|
| + length += backslashes + 1;
|
| +
|
| + quoted_string = XMALLOC (char, length + 1);
|
| +
|
| + p = quoted_string;
|
| + backslashes = 0;
|
| + if (quote_around)
|
| + *p++ = '"';
|
| + for (s = string; *s != '\0'; s++)
|
| + {
|
| + char c = *s;
|
| + if (c == '"')
|
| + {
|
| + unsigned int j;
|
| + for (j = backslashes + 1; j > 0; j--)
|
| + *p++ = '\\';
|
| + }
|
| + *p++ = c;
|
| + if (c == '\\')
|
| + backslashes++;
|
| + else
|
| + backslashes = 0;
|
| + }
|
| + if (quote_around)
|
| + {
|
| + unsigned int j;
|
| + for (j = backslashes; j > 0; j--)
|
| + *p++ = '\\';
|
| + *p++ = '"';
|
| + }
|
| + *p = '\0';
|
| +
|
| + new_argv[i] = quoted_string;
|
| + }
|
| + else
|
| + new_argv[i] = (char *) string;
|
| + }
|
| + new_argv[argc] = NULL;
|
| +
|
| + return new_argv;
|
| +}
|
| +EOF
|
| + ;;
|
| + esac
|
|
|
| + cat <<"EOF"
|
| +void lt_dump_script (FILE* f)
|
| +{
|
| +EOF
|
| + func_emit_wrapper yes |
|
| + $SED -n -e '
|
| +s/^\(.\{79\}\)\(..*\)/\1\
|
| +\2/
|
| +h
|
| +s/\([\\"]\)/\\\1/g
|
| +s/$/\\n/
|
| +s/\([^\n]*\).*/ fputs ("\1", f);/p
|
| +g
|
| +D'
|
| + cat <<"EOF"
|
| +}
|
| EOF
|
| }
|
| # end: func_emit_cwrapperexe_src
|
|
|
| +# func_win32_import_lib_p ARG
|
| +# True if ARG is an import lib, as indicated by $file_magic_cmd
|
| +func_win32_import_lib_p ()
|
| +{
|
| + $opt_debug
|
| + case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in
|
| + *import*) : ;;
|
| + *) false ;;
|
| + esac
|
| +}
|
| +
|
| # func_mode_link arg...
|
| func_mode_link ()
|
| {
|
| @@ -4072,6 +5133,7 @@ func_mode_link ()
|
| new_inherited_linker_flags=
|
|
|
| avoid_version=no
|
| + bindir=
|
| dlfiles=
|
| dlprefiles=
|
| dlself=no
|
| @@ -4164,6 +5226,11 @@ func_mode_link ()
|
| esac
|
|
|
| case $prev in
|
| + bindir)
|
| + bindir="$arg"
|
| + prev=
|
| + continue
|
| + ;;
|
| dlfiles|dlprefiles)
|
| if test "$preload" = no; then
|
| # Add the symbol object into the linking commands.
|
| @@ -4195,9 +5262,9 @@ func_mode_link ()
|
| ;;
|
| *)
|
| if test "$prev" = dlfiles; then
|
| - dlfiles="$dlfiles $arg"
|
| + func_append dlfiles " $arg"
|
| else
|
| - dlprefiles="$dlprefiles $arg"
|
| + func_append dlprefiles " $arg"
|
| fi
|
| prev=
|
| continue
|
| @@ -4221,7 +5288,7 @@ func_mode_link ()
|
| *-*-darwin*)
|
| case "$deplibs " in
|
| *" $qarg.ltframework "*) ;;
|
| - *) deplibs="$deplibs $qarg.ltframework" # this is fixed later
|
| + *) func_append deplibs " $qarg.ltframework" # this is fixed later
|
| ;;
|
| esac
|
| ;;
|
| @@ -4240,7 +5307,7 @@ func_mode_link ()
|
| moreargs=
|
| for fil in `cat "$save_arg"`
|
| do
|
| -# moreargs="$moreargs $fil"
|
| +# func_append moreargs " $fil"
|
| arg=$fil
|
| # A libtool-controlled object.
|
|
|
| @@ -4269,7 +5336,7 @@ func_mode_link ()
|
|
|
| if test "$prev" = dlfiles; then
|
| if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
|
| - dlfiles="$dlfiles $pic_object"
|
| + func_append dlfiles " $pic_object"
|
| prev=
|
| continue
|
| else
|
| @@ -4281,7 +5348,7 @@ func_mode_link ()
|
| # CHECK ME: I think I busted this. -Ossama
|
| if test "$prev" = dlprefiles; then
|
| # Preload the old-style object.
|
| - dlprefiles="$dlprefiles $pic_object"
|
| + func_append dlprefiles " $pic_object"
|
| prev=
|
| fi
|
|
|
| @@ -4351,12 +5418,12 @@ func_mode_link ()
|
| if test "$prev" = rpath; then
|
| case "$rpath " in
|
| *" $arg "*) ;;
|
| - *) rpath="$rpath $arg" ;;
|
| + *) func_append rpath " $arg" ;;
|
| esac
|
| else
|
| case "$xrpath " in
|
| *" $arg "*) ;;
|
| - *) xrpath="$xrpath $arg" ;;
|
| + *) func_append xrpath " $arg" ;;
|
| esac
|
| fi
|
| prev=
|
| @@ -4368,28 +5435,28 @@ func_mode_link ()
|
| continue
|
| ;;
|
| weak)
|
| - weak_libs="$weak_libs $arg"
|
| + func_append weak_libs " $arg"
|
| prev=
|
| continue
|
| ;;
|
| xcclinker)
|
| - linker_flags="$linker_flags $qarg"
|
| - compiler_flags="$compiler_flags $qarg"
|
| + func_append linker_flags " $qarg"
|
| + func_append compiler_flags " $qarg"
|
| prev=
|
| func_append compile_command " $qarg"
|
| func_append finalize_command " $qarg"
|
| continue
|
| ;;
|
| xcompiler)
|
| - compiler_flags="$compiler_flags $qarg"
|
| + func_append compiler_flags " $qarg"
|
| prev=
|
| func_append compile_command " $qarg"
|
| func_append finalize_command " $qarg"
|
| continue
|
| ;;
|
| xlinker)
|
| - linker_flags="$linker_flags $qarg"
|
| - compiler_flags="$compiler_flags $wl$qarg"
|
| + func_append linker_flags " $qarg"
|
| + func_append compiler_flags " $wl$qarg"
|
| prev=
|
| func_append compile_command " $wl$qarg"
|
| func_append finalize_command " $wl$qarg"
|
| @@ -4425,6 +5492,11 @@ func_mode_link ()
|
| continue
|
| ;;
|
|
|
| + -bindir)
|
| + prev=bindir
|
| + continue
|
| + ;;
|
| +
|
| -dlopen)
|
| prev=dlfiles
|
| continue
|
| @@ -4475,15 +5547,16 @@ func_mode_link ()
|
| ;;
|
|
|
| -L*)
|
| - func_stripname '-L' '' "$arg"
|
| - dir=$func_stripname_result
|
| - if test -z "$dir"; then
|
| + func_stripname "-L" '' "$arg"
|
| + if test -z "$func_stripname_result"; then
|
| if test "$#" -gt 0; then
|
| func_fatal_error "require no space between \`-L' and \`$1'"
|
| else
|
| func_fatal_error "need path for \`-L' option"
|
| fi
|
| fi
|
| + func_resolve_sysroot "$func_stripname_result"
|
| + dir=$func_resolve_sysroot_result
|
| # We need an absolute path.
|
| case $dir in
|
| [\\/]* | [A-Za-z]:[\\/]*) ;;
|
| @@ -4495,24 +5568,30 @@ func_mode_link ()
|
| ;;
|
| esac
|
| case "$deplibs " in
|
| - *" -L$dir "*) ;;
|
| + *" -L$dir "* | *" $arg "*)
|
| + # Will only happen for absolute or sysroot arguments
|
| + ;;
|
| *)
|
| - deplibs="$deplibs -L$dir"
|
| - lib_search_path="$lib_search_path $dir"
|
| + # Preserve sysroot, but never include relative directories
|
| + case $dir in
|
| + [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;;
|
| + *) func_append deplibs " -L$dir" ;;
|
| + esac
|
| + func_append lib_search_path " $dir"
|
| ;;
|
| esac
|
| case $host in
|
| *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
|
| - testbindir=`$ECHO "X$dir" | $Xsed -e 's*/lib$*/bin*'`
|
| + testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'`
|
| case :$dllsearchpath: in
|
| *":$dir:"*) ;;
|
| ::) dllsearchpath=$dir;;
|
| - *) dllsearchpath="$dllsearchpath:$dir";;
|
| + *) func_append dllsearchpath ":$dir";;
|
| esac
|
| case :$dllsearchpath: in
|
| *":$testbindir:"*) ;;
|
| ::) dllsearchpath=$testbindir;;
|
| - *) dllsearchpath="$dllsearchpath:$testbindir";;
|
| + *) func_append dllsearchpath ":$testbindir";;
|
| esac
|
| ;;
|
| esac
|
| @@ -4522,7 +5601,7 @@ func_mode_link ()
|
| -l*)
|
| if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then
|
| case $host in
|
| - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc*)
|
| + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*)
|
| # These systems don't actually have a C or math library (as such)
|
| continue
|
| ;;
|
| @@ -4536,7 +5615,7 @@ func_mode_link ()
|
| ;;
|
| *-*-rhapsody* | *-*-darwin1.[012])
|
| # Rhapsody C and math libraries are in the System framework
|
| - deplibs="$deplibs System.ltframework"
|
| + func_append deplibs " System.ltframework"
|
| continue
|
| ;;
|
| *-*-sco3.2v5* | *-*-sco5v6*)
|
| @@ -4556,7 +5635,7 @@ func_mode_link ()
|
| ;;
|
| esac
|
| fi
|
| - deplibs="$deplibs $arg"
|
| + func_append deplibs " $arg"
|
| continue
|
| ;;
|
|
|
| @@ -4568,21 +5647,22 @@ func_mode_link ()
|
| # Tru64 UNIX uses -model [arg] to determine the layout of C++
|
| # classes, name mangling, and exception handling.
|
| # Darwin uses the -arch flag to determine output architecture.
|
| - -model|-arch|-isysroot)
|
| - compiler_flags="$compiler_flags $arg"
|
| + -model|-arch|-isysroot|--sysroot)
|
| + func_append compiler_flags " $arg"
|
| func_append compile_command " $arg"
|
| func_append finalize_command " $arg"
|
| prev=xcompiler
|
| continue
|
| ;;
|
|
|
| - -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads)
|
| - compiler_flags="$compiler_flags $arg"
|
| + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \
|
| + |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*)
|
| + func_append compiler_flags " $arg"
|
| func_append compile_command " $arg"
|
| func_append finalize_command " $arg"
|
| case "$new_inherited_linker_flags " in
|
| *" $arg "*) ;;
|
| - * ) new_inherited_linker_flags="$new_inherited_linker_flags $arg" ;;
|
| + * ) func_append new_inherited_linker_flags " $arg" ;;
|
| esac
|
| continue
|
| ;;
|
| @@ -4649,13 +5729,17 @@ func_mode_link ()
|
| # We need an absolute path.
|
| case $dir in
|
| [\\/]* | [A-Za-z]:[\\/]*) ;;
|
| + =*)
|
| + func_stripname '=' '' "$dir"
|
| + dir=$lt_sysroot$func_stripname_result
|
| + ;;
|
| *)
|
| func_fatal_error "only absolute run-paths are allowed"
|
| ;;
|
| esac
|
| case "$xrpath " in
|
| *" $dir "*) ;;
|
| - *) xrpath="$xrpath $dir" ;;
|
| + *) func_append xrpath " $dir" ;;
|
| esac
|
| continue
|
| ;;
|
| @@ -4708,8 +5792,8 @@ func_mode_link ()
|
| for flag in $args; do
|
| IFS="$save_ifs"
|
| func_quote_for_eval "$flag"
|
| - arg="$arg $wl$func_quote_for_eval_result"
|
| - compiler_flags="$compiler_flags $func_quote_for_eval_result"
|
| + func_append arg " $func_quote_for_eval_result"
|
| + func_append compiler_flags " $func_quote_for_eval_result"
|
| done
|
| IFS="$save_ifs"
|
| func_stripname ' ' '' "$arg"
|
| @@ -4724,9 +5808,9 @@ func_mode_link ()
|
| for flag in $args; do
|
| IFS="$save_ifs"
|
| func_quote_for_eval "$flag"
|
| - arg="$arg $wl$func_quote_for_eval_result"
|
| - compiler_flags="$compiler_flags $wl$func_quote_for_eval_result"
|
| - linker_flags="$linker_flags $func_quote_for_eval_result"
|
| + func_append arg " $wl$func_quote_for_eval_result"
|
| + func_append compiler_flags " $wl$func_quote_for_eval_result"
|
| + func_append linker_flags " $func_quote_for_eval_result"
|
| done
|
| IFS="$save_ifs"
|
| func_stripname ' ' '' "$arg"
|
| @@ -4754,23 +5838,27 @@ func_mode_link ()
|
| arg="$func_quote_for_eval_result"
|
| ;;
|
|
|
| - # -64, -mips[0-9] enable 64-bit mode on the SGI compiler
|
| - # -r[0-9][0-9]* specifies the processor on the SGI compiler
|
| - # -xarch=*, -xtarget=* enable 64-bit mode on the Sun compiler
|
| - # +DA*, +DD* enable 64-bit mode on the HP compiler
|
| - # -q* pass through compiler args for the IBM compiler
|
| - # -m*, -t[45]*, -txscale* pass through architecture-specific
|
| - # compiler args for GCC
|
| - # -F/path gives path to uninstalled frameworks, gcc on darwin
|
| - # -p, -pg, --coverage, -fprofile-* pass through profiling flag for GCC
|
| - # @file GCC response files
|
| + # Flags to be passed through unchanged, with rationale:
|
| + # -64, -mips[0-9] enable 64-bit mode for the SGI compiler
|
| + # -r[0-9][0-9]* specify processor for the SGI compiler
|
| + # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler
|
| + # +DA*, +DD* enable 64-bit mode for the HP compiler
|
| + # -q* compiler args for the IBM compiler
|
| + # -m*, -t[45]*, -txscale* architecture-specific flags for GCC
|
| + # -F/path path to uninstalled frameworks, gcc on darwin
|
| + # -p, -pg, --coverage, -fprofile-* profiling flags for GCC
|
| + # @file GCC response files
|
| + # -tp=* Portland pgcc target processor selection
|
| + # --sysroot=* for sysroot support
|
| + # -O*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization
|
| -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
|
| - -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*)
|
| + -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
|
| + -O*|-flto*|-fwhopr*|-fuse-linker-plugin)
|
| func_quote_for_eval "$arg"
|
| arg="$func_quote_for_eval_result"
|
| func_append compile_command " $arg"
|
| func_append finalize_command " $arg"
|
| - compiler_flags="$compiler_flags $arg"
|
| + func_append compiler_flags " $arg"
|
| continue
|
| ;;
|
|
|
| @@ -4782,7 +5870,7 @@ func_mode_link ()
|
|
|
| *.$objext)
|
| # A standard object.
|
| - objs="$objs $arg"
|
| + func_append objs " $arg"
|
| ;;
|
|
|
| *.lo)
|
| @@ -4813,7 +5901,7 @@ func_mode_link ()
|
|
|
| if test "$prev" = dlfiles; then
|
| if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
|
| - dlfiles="$dlfiles $pic_object"
|
| + func_append dlfiles " $pic_object"
|
| prev=
|
| continue
|
| else
|
| @@ -4825,7 +5913,7 @@ func_mode_link ()
|
| # CHECK ME: I think I busted this. -Ossama
|
| if test "$prev" = dlprefiles; then
|
| # Preload the old-style object.
|
| - dlprefiles="$dlprefiles $pic_object"
|
| + func_append dlprefiles " $pic_object"
|
| prev=
|
| fi
|
|
|
| @@ -4870,24 +5958,25 @@ func_mode_link ()
|
|
|
| *.$libext)
|
| # An archive.
|
| - deplibs="$deplibs $arg"
|
| - old_deplibs="$old_deplibs $arg"
|
| + func_append deplibs " $arg"
|
| + func_append old_deplibs " $arg"
|
| continue
|
| ;;
|
|
|
| *.la)
|
| # A libtool-controlled library.
|
|
|
| + func_resolve_sysroot "$arg"
|
| if test "$prev" = dlfiles; then
|
| # This library was specified with -dlopen.
|
| - dlfiles="$dlfiles $arg"
|
| + func_append dlfiles " $func_resolve_sysroot_result"
|
| prev=
|
| elif test "$prev" = dlprefiles; then
|
| # The library was specified with -dlpreopen.
|
| - dlprefiles="$dlprefiles $arg"
|
| + func_append dlprefiles " $func_resolve_sysroot_result"
|
| prev=
|
| else
|
| - deplibs="$deplibs $arg"
|
| + func_append deplibs " $func_resolve_sysroot_result"
|
| fi
|
| continue
|
| ;;
|
| @@ -4925,7 +6014,7 @@ func_mode_link ()
|
|
|
| if test -n "$shlibpath_var"; then
|
| # get the directories listed in $shlibpath_var
|
| - eval shlib_search_path=\`\$ECHO \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\`
|
| + eval shlib_search_path=\`\$ECHO \"\${$shlibpath_var}\" \| \$SED \'s/:/ /g\'\`
|
| else
|
| shlib_search_path=
|
| fi
|
| @@ -4934,6 +6023,8 @@ func_mode_link ()
|
|
|
| func_dirname "$output" "/" ""
|
| output_objdir="$func_dirname_result$objdir"
|
| + func_to_tool_file "$output_objdir/"
|
| + tool_output_objdir=$func_to_tool_file_result
|
| # Create the object directory.
|
| func_mkdir_p "$output_objdir"
|
|
|
| @@ -4954,12 +6045,12 @@ func_mode_link ()
|
| # Find all interdependent deplibs by searching for libraries
|
| # that are linked more than once (e.g. -la -lb -la)
|
| for deplib in $deplibs; do
|
| - if $opt_duplicate_deps ; then
|
| + if $opt_preserve_dup_deps ; then
|
| case "$libs " in
|
| - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
|
| + *" $deplib "*) func_append specialdeplibs " $deplib" ;;
|
| esac
|
| fi
|
| - libs="$libs $deplib"
|
| + func_append libs " $deplib"
|
| done
|
|
|
| if test "$linkmode" = lib; then
|
| @@ -4972,9 +6063,9 @@ func_mode_link ()
|
| if $opt_duplicate_compiler_generated_deps; then
|
| for pre_post_dep in $predeps $postdeps; do
|
| case "$pre_post_deps " in
|
| - *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;;
|
| + *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;;
|
| esac
|
| - pre_post_deps="$pre_post_deps $pre_post_dep"
|
| + func_append pre_post_deps " $pre_post_dep"
|
| done
|
| fi
|
| pre_post_deps=
|
| @@ -5044,17 +6135,19 @@ func_mode_link ()
|
| for lib in $dlprefiles; do
|
| # Ignore non-libtool-libs
|
| dependency_libs=
|
| + func_resolve_sysroot "$lib"
|
| case $lib in
|
| - *.la) func_source "$lib" ;;
|
| + *.la) func_source "$func_resolve_sysroot_result" ;;
|
| esac
|
|
|
| # Collect preopened libtool deplibs, except any this library
|
| # has declared as weak libs
|
| for deplib in $dependency_libs; do
|
| - deplib_base=`$ECHO "X$deplib" | $Xsed -e "$basename"`
|
| + func_basename "$deplib"
|
| + deplib_base=$func_basename_result
|
| case " $weak_libs " in
|
| *" $deplib_base "*) ;;
|
| - *) deplibs="$deplibs $deplib" ;;
|
| + *) func_append deplibs " $deplib" ;;
|
| esac
|
| done
|
| done
|
| @@ -5070,16 +6163,17 @@ func_mode_link ()
|
| lib=
|
| found=no
|
| case $deplib in
|
| - -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads)
|
| + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \
|
| + |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*)
|
| if test "$linkmode,$pass" = "prog,link"; then
|
| compile_deplibs="$deplib $compile_deplibs"
|
| finalize_deplibs="$deplib $finalize_deplibs"
|
| else
|
| - compiler_flags="$compiler_flags $deplib"
|
| + func_append compiler_flags " $deplib"
|
| if test "$linkmode" = lib ; then
|
| case "$new_inherited_linker_flags " in
|
| *" $deplib "*) ;;
|
| - * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;;
|
| + * ) func_append new_inherited_linker_flags " $deplib" ;;
|
| esac
|
| fi
|
| fi
|
| @@ -5164,7 +6258,7 @@ func_mode_link ()
|
| if test "$linkmode" = lib ; then
|
| case "$new_inherited_linker_flags " in
|
| *" $deplib "*) ;;
|
| - * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;;
|
| + * ) func_append new_inherited_linker_flags " $deplib" ;;
|
| esac
|
| fi
|
| fi
|
| @@ -5177,7 +6271,8 @@ func_mode_link ()
|
| test "$pass" = conv && continue
|
| newdependency_libs="$deplib $newdependency_libs"
|
| func_stripname '-L' '' "$deplib"
|
| - newlib_search_path="$newlib_search_path $func_stripname_result"
|
| + func_resolve_sysroot "$func_stripname_result"
|
| + func_append newlib_search_path " $func_resolve_sysroot_result"
|
| ;;
|
| prog)
|
| if test "$pass" = conv; then
|
| @@ -5191,7 +6286,8 @@ func_mode_link ()
|
| finalize_deplibs="$deplib $finalize_deplibs"
|
| fi
|
| func_stripname '-L' '' "$deplib"
|
| - newlib_search_path="$newlib_search_path $func_stripname_result"
|
| + func_resolve_sysroot "$func_stripname_result"
|
| + func_append newlib_search_path " $func_resolve_sysroot_result"
|
| ;;
|
| *)
|
| func_warning "\`-L' is ignored for archives/objects"
|
| @@ -5202,17 +6298,21 @@ func_mode_link ()
|
| -R*)
|
| if test "$pass" = link; then
|
| func_stripname '-R' '' "$deplib"
|
| - dir=$func_stripname_result
|
| + func_resolve_sysroot "$func_stripname_result"
|
| + dir=$func_resolve_sysroot_result
|
| # Make sure the xrpath contains only unique directories.
|
| case "$xrpath " in
|
| *" $dir "*) ;;
|
| - *) xrpath="$xrpath $dir" ;;
|
| + *) func_append xrpath " $dir" ;;
|
| esac
|
| fi
|
| deplibs="$deplib $deplibs"
|
| continue
|
| ;;
|
| - *.la) lib="$deplib" ;;
|
| + *.la)
|
| + func_resolve_sysroot "$deplib"
|
| + lib=$func_resolve_sysroot_result
|
| + ;;
|
| *.$libext)
|
| if test "$pass" = conv; then
|
| deplibs="$deplib $deplibs"
|
| @@ -5230,7 +6330,7 @@ func_mode_link ()
|
| match_pattern*)
|
| set dummy $deplibs_check_method; shift
|
| match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
|
| - if eval "\$ECHO \"X$deplib\"" 2>/dev/null | $Xsed -e 10q \
|
| + if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \
|
| | $EGREP "$match_pattern_regex" > /dev/null; then
|
| valid_a_lib=yes
|
| fi
|
| @@ -5240,15 +6340,15 @@ func_mode_link ()
|
| ;;
|
| esac
|
| if test "$valid_a_lib" != yes; then
|
| - $ECHO
|
| + 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 use here."
|
| + 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 use here."
|
| else
|
| - $ECHO
|
| + echo
|
| $ECHO "*** Warning: Linking the shared library $output against the"
|
| $ECHO "*** static library $deplib is not portable!"
|
| deplibs="$deplib $deplibs"
|
| @@ -5275,11 +6375,11 @@ func_mode_link ()
|
| 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"
|
| + func_append newdlprefiles " $deplib"
|
| compile_deplibs="$deplib $compile_deplibs"
|
| finalize_deplibs="$deplib $finalize_deplibs"
|
| else
|
| - newdlfiles="$newdlfiles $deplib"
|
| + func_append newdlfiles " $deplib"
|
| fi
|
| fi
|
| continue
|
| @@ -5321,20 +6421,20 @@ func_mode_link ()
|
|
|
| # Convert "-framework foo" to "foo.ltframework"
|
| if test -n "$inherited_linker_flags"; then
|
| - tmp_inherited_linker_flags=`$ECHO "X$inherited_linker_flags" | $Xsed -e 's/-framework \([^ $]*\)/\1.ltframework/g'`
|
| + tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'`
|
| for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do
|
| case " $new_inherited_linker_flags " in
|
| *" $tmp_inherited_linker_flag "*) ;;
|
| - *) new_inherited_linker_flags="$new_inherited_linker_flags $tmp_inherited_linker_flag";;
|
| + *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";;
|
| esac
|
| done
|
| fi
|
| - dependency_libs=`$ECHO "X $dependency_libs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| + dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| if test "$linkmode,$pass" = "lib,link" ||
|
| test "$linkmode,$pass" = "prog,scan" ||
|
| { test "$linkmode" != prog && test "$linkmode" != lib; }; then
|
| - test -n "$dlopen" && dlfiles="$dlfiles $dlopen"
|
| - test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen"
|
| + test -n "$dlopen" && func_append dlfiles " $dlopen"
|
| + test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen"
|
| fi
|
|
|
| if test "$pass" = conv; then
|
| @@ -5345,17 +6445,17 @@ func_mode_link ()
|
| func_fatal_error "cannot find name of link library for \`$lib'"
|
| fi
|
| # It is a libtool convenience library, so add in its objects.
|
| - convenience="$convenience $ladir/$objdir/$old_library"
|
| - old_convenience="$old_convenience $ladir/$objdir/$old_library"
|
| + func_append convenience " $ladir/$objdir/$old_library"
|
| + func_append old_convenience " $ladir/$objdir/$old_library"
|
| tmp_libs=
|
| for deplib in $dependency_libs; do
|
| deplibs="$deplib $deplibs"
|
| - if $opt_duplicate_deps ; then
|
| + if $opt_preserve_dup_deps ; then
|
| case "$tmp_libs " in
|
| - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
|
| + *" $deplib "*) func_append specialdeplibs " $deplib" ;;
|
| esac
|
| fi
|
| - tmp_libs="$tmp_libs $deplib"
|
| + func_append tmp_libs " $deplib"
|
| done
|
| elif test "$linkmode" != prog && test "$linkmode" != lib; then
|
| func_fatal_error "\`$lib' is not a convenience library"
|
| @@ -5366,9 +6466,15 @@ func_mode_link ()
|
|
|
| # Get the name of the library we link against.
|
| linklib=
|
| - for l in $old_library $library_names; do
|
| - linklib="$l"
|
| - done
|
| + if test -n "$old_library" &&
|
| + { test "$prefer_static_libs" = yes ||
|
| + test "$prefer_static_libs,$installed" = "built,no"; }; then
|
| + linklib=$old_library
|
| + else
|
| + for l in $old_library $library_names; do
|
| + linklib="$l"
|
| + done
|
| + fi
|
| if test -z "$linklib"; then
|
| func_fatal_error "cannot find name of link library for \`$lib'"
|
| fi
|
| @@ -5385,9 +6491,9 @@ func_mode_link ()
|
| # 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"
|
| + func_append dlprefiles " $lib $dependency_libs"
|
| else
|
| - newdlfiles="$newdlfiles $lib"
|
| + func_append newdlfiles " $lib"
|
| fi
|
| continue
|
| fi # $pass = dlopen
|
| @@ -5409,14 +6515,14 @@ func_mode_link ()
|
|
|
| # Find the relevant object directory and library name.
|
| if test "X$installed" = Xyes; then
|
| - if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
|
| + if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
|
| func_warning "library \`$lib' was moved."
|
| dir="$ladir"
|
| absdir="$abs_ladir"
|
| libdir="$abs_ladir"
|
| else
|
| - dir="$libdir"
|
| - absdir="$libdir"
|
| + dir="$lt_sysroot$libdir"
|
| + absdir="$lt_sysroot$libdir"
|
| fi
|
| test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes
|
| else
|
| @@ -5424,12 +6530,12 @@ func_mode_link ()
|
| dir="$ladir"
|
| absdir="$abs_ladir"
|
| # Remove this search path later
|
| - notinst_path="$notinst_path $abs_ladir"
|
| + func_append notinst_path " $abs_ladir"
|
| else
|
| dir="$ladir/$objdir"
|
| absdir="$abs_ladir/$objdir"
|
| # Remove this search path later
|
| - notinst_path="$notinst_path $abs_ladir"
|
| + func_append notinst_path " $abs_ladir"
|
| fi
|
| fi # $installed = yes
|
| func_stripname 'lib' '.la' "$laname"
|
| @@ -5440,20 +6546,46 @@ func_mode_link ()
|
| if test -z "$libdir" && test "$linkmode" = prog; then
|
| func_fatal_error "only libraries may -dlpreopen a convenience library: \`$lib'"
|
| fi
|
| - # Prefer using a static library (so that no silly _DYNAMIC symbols
|
| - # are required to link).
|
| - if test -n "$old_library"; then
|
| - newdlprefiles="$newdlprefiles $dir/$old_library"
|
| - # Keep a list of preopened convenience libraries to check
|
| - # that they are being used correctly in the link pass.
|
| - test -z "$libdir" && \
|
| - dlpreconveniencelibs="$dlpreconveniencelibs $dir/$old_library"
|
| - # Otherwise, use the dlname, so that lt_dlopen finds it.
|
| - elif test -n "$dlname"; then
|
| - newdlprefiles="$newdlprefiles $dir/$dlname"
|
| - else
|
| - newdlprefiles="$newdlprefiles $dir/$linklib"
|
| - fi
|
| + case "$host" in
|
| + # special handling for platforms with PE-DLLs.
|
| + *cygwin* | *mingw* | *cegcc* )
|
| + # Linker will automatically link against shared library if both
|
| + # static and shared are present. Therefore, ensure we extract
|
| + # symbols from the import library if a shared library is present
|
| + # (otherwise, the dlopen module name will be incorrect). We do
|
| + # this by putting the import library name into $newdlprefiles.
|
| + # We recover the dlopen module name by 'saving' the la file
|
| + # name in a special purpose variable, and (later) extracting the
|
| + # dlname from the la file.
|
| + if test -n "$dlname"; then
|
| + func_tr_sh "$dir/$linklib"
|
| + eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname"
|
| + func_append newdlprefiles " $dir/$linklib"
|
| + else
|
| + func_append newdlprefiles " $dir/$old_library"
|
| + # Keep a list of preopened convenience libraries to check
|
| + # that they are being used correctly in the link pass.
|
| + test -z "$libdir" && \
|
| + func_append dlpreconveniencelibs " $dir/$old_library"
|
| + fi
|
| + ;;
|
| + * )
|
| + # Prefer using a static library (so that no silly _DYNAMIC symbols
|
| + # are required to link).
|
| + if test -n "$old_library"; then
|
| + func_append newdlprefiles " $dir/$old_library"
|
| + # Keep a list of preopened convenience libraries to check
|
| + # that they are being used correctly in the link pass.
|
| + test -z "$libdir" && \
|
| + func_append dlpreconveniencelibs " $dir/$old_library"
|
| + # Otherwise, use the dlname, so that lt_dlopen finds it.
|
| + elif test -n "$dlname"; then
|
| + func_append newdlprefiles " $dir/$dlname"
|
| + else
|
| + func_append newdlprefiles " $dir/$linklib"
|
| + fi
|
| + ;;
|
| + esac
|
| fi # $pass = dlpreopen
|
|
|
| if test -z "$libdir"; then
|
| @@ -5471,7 +6603,7 @@ func_mode_link ()
|
|
|
|
|
| if test "$linkmode" = prog && test "$pass" != link; then
|
| - newlib_search_path="$newlib_search_path $ladir"
|
| + func_append newlib_search_path " $ladir"
|
| deplibs="$lib $deplibs"
|
|
|
| linkalldeplibs=no
|
| @@ -5484,7 +6616,8 @@ func_mode_link ()
|
| for deplib in $dependency_libs; do
|
| case $deplib in
|
| -L*) func_stripname '-L' '' "$deplib"
|
| - newlib_search_path="$newlib_search_path $func_stripname_result"
|
| + func_resolve_sysroot "$func_stripname_result"
|
| + func_append newlib_search_path " $func_resolve_sysroot_result"
|
| ;;
|
| esac
|
| # Need to link against all dependency_libs?
|
| @@ -5495,12 +6628,12 @@ func_mode_link ()
|
| # or/and link against static libraries
|
| newdependency_libs="$deplib $newdependency_libs"
|
| fi
|
| - if $opt_duplicate_deps ; then
|
| + if $opt_preserve_dup_deps ; then
|
| case "$tmp_libs " in
|
| - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
|
| + *" $deplib "*) func_append specialdeplibs " $deplib" ;;
|
| esac
|
| fi
|
| - tmp_libs="$tmp_libs $deplib"
|
| + func_append tmp_libs " $deplib"
|
| done # for deplib
|
| continue
|
| fi # $linkmode = prog...
|
| @@ -5515,7 +6648,7 @@ func_mode_link ()
|
| # Make sure the rpath contains only unique directories.
|
| case "$temp_rpath:" in
|
| *"$absdir:"*) ;;
|
| - *) temp_rpath="$temp_rpath$absdir:" ;;
|
| + *) func_append temp_rpath "$absdir:" ;;
|
| esac
|
| fi
|
|
|
| @@ -5527,7 +6660,7 @@ func_mode_link ()
|
| *)
|
| case "$compile_rpath " in
|
| *" $absdir "*) ;;
|
| - *) compile_rpath="$compile_rpath $absdir"
|
| + *) func_append compile_rpath " $absdir" ;;
|
| esac
|
| ;;
|
| esac
|
| @@ -5536,7 +6669,7 @@ func_mode_link ()
|
| *)
|
| case "$finalize_rpath " in
|
| *" $libdir "*) ;;
|
| - *) finalize_rpath="$finalize_rpath $libdir"
|
| + *) func_append finalize_rpath " $libdir" ;;
|
| esac
|
| ;;
|
| esac
|
| @@ -5561,12 +6694,12 @@ func_mode_link ()
|
| case $host in
|
| *cygwin* | *mingw* | *cegcc*)
|
| # No point in relinking DLLs because paths are not encoded
|
| - notinst_deplibs="$notinst_deplibs $lib"
|
| + func_append notinst_deplibs " $lib"
|
| need_relink=no
|
| ;;
|
| *)
|
| if test "$installed" = no; then
|
| - notinst_deplibs="$notinst_deplibs $lib"
|
| + func_append notinst_deplibs " $lib"
|
| need_relink=yes
|
| fi
|
| ;;
|
| @@ -5583,7 +6716,7 @@ func_mode_link ()
|
| fi
|
| done
|
| if test -z "$dlopenmodule" && test "$shouldnotlink" = yes && test "$pass" = link; then
|
| - $ECHO
|
| + echo
|
| if test "$linkmode" = prog; then
|
| $ECHO "*** Warning: Linking the executable $output against the loadable module"
|
| else
|
| @@ -5601,7 +6734,7 @@ func_mode_link ()
|
| *)
|
| case "$compile_rpath " in
|
| *" $absdir "*) ;;
|
| - *) compile_rpath="$compile_rpath $absdir"
|
| + *) func_append compile_rpath " $absdir" ;;
|
| esac
|
| ;;
|
| esac
|
| @@ -5610,7 +6743,7 @@ func_mode_link ()
|
| *)
|
| case "$finalize_rpath " in
|
| *" $libdir "*) ;;
|
| - *) finalize_rpath="$finalize_rpath $libdir"
|
| + *) func_append finalize_rpath " $libdir" ;;
|
| esac
|
| ;;
|
| esac
|
| @@ -5664,7 +6797,7 @@ func_mode_link ()
|
| linklib=$newlib
|
| fi # test -n "$old_archive_from_expsyms_cmds"
|
|
|
| - if test "$linkmode" = prog || test "$mode" != relink; then
|
| + if test "$linkmode" = prog || test "$opt_mode" != relink; then
|
| add_shlibpath=
|
| add_dir=
|
| add=
|
| @@ -5686,9 +6819,9 @@ func_mode_link ()
|
| if test "X$dlopenmodule" != "X$lib"; 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"
|
| + 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
|
| @@ -5715,12 +6848,12 @@ func_mode_link ()
|
| test "$hardcode_direct_absolute" = no; then
|
| add="$dir/$linklib"
|
| elif test "$hardcode_minus_L" = yes; then
|
| - add_dir="-L$dir"
|
| + add_dir="-L$absdir"
|
| # 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"
|
| + func_append add_dir " -L$inst_prefix_dir$libdir"
|
| ;;
|
| esac
|
| fi
|
| @@ -5742,7 +6875,7 @@ func_mode_link ()
|
| if test -n "$add_shlibpath"; then
|
| case :$compile_shlibpath: in
|
| *":$add_shlibpath:"*) ;;
|
| - *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;;
|
| + *) func_append compile_shlibpath "$add_shlibpath:" ;;
|
| esac
|
| fi
|
| if test "$linkmode" = prog; then
|
| @@ -5756,13 +6889,13 @@ func_mode_link ()
|
| test "$hardcode_shlibpath_var" = yes; then
|
| case :$finalize_shlibpath: in
|
| *":$libdir:"*) ;;
|
| - *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
|
| + *) func_append finalize_shlibpath "$libdir:" ;;
|
| esac
|
| fi
|
| fi
|
| fi
|
|
|
| - if test "$linkmode" = prog || test "$mode" = relink; then
|
| + if test "$linkmode" = prog || test "$opt_mode" = relink; then
|
| add_shlibpath=
|
| add_dir=
|
| add=
|
| @@ -5776,7 +6909,7 @@ func_mode_link ()
|
| elif test "$hardcode_shlibpath_var" = yes; then
|
| case :$finalize_shlibpath: in
|
| *":$libdir:"*) ;;
|
| - *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
|
| + *) func_append finalize_shlibpath "$libdir:" ;;
|
| esac
|
| add="-l$name"
|
| elif test "$hardcode_automatic" = yes; then
|
| @@ -5793,7 +6926,7 @@ func_mode_link ()
|
| if test -n "$inst_prefix_dir"; then
|
| case $libdir in
|
| [\\/]*)
|
| - add_dir="$add_dir -L$inst_prefix_dir$libdir"
|
| + func_append add_dir " -L$inst_prefix_dir$libdir"
|
| ;;
|
| esac
|
| fi
|
| @@ -5828,21 +6961,21 @@ func_mode_link ()
|
|
|
| # Just print a warning and add the library to dependency_libs so
|
| # that the program can be linked against the static library.
|
| - $ECHO
|
| + 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 "*** 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
|
| @@ -5870,27 +7003,33 @@ func_mode_link ()
|
| temp_xrpath=$func_stripname_result
|
| case " $xrpath " in
|
| *" $temp_xrpath "*) ;;
|
| - *) xrpath="$xrpath $temp_xrpath";;
|
| + *) func_append xrpath " $temp_xrpath";;
|
| esac;;
|
| - *) temp_deplibs="$temp_deplibs $libdir";;
|
| + *) func_append temp_deplibs " $libdir";;
|
| esac
|
| done
|
| dependency_libs="$temp_deplibs"
|
| fi
|
|
|
| - newlib_search_path="$newlib_search_path $absdir"
|
| + func_append newlib_search_path " $absdir"
|
| # Link against this library
|
| test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
|
| # ... and its dependency_libs
|
| tmp_libs=
|
| for deplib in $dependency_libs; do
|
| newdependency_libs="$deplib $newdependency_libs"
|
| - if $opt_duplicate_deps ; then
|
| + case $deplib in
|
| + -L*) func_stripname '-L' '' "$deplib"
|
| + func_resolve_sysroot "$func_stripname_result";;
|
| + *) func_resolve_sysroot "$deplib" ;;
|
| + esac
|
| + if $opt_preserve_dup_deps ; then
|
| case "$tmp_libs " in
|
| - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
|
| + *" $func_resolve_sysroot_result "*)
|
| + func_append specialdeplibs " $func_resolve_sysroot_result" ;;
|
| esac
|
| fi
|
| - tmp_libs="$tmp_libs $deplib"
|
| + func_append tmp_libs " $func_resolve_sysroot_result"
|
| done
|
|
|
| if test "$link_all_deplibs" != no; then
|
| @@ -5900,8 +7039,10 @@ func_mode_link ()
|
| case $deplib in
|
| -L*) path="$deplib" ;;
|
| *.la)
|
| + func_resolve_sysroot "$deplib"
|
| + deplib=$func_resolve_sysroot_result
|
| func_dirname "$deplib" "" "."
|
| - dir="$func_dirname_result"
|
| + dir=$func_dirname_result
|
| # We need an absolute path.
|
| case $dir in
|
| [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;;
|
| @@ -5928,8 +7069,8 @@ func_mode_link ()
|
| if test -z "$darwin_install_name"; then
|
| darwin_install_name=`${OTOOL64} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
|
| fi
|
| - compiler_flags="$compiler_flags ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}"
|
| - linker_flags="$linker_flags -dylib_file ${darwin_install_name}:${depdepl}"
|
| + func_append compiler_flags " ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}"
|
| + func_append linker_flags " -dylib_file ${darwin_install_name}:${depdepl}"
|
| path=
|
| fi
|
| fi
|
| @@ -5962,7 +7103,7 @@ func_mode_link ()
|
| compile_deplibs="$new_inherited_linker_flags $compile_deplibs"
|
| finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs"
|
| else
|
| - compiler_flags="$compiler_flags "`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| + compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| fi
|
| fi
|
| dependency_libs="$newdependency_libs"
|
| @@ -5979,7 +7120,7 @@ func_mode_link ()
|
| for dir in $newlib_search_path; do
|
| case "$lib_search_path " in
|
| *" $dir "*) ;;
|
| - *) lib_search_path="$lib_search_path $dir" ;;
|
| + *) func_append lib_search_path " $dir" ;;
|
| esac
|
| done
|
| newlib_search_path=
|
| @@ -6037,10 +7178,10 @@ func_mode_link ()
|
| -L*)
|
| case " $tmp_libs " in
|
| *" $deplib "*) ;;
|
| - *) tmp_libs="$tmp_libs $deplib" ;;
|
| + *) func_append tmp_libs " $deplib" ;;
|
| esac
|
| ;;
|
| - *) tmp_libs="$tmp_libs $deplib" ;;
|
| + *) func_append tmp_libs " $deplib" ;;
|
| esac
|
| done
|
| eval $var=\"$tmp_libs\"
|
| @@ -6056,7 +7197,7 @@ func_mode_link ()
|
| ;;
|
| esac
|
| if test -n "$i" ; then
|
| - tmp_libs="$tmp_libs $i"
|
| + func_append tmp_libs " $i"
|
| fi
|
| done
|
| dependency_libs=$tmp_libs
|
| @@ -6097,7 +7238,7 @@ func_mode_link ()
|
| # Now set the variables for building old libraries.
|
| build_libtool_libs=no
|
| oldlibs="$output"
|
| - objs="$objs$old_deplibs"
|
| + func_append objs "$old_deplibs"
|
| ;;
|
|
|
| lib)
|
| @@ -6130,10 +7271,10 @@ func_mode_link ()
|
| if test "$deplibs_check_method" != pass_all; then
|
| func_fatal_error "cannot build libtool library \`$output' from non-libtool objects on this host:$objs"
|
| else
|
| - $ECHO
|
| + echo
|
| $ECHO "*** Warning: Linking the shared library $output against the non-libtool"
|
| $ECHO "*** objects $objs is not portable!"
|
| - libobjs="$libobjs $objs"
|
| + func_append libobjs " $objs"
|
| fi
|
| fi
|
|
|
| @@ -6192,13 +7333,14 @@ func_mode_link ()
|
| # which has an extra 1 added just for fun
|
| #
|
| case $version_type in
|
| + # correct linux to gnu/linux during the next big refactor
|
| darwin|linux|osf|windows|none)
|
| func_arith $number_major + $number_minor
|
| current=$func_arith_result
|
| age="$number_minor"
|
| revision="$number_revision"
|
| ;;
|
| - freebsd-aout|freebsd-elf|sunos)
|
| + freebsd-aout|freebsd-elf|qnx|sunos)
|
| current="$number_major"
|
| revision="$number_minor"
|
| age="0"
|
| @@ -6311,7 +7453,7 @@ func_mode_link ()
|
| versuffix="$major.$revision"
|
| ;;
|
|
|
| - linux)
|
| + linux) # correct to gnu/linux during the next big refactor
|
| func_arith $current - $age
|
| major=.$func_arith_result
|
| versuffix="$major.$age.$revision"
|
| @@ -6334,7 +7476,7 @@ func_mode_link ()
|
| done
|
|
|
| # Make executables depend on our current version.
|
| - verstring="$verstring:${current}.0"
|
| + func_append verstring ":${current}.0"
|
| ;;
|
|
|
| qnx)
|
| @@ -6402,10 +7544,10 @@ func_mode_link ()
|
| fi
|
|
|
| func_generate_dlsyms "$libname" "$libname" "yes"
|
| - libobjs="$libobjs $symfileobj"
|
| + func_append libobjs " $symfileobj"
|
| test "X$libobjs" = "X " && libobjs=
|
|
|
| - if test "$mode" != relink; then
|
| + if test "$opt_mode" != relink; then
|
| # Remove our outputs, but don't remove object files since they
|
| # may have been created when compiling PIC objects.
|
| removelist=
|
| @@ -6421,7 +7563,7 @@ func_mode_link ()
|
| continue
|
| fi
|
| fi
|
| - removelist="$removelist $p"
|
| + func_append removelist " $p"
|
| ;;
|
| *) ;;
|
| esac
|
| @@ -6432,27 +7574,28 @@ func_mode_link ()
|
|
|
| # Now set the variables for building old libraries.
|
| if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then
|
| - oldlibs="$oldlibs $output_objdir/$libname.$libext"
|
| + func_append oldlibs " $output_objdir/$libname.$libext"
|
|
|
| # Transform .lo files to .o files.
|
| - oldobjs="$objs "`$ECHO "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP`
|
| + oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; $lo2o" | $NL2SP`
|
| fi
|
|
|
| # Eliminate all temporary directories.
|
| #for path in $notinst_path; do
|
| - # lib_search_path=`$ECHO "X$lib_search_path " | $Xsed -e "s% $path % %g"`
|
| - # deplibs=`$ECHO "X$deplibs " | $Xsed -e "s% -L$path % %g"`
|
| - # dependency_libs=`$ECHO "X$dependency_libs " | $Xsed -e "s% -L$path % %g"`
|
| + # lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"`
|
| + # deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"`
|
| + # dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"`
|
| #done
|
|
|
| if test -n "$xrpath"; then
|
| # If the user specified any rpath flags, then add them.
|
| temp_xrpath=
|
| for libdir in $xrpath; do
|
| - temp_xrpath="$temp_xrpath -R$libdir"
|
| + func_replace_sysroot "$libdir"
|
| + func_append temp_xrpath " -R$func_replace_sysroot_result"
|
| case "$finalize_rpath " in
|
| *" $libdir "*) ;;
|
| - *) finalize_rpath="$finalize_rpath $libdir" ;;
|
| + *) func_append finalize_rpath " $libdir" ;;
|
| esac
|
| done
|
| if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then
|
| @@ -6466,7 +7609,7 @@ func_mode_link ()
|
| for lib in $old_dlfiles; do
|
| case " $dlprefiles $dlfiles " in
|
| *" $lib "*) ;;
|
| - *) dlfiles="$dlfiles $lib" ;;
|
| + *) func_append dlfiles " $lib" ;;
|
| esac
|
| done
|
|
|
| @@ -6476,19 +7619,19 @@ func_mode_link ()
|
| for lib in $old_dlprefiles; do
|
| case "$dlprefiles " in
|
| *" $lib "*) ;;
|
| - *) dlprefiles="$dlprefiles $lib" ;;
|
| + *) func_append dlprefiles " $lib" ;;
|
| esac
|
| done
|
|
|
| if test "$build_libtool_libs" = yes; then
|
| if test -n "$rpath"; then
|
| case $host in
|
| - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc*)
|
| + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*)
|
| # these systems don't actually have a c library (as such)!
|
| ;;
|
| *-*-rhapsody* | *-*-darwin1.[012])
|
| # Rhapsody C library is in the System framework
|
| - deplibs="$deplibs System.ltframework"
|
| + func_append deplibs " System.ltframework"
|
| ;;
|
| *-*-netbsd*)
|
| # Don't link with libc until the a.out ld.so is fixed.
|
| @@ -6505,7 +7648,7 @@ func_mode_link ()
|
| *)
|
| # Add libc to deplibs on all other systems if necessary.
|
| if test "$build_libtool_need_lc" = "yes"; then
|
| - deplibs="$deplibs -lc"
|
| + func_append deplibs " -lc"
|
| fi
|
| ;;
|
| esac
|
| @@ -6554,7 +7697,7 @@ EOF
|
| if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
| case " $predeps $postdeps " in
|
| *" $i "*)
|
| - newdeplibs="$newdeplibs $i"
|
| + func_append newdeplibs " $i"
|
| i=""
|
| ;;
|
| esac
|
| @@ -6565,21 +7708,21 @@ EOF
|
| set dummy $deplib_matches; shift
|
| deplib_match=$1
|
| if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
|
| - newdeplibs="$newdeplibs $i"
|
| + func_append newdeplibs " $i"
|
| else
|
| droppeddeps=yes
|
| - $ECHO
|
| + 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."
|
| + 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
|
| ;;
|
| *)
|
| - newdeplibs="$newdeplibs $i"
|
| + func_append newdeplibs " $i"
|
| ;;
|
| esac
|
| done
|
| @@ -6597,7 +7740,7 @@ EOF
|
| if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
| case " $predeps $postdeps " in
|
| *" $i "*)
|
| - newdeplibs="$newdeplibs $i"
|
| + func_append newdeplibs " $i"
|
| i=""
|
| ;;
|
| esac
|
| @@ -6608,29 +7751,29 @@ EOF
|
| set dummy $deplib_matches; shift
|
| deplib_match=$1
|
| if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
|
| - newdeplibs="$newdeplibs $i"
|
| + func_append newdeplibs " $i"
|
| else
|
| droppeddeps=yes
|
| - $ECHO
|
| + 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."
|
| + 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
|
| $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 "*** 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
|
| ;;
|
| *)
|
| - newdeplibs="$newdeplibs $i"
|
| + func_append newdeplibs " $i"
|
| ;;
|
| esac
|
| done
|
| @@ -6647,15 +7790,27 @@ EOF
|
| if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
| case " $predeps $postdeps " in
|
| *" $a_deplib "*)
|
| - newdeplibs="$newdeplibs $a_deplib"
|
| + func_append newdeplibs " $a_deplib"
|
| a_deplib=""
|
| ;;
|
| esac
|
| fi
|
| if test -n "$a_deplib" ; then
|
| libname=`eval "\\$ECHO \"$libname_spec\""`
|
| + if test -n "$file_magic_glob"; then
|
| + libnameglob=`func_echo_all "$libname" | $SED -e $file_magic_glob`
|
| + else
|
| + libnameglob=$libname
|
| + fi
|
| + test "$want_nocaseglob" = yes && nocaseglob=`shopt -p nocaseglob`
|
| for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
|
| - potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
|
| + if test "$want_nocaseglob" = yes; then
|
| + shopt -s nocaseglob
|
| + potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null`
|
| + $nocaseglob
|
| + else
|
| + potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null`
|
| + fi
|
| for potent_lib in $potential_libs; do
|
| # Follow soft links.
|
| if ls -lLd "$potent_lib" 2>/dev/null |
|
| @@ -6672,13 +7827,13 @@ EOF
|
| potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'`
|
| case $potliblink in
|
| [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";;
|
| - *) potlib=`$ECHO "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";;
|
| + *) potlib=`$ECHO "$potlib" | $SED 's,[^/]*$,,'`"$potliblink";;
|
| esac
|
| done
|
| if eval $file_magic_cmd \"\$potlib\" 2>/dev/null |
|
| $SED -e 10q |
|
| $EGREP "$file_magic_regex" > /dev/null; then
|
| - newdeplibs="$newdeplibs $a_deplib"
|
| + func_append newdeplibs " $a_deplib"
|
| a_deplib=""
|
| break 2
|
| fi
|
| @@ -6687,12 +7842,12 @@ EOF
|
| fi
|
| if test -n "$a_deplib" ; then
|
| droppeddeps=yes
|
| - $ECHO
|
| + 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 "*** 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)"
|
| else
|
| @@ -6703,7 +7858,7 @@ EOF
|
| ;;
|
| *)
|
| # Add a -L argument.
|
| - newdeplibs="$newdeplibs $a_deplib"
|
| + func_append newdeplibs " $a_deplib"
|
| ;;
|
| esac
|
| done # Gone through all deplibs.
|
| @@ -6719,7 +7874,7 @@ EOF
|
| if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
|
| case " $predeps $postdeps " in
|
| *" $a_deplib "*)
|
| - newdeplibs="$newdeplibs $a_deplib"
|
| + func_append newdeplibs " $a_deplib"
|
| a_deplib=""
|
| ;;
|
| esac
|
| @@ -6730,9 +7885,9 @@ EOF
|
| 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 \"X$potent_lib\"" 2>/dev/null | $Xsed -e 10q | \
|
| + if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \
|
| $EGREP "$match_pattern_regex" > /dev/null; then
|
| - newdeplibs="$newdeplibs $a_deplib"
|
| + func_append newdeplibs " $a_deplib"
|
| a_deplib=""
|
| break 2
|
| fi
|
| @@ -6741,12 +7896,12 @@ EOF
|
| fi
|
| if test -n "$a_deplib" ; then
|
| droppeddeps=yes
|
| - $ECHO
|
| + 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 "*** 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)"
|
| else
|
| @@ -6757,32 +7912,32 @@ EOF
|
| ;;
|
| *)
|
| # Add a -L argument.
|
| - newdeplibs="$newdeplibs $a_deplib"
|
| + func_append newdeplibs " $a_deplib"
|
| ;;
|
| esac
|
| done # Gone through all deplibs.
|
| ;;
|
| none | unknown | *)
|
| newdeplibs=""
|
| - tmp_deplibs=`$ECHO "X $deplibs" | $Xsed \
|
| - -e 's/ -lc$//' -e 's/ -[LR][^ ]*//g'`
|
| + tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; 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" | $Xsed -e "s,$i,,"`
|
| + tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s,$i,,"`
|
| done
|
| fi
|
| - if $ECHO "X $tmp_deplibs" | $Xsed -e 's/[ ]//g' |
|
| - $GREP . >/dev/null; then
|
| - $ECHO
|
| + case $tmp_deplibs in
|
| + *[!\ \ ]*)
|
| + 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
|
| + ;;
|
| + esac
|
| ;;
|
| esac
|
| versuffix=$versuffix_save
|
| @@ -6794,23 +7949,23 @@ EOF
|
| case $host in
|
| *-*-rhapsody* | *-*-darwin1.[012])
|
| # On Rhapsody replace the C library with the System framework
|
| - newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's/ -lc / System.ltframework /'`
|
| + newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'`
|
| ;;
|
| esac
|
|
|
| if test "$droppeddeps" = yes; then
|
| if test "$module" = yes; then
|
| - $ECHO
|
| - $ECHO "*** Warning: libtool could not satisfy all declared inter-library"
|
| + 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 "*** 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"
|
| @@ -6820,16 +7975,16 @@ EOF
|
| 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."
|
| + 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
|
| + 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
|
| @@ -6846,9 +8001,9 @@ EOF
|
| # Time to change all our "foo.ltframework" stuff back to "-framework foo"
|
| case $host in
|
| *-*-darwin*)
|
| - newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| - new_inherited_linker_flags=`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| - deplibs=`$ECHO "X $deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| + newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| + new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| + deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| ;;
|
| esac
|
|
|
| @@ -6861,7 +8016,7 @@ EOF
|
| *)
|
| case " $deplibs " in
|
| *" -L$path/$objdir "*)
|
| - new_libs="$new_libs -L$path/$objdir" ;;
|
| + func_append new_libs " -L$path/$objdir" ;;
|
| esac
|
| ;;
|
| esac
|
| @@ -6871,10 +8026,10 @@ EOF
|
| -L*)
|
| case " $new_libs " in
|
| *" $deplib "*) ;;
|
| - *) new_libs="$new_libs $deplib" ;;
|
| + *) func_append new_libs " $deplib" ;;
|
| esac
|
| ;;
|
| - *) new_libs="$new_libs $deplib" ;;
|
| + *) func_append new_libs " $deplib" ;;
|
| esac
|
| done
|
| deplibs="$new_libs"
|
| @@ -6886,15 +8041,22 @@ EOF
|
|
|
| # Test again, we may have decided not to build it any more
|
| if test "$build_libtool_libs" = yes; then
|
| + # Remove ${wl} instances when linking with ld.
|
| + # FIXME: should test the right _cmds variable.
|
| + case $archive_cmds in
|
| + *\$LD\ *) wl= ;;
|
| + esac
|
| if test "$hardcode_into_libs" = yes; then
|
| # Hardcode the library paths
|
| hardcode_libdirs=
|
| dep_rpath=
|
| rpath="$finalize_rpath"
|
| - test "$mode" != relink && rpath="$compile_rpath$rpath"
|
| + test "$opt_mode" != relink && rpath="$compile_rpath$rpath"
|
| for libdir in $rpath; do
|
| if test -n "$hardcode_libdir_flag_spec"; then
|
| if test -n "$hardcode_libdir_separator"; then
|
| + func_replace_sysroot "$libdir"
|
| + libdir=$func_replace_sysroot_result
|
| if test -z "$hardcode_libdirs"; then
|
| hardcode_libdirs="$libdir"
|
| else
|
| @@ -6903,18 +8065,18 @@ EOF
|
| *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
|
| ;;
|
| *)
|
| - hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
|
| + func_append hardcode_libdirs "$hardcode_libdir_separator$libdir"
|
| ;;
|
| esac
|
| fi
|
| else
|
| eval flag=\"$hardcode_libdir_flag_spec\"
|
| - dep_rpath="$dep_rpath $flag"
|
| + func_append dep_rpath " $flag"
|
| fi
|
| elif test -n "$runpath_var"; then
|
| case "$perm_rpath " in
|
| *" $libdir "*) ;;
|
| - *) perm_rpath="$perm_rpath $libdir" ;;
|
| + *) func_append perm_rpath " $libdir" ;;
|
| esac
|
| fi
|
| done
|
| @@ -6922,17 +8084,13 @@ EOF
|
| if test -n "$hardcode_libdir_separator" &&
|
| test -n "$hardcode_libdirs"; then
|
| libdir="$hardcode_libdirs"
|
| - 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
|
| + eval "dep_rpath=\"$hardcode_libdir_flag_spec\""
|
| fi
|
| if test -n "$runpath_var" && test -n "$perm_rpath"; then
|
| # We should set the runpath_var.
|
| rpath=
|
| for dir in $perm_rpath; do
|
| - rpath="$rpath$dir:"
|
| + func_append rpath "$dir:"
|
| done
|
| eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var"
|
| fi
|
| @@ -6940,7 +8098,7 @@ EOF
|
| fi
|
|
|
| shlibpath="$finalize_shlibpath"
|
| - test "$mode" != relink && shlibpath="$compile_shlibpath$shlibpath"
|
| + test "$opt_mode" != relink && shlibpath="$compile_shlibpath$shlibpath"
|
| if test -n "$shlibpath"; then
|
| eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var"
|
| fi
|
| @@ -6966,18 +8124,18 @@ EOF
|
| linknames=
|
| for link
|
| do
|
| - linknames="$linknames $link"
|
| + func_append linknames " $link"
|
| done
|
|
|
| # Use standard objects if they are pic
|
| - test -z "$pic_flag" && libobjs=`$ECHO "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
|
| + test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP`
|
| test "X$libobjs" = "X " && libobjs=
|
|
|
| delfiles=
|
| if test -n "$export_symbols" && test -n "$include_expsyms"; then
|
| $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp"
|
| export_symbols="$output_objdir/$libname.uexp"
|
| - delfiles="$delfiles $export_symbols"
|
| + func_append delfiles " $export_symbols"
|
| fi
|
|
|
| orig_export_symbols=
|
| @@ -7008,13 +8166,45 @@ EOF
|
| $opt_dry_run || $RM $export_symbols
|
| cmds=$export_symbols_cmds
|
| save_ifs="$IFS"; IFS='~'
|
| - for cmd in $cmds; do
|
| + for cmd1 in $cmds; do
|
| IFS="$save_ifs"
|
| - eval cmd=\"$cmd\"
|
| - func_len " $cmd"
|
| - len=$func_len_result
|
| - if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
|
| + # Take the normal branch if the nm_file_list_spec branch
|
| + # doesn't work or if tool conversion is not needed.
|
| + case $nm_file_list_spec~$to_tool_file_cmd in
|
| + *~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*)
|
| + try_normal_branch=yes
|
| + eval cmd=\"$cmd1\"
|
| + func_len " $cmd"
|
| + len=$func_len_result
|
| + ;;
|
| + *)
|
| + try_normal_branch=no
|
| + ;;
|
| + esac
|
| + if test "$try_normal_branch" = yes \
|
| + && { test "$len" -lt "$max_cmd_len" \
|
| + || test "$max_cmd_len" -le -1; }
|
| + then
|
| + func_show_eval "$cmd" 'exit $?'
|
| + skipped_export=false
|
| + elif test -n "$nm_file_list_spec"; then
|
| + func_basename "$output"
|
| + output_la=$func_basename_result
|
| + save_libobjs=$libobjs
|
| + save_output=$output
|
| + output=${output_objdir}/${output_la}.nm
|
| + func_to_tool_file "$output"
|
| + libobjs=$nm_file_list_spec$func_to_tool_file_result
|
| + func_append delfiles " $output"
|
| + func_verbose "creating $NM input file list: $output"
|
| + for obj in $save_libobjs; do
|
| + func_to_tool_file "$obj"
|
| + $ECHO "$func_to_tool_file_result"
|
| + done > "$output"
|
| + eval cmd=\"$cmd1\"
|
| func_show_eval "$cmd" 'exit $?'
|
| + output=$save_output
|
| + libobjs=$save_libobjs
|
| skipped_export=false
|
| else
|
| # The command line is too long to execute in one step.
|
| @@ -7036,7 +8226,7 @@ EOF
|
| if test -n "$export_symbols" && test -n "$include_expsyms"; then
|
| tmp_export_symbols="$export_symbols"
|
| test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
|
| - $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"'
|
| + $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
|
| fi
|
|
|
| if test "X$skipped_export" != "X:" && test -n "$orig_export_symbols"; then
|
| @@ -7048,7 +8238,7 @@ EOF
|
| # global variables. join(1) would be nice here, but unfortunately
|
| # isn't a blessed tool.
|
| $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter
|
| - delfiles="$delfiles $export_symbols $output_objdir/$libname.filter"
|
| + func_append delfiles " $export_symbols $output_objdir/$libname.filter"
|
| export_symbols=$output_objdir/$libname.def
|
| $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
|
| fi
|
| @@ -7058,7 +8248,7 @@ EOF
|
| case " $convenience " in
|
| *" $test_deplib "*) ;;
|
| *)
|
| - tmp_deplibs="$tmp_deplibs $test_deplib"
|
| + func_append tmp_deplibs " $test_deplib"
|
| ;;
|
| esac
|
| done
|
| @@ -7078,21 +8268,21 @@ EOF
|
| test "X$libobjs" = "X " && libobjs=
|
| else
|
| gentop="$output_objdir/${outputname}x"
|
| - generated="$generated $gentop"
|
| + func_append generated " $gentop"
|
|
|
| func_extract_archives $gentop $convenience
|
| - libobjs="$libobjs $func_extract_archives_result"
|
| + func_append libobjs " $func_extract_archives_result"
|
| test "X$libobjs" = "X " && libobjs=
|
| fi
|
| fi
|
|
|
| if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then
|
| eval flag=\"$thread_safe_flag_spec\"
|
| - linker_flags="$linker_flags $flag"
|
| + func_append linker_flags " $flag"
|
| fi
|
|
|
| # Make a backup of the uninstalled library when relinking
|
| - if test "$mode" = relink; then
|
| + if test "$opt_mode" = relink; then
|
| $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $?
|
| fi
|
|
|
| @@ -7137,7 +8327,8 @@ EOF
|
| save_libobjs=$libobjs
|
| fi
|
| save_output=$output
|
| - output_la=`$ECHO "X$output" | $Xsed -e "$basename"`
|
| + func_basename "$output"
|
| + output_la=$func_basename_result
|
|
|
| # Clear the reloadable object creation command queue and
|
| # initialize k to one.
|
| @@ -7150,13 +8341,16 @@ EOF
|
| if test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "$with_gnu_ld" = yes; then
|
| output=${output_objdir}/${output_la}.lnkscript
|
| func_verbose "creating GNU ld script: $output"
|
| - $ECHO 'INPUT (' > $output
|
| + echo 'INPUT (' > $output
|
| for obj in $save_libobjs
|
| do
|
| - $ECHO "$obj" >> $output
|
| + func_to_tool_file "$obj"
|
| + $ECHO "$func_to_tool_file_result" >> $output
|
| done
|
| - $ECHO ')' >> $output
|
| - delfiles="$delfiles $output"
|
| + echo ')' >> $output
|
| + func_append delfiles " $output"
|
| + func_to_tool_file "$output"
|
| + output=$func_to_tool_file_result
|
| elif test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "X$file_list_spec" != X; then
|
| output=${output_objdir}/${output_la}.lnk
|
| func_verbose "creating linker input file list: $output"
|
| @@ -7170,10 +8364,12 @@ EOF
|
| fi
|
| for obj
|
| do
|
| - $ECHO "$obj" >> $output
|
| + func_to_tool_file "$obj"
|
| + $ECHO "$func_to_tool_file_result" >> $output
|
| done
|
| - delfiles="$delfiles $output"
|
| - output=$firstobj\"$file_list_spec$output\"
|
| + func_append delfiles " $output"
|
| + func_to_tool_file "$output"
|
| + output=$firstobj\"$file_list_spec$func_to_tool_file_result\"
|
| else
|
| if test -n "$save_libobjs"; then
|
| func_verbose "creating reloadable object files..."
|
| @@ -7197,17 +8393,19 @@ EOF
|
| # 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\"
|
| + reload_objs=$objlist
|
| + eval concat_cmds=\"$reload_cmds\"
|
| else
|
| # All subsequent reloadable object files will link in
|
| # the last one created.
|
| - eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj~\$RM $last_robj\"
|
| + reload_objs="$objlist $last_robj"
|
| + eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\"
|
| fi
|
| last_robj=$output_objdir/$output_la-${k}.$objext
|
| func_arith $k + 1
|
| k=$func_arith_result
|
| output=$output_objdir/$output_la-${k}.$objext
|
| - objlist=$obj
|
| + objlist=" $obj"
|
| func_len " $last_robj"
|
| func_arith $len0 + $func_len_result
|
| len=$func_arith_result
|
| @@ -7217,11 +8415,12 @@ EOF
|
| # 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\"
|
| + reload_objs="$objlist $last_robj"
|
| + eval concat_cmds=\"\${concat_cmds}$reload_cmds\"
|
| if test -n "$last_robj"; then
|
| eval concat_cmds=\"\${concat_cmds}~\$RM $last_robj\"
|
| fi
|
| - delfiles="$delfiles $output"
|
| + func_append delfiles " $output"
|
|
|
| else
|
| output=
|
| @@ -7255,7 +8454,7 @@ EOF
|
| lt_exit=$?
|
|
|
| # Restore the uninstalled library and exit
|
| - if test "$mode" = relink; then
|
| + if test "$opt_mode" = relink; then
|
| ( cd "$output_objdir" && \
|
| $RM "${realname}T" && \
|
| $MV "${realname}U" "$realname" )
|
| @@ -7276,7 +8475,7 @@ EOF
|
| if test -n "$export_symbols" && test -n "$include_expsyms"; then
|
| tmp_export_symbols="$export_symbols"
|
| test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
|
| - $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"'
|
| + $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
|
| fi
|
|
|
| if test -n "$orig_export_symbols"; then
|
| @@ -7288,7 +8487,7 @@ EOF
|
| # global variables. join(1) would be nice here, but unfortunately
|
| # isn't a blessed tool.
|
| $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter
|
| - delfiles="$delfiles $export_symbols $output_objdir/$libname.filter"
|
| + func_append delfiles " $export_symbols $output_objdir/$libname.filter"
|
| export_symbols=$output_objdir/$libname.def
|
| $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
|
| fi
|
| @@ -7329,10 +8528,10 @@ EOF
|
| # Add any objects from preloaded convenience libraries
|
| if test -n "$dlprefiles"; then
|
| gentop="$output_objdir/${outputname}x"
|
| - generated="$generated $gentop"
|
| + func_append generated " $gentop"
|
|
|
| func_extract_archives $gentop $dlprefiles
|
| - libobjs="$libobjs $func_extract_archives_result"
|
| + func_append libobjs " $func_extract_archives_result"
|
| test "X$libobjs" = "X " && libobjs=
|
| fi
|
|
|
| @@ -7348,7 +8547,7 @@ EOF
|
| lt_exit=$?
|
|
|
| # Restore the uninstalled library and exit
|
| - if test "$mode" = relink; then
|
| + if test "$opt_mode" = relink; then
|
| ( cd "$output_objdir" && \
|
| $RM "${realname}T" && \
|
| $MV "${realname}U" "$realname" )
|
| @@ -7360,7 +8559,7 @@ EOF
|
| IFS="$save_ifs"
|
|
|
| # Restore the uninstalled library and exit
|
| - if test "$mode" = relink; then
|
| + if test "$opt_mode" = relink; then
|
| $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $?
|
|
|
| if test -n "$convenience"; then
|
| @@ -7441,18 +8640,21 @@ EOF
|
| if test -n "$convenience"; then
|
| if test -n "$whole_archive_flag_spec"; then
|
| eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\"
|
| - reload_conv_objs=$reload_objs\ `$ECHO "X$tmp_whole_archive_flags" | $Xsed -e 's|,| |g'`
|
| + reload_conv_objs=$reload_objs\ `$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'`
|
| else
|
| gentop="$output_objdir/${obj}x"
|
| - generated="$generated $gentop"
|
| + func_append generated " $gentop"
|
|
|
| func_extract_archives $gentop $convenience
|
| reload_conv_objs="$reload_objs $func_extract_archives_result"
|
| fi
|
| fi
|
|
|
| + # If we're not building shared, we need to use non_pic_objs
|
| + test "$build_libtool_libs" != yes && libobjs="$non_pic_objects"
|
| +
|
| # Create the old-style object.
|
| - 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
|
| + reload_objs="$objs$old_deplibs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; /\.lib$/d; $lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test
|
|
|
| output="$obj"
|
| func_execute_cmds "$reload_cmds" 'exit $?'
|
| @@ -7512,8 +8714,8 @@ EOF
|
| case $host in
|
| *-*-rhapsody* | *-*-darwin1.[012])
|
| # On Rhapsody replace the C library is the System framework
|
| - compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'`
|
| - finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'`
|
| + compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'`
|
| + finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'`
|
| ;;
|
| esac
|
|
|
| @@ -7524,14 +8726,14 @@ EOF
|
| if test "$tagname" = CXX ; then
|
| case ${MACOSX_DEPLOYMENT_TARGET-10.0} in
|
| 10.[0123])
|
| - compile_command="$compile_command ${wl}-bind_at_load"
|
| - finalize_command="$finalize_command ${wl}-bind_at_load"
|
| + func_append compile_command " ${wl}-bind_at_load"
|
| + func_append finalize_command " ${wl}-bind_at_load"
|
| ;;
|
| esac
|
| fi
|
| # Time to change all our "foo.ltframework" stuff back to "-framework foo"
|
| - compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| - finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| + compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| + finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
|
| ;;
|
| esac
|
|
|
| @@ -7545,7 +8747,7 @@ EOF
|
| *)
|
| case " $compile_deplibs " in
|
| *" -L$path/$objdir "*)
|
| - new_libs="$new_libs -L$path/$objdir" ;;
|
| + func_append new_libs " -L$path/$objdir" ;;
|
| esac
|
| ;;
|
| esac
|
| @@ -7555,17 +8757,17 @@ EOF
|
| -L*)
|
| case " $new_libs " in
|
| *" $deplib "*) ;;
|
| - *) new_libs="$new_libs $deplib" ;;
|
| + *) func_append new_libs " $deplib" ;;
|
| esac
|
| ;;
|
| - *) new_libs="$new_libs $deplib" ;;
|
| + *) func_append new_libs " $deplib" ;;
|
| esac
|
| done
|
| compile_deplibs="$new_libs"
|
|
|
|
|
| - compile_command="$compile_command $compile_deplibs"
|
| - finalize_command="$finalize_command $finalize_deplibs"
|
| + func_append compile_command " $compile_deplibs"
|
| + func_append finalize_command " $finalize_deplibs"
|
|
|
| if test -n "$rpath$xrpath"; then
|
| # If the user specified any rpath flags, then add them.
|
| @@ -7573,7 +8775,7 @@ EOF
|
| # This is the magic to use -rpath.
|
| case "$finalize_rpath " in
|
| *" $libdir "*) ;;
|
| - *) finalize_rpath="$finalize_rpath $libdir" ;;
|
| + *) func_append finalize_rpath " $libdir" ;;
|
| esac
|
| done
|
| fi
|
| @@ -7592,18 +8794,18 @@ EOF
|
| *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
|
| ;;
|
| *)
|
| - hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
|
| + func_append hardcode_libdirs "$hardcode_libdir_separator$libdir"
|
| ;;
|
| esac
|
| fi
|
| else
|
| eval flag=\"$hardcode_libdir_flag_spec\"
|
| - rpath="$rpath $flag"
|
| + func_append rpath " $flag"
|
| fi
|
| elif test -n "$runpath_var"; then
|
| case "$perm_rpath " in
|
| *" $libdir "*) ;;
|
| - *) perm_rpath="$perm_rpath $libdir" ;;
|
| + *) func_append perm_rpath " $libdir" ;;
|
| esac
|
| fi
|
| case $host in
|
| @@ -7612,12 +8814,12 @@ EOF
|
| case :$dllsearchpath: in
|
| *":$libdir:"*) ;;
|
| ::) dllsearchpath=$libdir;;
|
| - *) dllsearchpath="$dllsearchpath:$libdir";;
|
| + *) func_append dllsearchpath ":$libdir";;
|
| esac
|
| case :$dllsearchpath: in
|
| *":$testbindir:"*) ;;
|
| ::) dllsearchpath=$testbindir;;
|
| - *) dllsearchpath="$dllsearchpath:$testbindir";;
|
| + *) func_append dllsearchpath ":$testbindir";;
|
| esac
|
| ;;
|
| esac
|
| @@ -7643,18 +8845,18 @@ EOF
|
| *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
|
| ;;
|
| *)
|
| - hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
|
| + func_append hardcode_libdirs "$hardcode_libdir_separator$libdir"
|
| ;;
|
| esac
|
| fi
|
| else
|
| eval flag=\"$hardcode_libdir_flag_spec\"
|
| - rpath="$rpath $flag"
|
| + func_append rpath " $flag"
|
| fi
|
| elif test -n "$runpath_var"; then
|
| case "$finalize_perm_rpath " in
|
| *" $libdir "*) ;;
|
| - *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;;
|
| + *) func_append finalize_perm_rpath " $libdir" ;;
|
| esac
|
| fi
|
| done
|
| @@ -7668,8 +8870,8 @@ EOF
|
|
|
| if test -n "$libobjs" && test "$build_old_libs" = yes; then
|
| # Transform all the library objects into standard objects.
|
| - compile_command=`$ECHO "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
|
| - finalize_command=`$ECHO "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
|
| + compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
|
| + finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
|
| fi
|
|
|
| func_generate_dlsyms "$outputname" "@PROGRAM@" "no"
|
| @@ -7681,15 +8883,15 @@ EOF
|
|
|
| wrappers_required=yes
|
| case $host in
|
| + *cegcc* | *mingw32ce*)
|
| + # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway.
|
| + wrappers_required=no
|
| + ;;
|
| *cygwin* | *mingw* )
|
| if test "$build_libtool_libs" != yes; then
|
| wrappers_required=no
|
| fi
|
| ;;
|
| - *cegcc)
|
| - # Disable wrappers for cegcc, we are cross compiling anyway.
|
| - wrappers_required=no
|
| - ;;
|
| *)
|
| if test "$need_relink" = no || test "$build_libtool_libs" != yes; then
|
| wrappers_required=no
|
| @@ -7698,13 +8900,19 @@ EOF
|
| esac
|
| if test "$wrappers_required" = no; then
|
| # Replace the output file specification.
|
| - compile_command=`$ECHO "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
|
| + compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
|
| link_command="$compile_command$compile_rpath"
|
|
|
| # We have no uninstalled library dependencies, so finalize right now.
|
| exit_status=0
|
| func_show_eval "$link_command" 'exit_status=$?'
|
|
|
| + if test -n "$postlink_cmds"; then
|
| + func_to_tool_file "$output"
|
| + postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'`
|
| + func_execute_cmds "$postlink_cmds" 'exit $?'
|
| + fi
|
| +
|
| # Delete the generated files.
|
| if test -f "$output_objdir/${outputname}S.${objext}"; then
|
| func_show_eval '$RM "$output_objdir/${outputname}S.${objext}"'
|
| @@ -7727,7 +8935,7 @@ EOF
|
| # We should set the runpath_var.
|
| rpath=
|
| for dir in $perm_rpath; do
|
| - rpath="$rpath$dir:"
|
| + func_append rpath "$dir:"
|
| done
|
| compile_var="$runpath_var=\"$rpath\$$runpath_var\" "
|
| fi
|
| @@ -7735,7 +8943,7 @@ EOF
|
| # We should set the runpath_var.
|
| rpath=
|
| for dir in $finalize_perm_rpath; do
|
| - rpath="$rpath$dir:"
|
| + func_append rpath "$dir:"
|
| done
|
| finalize_var="$runpath_var=\"$rpath\$$runpath_var\" "
|
| fi
|
| @@ -7745,11 +8953,18 @@ EOF
|
| # We don't need to create a wrapper script.
|
| link_command="$compile_var$compile_command$compile_rpath"
|
| # Replace the output file specification.
|
| - link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
|
| + link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
|
| # Delete the old output file.
|
| $opt_dry_run || $RM $output
|
| # Link the executable and exit
|
| func_show_eval "$link_command" 'exit $?'
|
| +
|
| + if test -n "$postlink_cmds"; then
|
| + func_to_tool_file "$output"
|
| + postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'`
|
| + func_execute_cmds "$postlink_cmds" 'exit $?'
|
| + fi
|
| +
|
| exit $EXIT_SUCCESS
|
| fi
|
|
|
| @@ -7764,7 +8979,7 @@ EOF
|
| if test "$fast_install" != no; then
|
| link_command="$finalize_var$compile_command$finalize_rpath"
|
| if test "$fast_install" = yes; then
|
| - relink_command=`$ECHO "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'`
|
| + relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'`
|
| else
|
| # fast_install is set to needless
|
| relink_command=
|
| @@ -7776,13 +8991,19 @@ EOF
|
| fi
|
|
|
| # Replace the output file specification.
|
| - link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
|
| + link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
|
|
|
| # Delete the old output files.
|
| $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname
|
|
|
| func_show_eval "$link_command" 'exit $?'
|
|
|
| + if test -n "$postlink_cmds"; then
|
| + func_to_tool_file "$output_objdir/$outputname"
|
| + postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'`
|
| + func_execute_cmds "$postlink_cmds" 'exit $?'
|
| + fi
|
| +
|
| # Now create the wrapper script.
|
| func_verbose "creating $output"
|
|
|
| @@ -7800,18 +9021,7 @@ EOF
|
| fi
|
| done
|
| relink_command="(cd `pwd`; $relink_command)"
|
| - relink_command=`$ECHO "X$relink_command" | $Xsed -e "$sed_quote_subst"`
|
| - fi
|
| -
|
| - # Quote $ECHO for shipping.
|
| - 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
|
| - qecho=`$ECHO "X$ECHO" | $Xsed -e "$sed_quote_subst"`
|
| + relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"`
|
| fi
|
|
|
| # Only actually do things if not in dry run mode.
|
| @@ -7891,7 +9101,7 @@ EOF
|
| else
|
| oldobjs="$old_deplibs $non_pic_objects"
|
| if test "$preload" = yes && test -f "$symfileobj"; then
|
| - oldobjs="$oldobjs $symfileobj"
|
| + func_append oldobjs " $symfileobj"
|
| fi
|
| fi
|
| addlibs="$old_convenience"
|
| @@ -7899,10 +9109,10 @@ EOF
|
|
|
| if test -n "$addlibs"; then
|
| gentop="$output_objdir/${outputname}x"
|
| - generated="$generated $gentop"
|
| + func_append generated " $gentop"
|
|
|
| func_extract_archives $gentop $addlibs
|
| - oldobjs="$oldobjs $func_extract_archives_result"
|
| + func_append oldobjs " $func_extract_archives_result"
|
| fi
|
|
|
| # Do each command in the archive commands.
|
| @@ -7913,10 +9123,10 @@ EOF
|
| # Add any objects from preloaded convenience libraries
|
| if test -n "$dlprefiles"; then
|
| gentop="$output_objdir/${outputname}x"
|
| - generated="$generated $gentop"
|
| + func_append generated " $gentop"
|
|
|
| func_extract_archives $gentop $dlprefiles
|
| - oldobjs="$oldobjs $func_extract_archives_result"
|
| + func_append oldobjs " $func_extract_archives_result"
|
| fi
|
|
|
| # POSIX demands no paths to be encoded in archives. We have
|
| @@ -7932,9 +9142,9 @@ EOF
|
| done | sort | sort -uc >/dev/null 2>&1); then
|
| :
|
| else
|
| - $ECHO "copying selected object files to avoid basename conflicts..."
|
| + echo "copying selected object files to avoid basename conflicts..."
|
| gentop="$output_objdir/${outputname}x"
|
| - generated="$generated $gentop"
|
| + func_append generated " $gentop"
|
| func_mkdir_p "$gentop"
|
| save_oldobjs=$oldobjs
|
| oldobjs=
|
| @@ -7958,18 +9168,30 @@ EOF
|
| esac
|
| done
|
| func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj"
|
| - oldobjs="$oldobjs $gentop/$newobj"
|
| + func_append oldobjs " $gentop/$newobj"
|
| ;;
|
| - *) oldobjs="$oldobjs $obj" ;;
|
| + *) func_append oldobjs " $obj" ;;
|
| esac
|
| done
|
| fi
|
| + func_to_tool_file "$oldlib" func_convert_file_msys_to_w32
|
| + tool_oldlib=$func_to_tool_file_result
|
| eval cmds=\"$old_archive_cmds\"
|
|
|
| func_len " $cmds"
|
| len=$func_len_result
|
| if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
|
| cmds=$old_archive_cmds
|
| + elif test -n "$archiver_list_spec"; then
|
| + func_verbose "using command file archive linking..."
|
| + for obj in $oldobjs
|
| + do
|
| + func_to_tool_file "$obj"
|
| + $ECHO "$func_to_tool_file_result"
|
| + done > $output_objdir/$libname.libcmd
|
| + func_to_tool_file "$output_objdir/$libname.libcmd"
|
| + oldobjs=" $archiver_list_spec$func_to_tool_file_result"
|
| + cmds=$old_archive_cmds
|
| else
|
| # the command line is too long to link in one step, link in parts
|
| func_verbose "using piecewise archive linking..."
|
| @@ -8043,7 +9265,7 @@ EOF
|
| done
|
| # Quote the link command for shipping.
|
| 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"`
|
| + relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"`
|
| if test "$hardcode_automatic" = yes ; then
|
| relink_command=
|
| fi
|
| @@ -8063,12 +9285,23 @@ EOF
|
| *.la)
|
| func_basename "$deplib"
|
| name="$func_basename_result"
|
| - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
|
| + func_resolve_sysroot "$deplib"
|
| + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result`
|
| test -z "$libdir" && \
|
| func_fatal_error "\`$deplib' is not a valid libtool archive"
|
| - newdependency_libs="$newdependency_libs $libdir/$name"
|
| + func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name"
|
| + ;;
|
| + -L*)
|
| + func_stripname -L '' "$deplib"
|
| + func_replace_sysroot "$func_stripname_result"
|
| + func_append newdependency_libs " -L$func_replace_sysroot_result"
|
| ;;
|
| - *) newdependency_libs="$newdependency_libs $deplib" ;;
|
| + -R*)
|
| + func_stripname -R '' "$deplib"
|
| + func_replace_sysroot "$func_stripname_result"
|
| + func_append newdependency_libs " -R$func_replace_sysroot_result"
|
| + ;;
|
| + *) func_append newdependency_libs " $deplib" ;;
|
| esac
|
| done
|
| dependency_libs="$newdependency_libs"
|
| @@ -8082,9 +9315,9 @@ EOF
|
| eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
|
| test -z "$libdir" && \
|
| func_fatal_error "\`$lib' is not a valid libtool archive"
|
| - newdlfiles="$newdlfiles $libdir/$name"
|
| + func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name"
|
| ;;
|
| - *) newdlfiles="$newdlfiles $lib" ;;
|
| + *) func_append newdlfiles " $lib" ;;
|
| esac
|
| done
|
| dlfiles="$newdlfiles"
|
| @@ -8101,7 +9334,7 @@ EOF
|
| eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
|
| test -z "$libdir" && \
|
| func_fatal_error "\`$lib' is not a valid libtool archive"
|
| - newdlprefiles="$newdlprefiles $libdir/$name"
|
| + func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name"
|
| ;;
|
| esac
|
| done
|
| @@ -8113,7 +9346,7 @@ EOF
|
| [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
|
| *) abs=`pwd`"/$lib" ;;
|
| esac
|
| - newdlfiles="$newdlfiles $abs"
|
| + func_append newdlfiles " $abs"
|
| done
|
| dlfiles="$newdlfiles"
|
| newdlprefiles=
|
| @@ -8122,15 +9355,33 @@ EOF
|
| [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
|
| *) abs=`pwd`"/$lib" ;;
|
| esac
|
| - newdlprefiles="$newdlprefiles $abs"
|
| + func_append newdlprefiles " $abs"
|
| done
|
| dlprefiles="$newdlprefiles"
|
| fi
|
| $RM $output
|
| # place dlname in correct position for cygwin
|
| + # In fact, it would be nice if we could use this code for all target
|
| + # systems that can't hard-code library paths into their executables
|
| + # and that have no shared library path variable independent of PATH,
|
| + # but it turns out we can't easily determine that from inspecting
|
| + # libtool variables, so we have to hard-code the OSs to which it
|
| + # applies here; at the moment, that means platforms that use the PE
|
| + # object format with DLL files. See the long comment at the top of
|
| + # tests/bindir.at for full details.
|
| tdlname=$dlname
|
| case $host,$output,$installed,$module,$dlname in
|
| - *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;;
|
| + *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll)
|
| + # If a -bindir argument was supplied, place the dll there.
|
| + if test "x$bindir" != x ;
|
| + then
|
| + func_relative_path "$install_libdir" "$bindir"
|
| + tdlname=$func_relative_path_result$dlname
|
| + else
|
| + # Otherwise fall back on heuristic.
|
| + tdlname=../bin/$dlname
|
| + fi
|
| + ;;
|
| esac
|
| $ECHO > $output "\
|
| # $outputname - a libtool library file
|
| @@ -8189,7 +9440,7 @@ relink_command=\"$relink_command\""
|
| exit $EXIT_SUCCESS
|
| }
|
|
|
| -{ test "$mode" = link || test "$mode" = relink; } &&
|
| +{ test "$opt_mode" = link || test "$opt_mode" = relink; } &&
|
| func_mode_link ${1+"$@"}
|
|
|
|
|
| @@ -8209,9 +9460,9 @@ func_mode_uninstall ()
|
| for arg
|
| do
|
| case $arg in
|
| - -f) RM="$RM $arg"; rmforce=yes ;;
|
| - -*) RM="$RM $arg" ;;
|
| - *) files="$files $arg" ;;
|
| + -f) func_append RM " $arg"; rmforce=yes ;;
|
| + -*) func_append RM " $arg" ;;
|
| + *) func_append files " $arg" ;;
|
| esac
|
| done
|
|
|
| @@ -8220,24 +9471,23 @@ func_mode_uninstall ()
|
|
|
| rmdirs=
|
|
|
| - origobjdir="$objdir"
|
| for file in $files; do
|
| func_dirname "$file" "" "."
|
| dir="$func_dirname_result"
|
| if test "X$dir" = X.; then
|
| - objdir="$origobjdir"
|
| + odir="$objdir"
|
| else
|
| - objdir="$dir/$origobjdir"
|
| + odir="$dir/$objdir"
|
| fi
|
| func_basename "$file"
|
| name="$func_basename_result"
|
| - test "$mode" = uninstall && objdir="$dir"
|
| + test "$opt_mode" = uninstall && odir="$dir"
|
|
|
| - # Remember objdir for removal later, being careful to avoid duplicates
|
| - if test "$mode" = clean; then
|
| + # Remember odir for removal later, being careful to avoid duplicates
|
| + if test "$opt_mode" = clean; then
|
| case " $rmdirs " in
|
| - *" $objdir "*) ;;
|
| - *) rmdirs="$rmdirs $objdir" ;;
|
| + *" $odir "*) ;;
|
| + *) func_append rmdirs " $odir" ;;
|
| esac
|
| fi
|
|
|
| @@ -8263,18 +9513,17 @@ func_mode_uninstall ()
|
|
|
| # Delete the libtool libraries and symlinks.
|
| for n in $library_names; do
|
| - rmfiles="$rmfiles $objdir/$n"
|
| + func_append rmfiles " $odir/$n"
|
| done
|
| - test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library"
|
| + test -n "$old_library" && func_append rmfiles " $odir/$old_library"
|
|
|
| - case "$mode" in
|
| + case "$opt_mode" in
|
| clean)
|
| - case " $library_names " in
|
| - # " " in the beginning catches empty $dlname
|
| + case " $library_names " in
|
| *" $dlname "*) ;;
|
| - *) rmfiles="$rmfiles $objdir/$dlname" ;;
|
| + *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;;
|
| esac
|
| - test -n "$libdir" && rmfiles="$rmfiles $objdir/$name $objdir/${name}i"
|
| + test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i"
|
| ;;
|
| uninstall)
|
| if test -n "$library_names"; then
|
| @@ -8302,19 +9551,19 @@ func_mode_uninstall ()
|
| # 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"
|
| + func_append 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"
|
| + func_append rmfiles " $dir/$non_pic_object"
|
| fi
|
| fi
|
| ;;
|
|
|
| *)
|
| - if test "$mode" = clean ; then
|
| + if test "$opt_mode" = clean ; then
|
| noexename=$name
|
| case $file in
|
| *.exe)
|
| @@ -8324,7 +9573,7 @@ func_mode_uninstall ()
|
| noexename=$func_stripname_result
|
| # $file with .exe has already been added to rmfiles,
|
| # add $file without .exe
|
| - rmfiles="$rmfiles $file"
|
| + func_append rmfiles " $file"
|
| ;;
|
| esac
|
| # Do a test to see if this is a libtool program.
|
| @@ -8333,7 +9582,7 @@ func_mode_uninstall ()
|
| func_ltwrapper_scriptname "$file"
|
| relink_command=
|
| func_source $func_ltwrapper_scriptname_result
|
| - rmfiles="$rmfiles $func_ltwrapper_scriptname_result"
|
| + func_append rmfiles " $func_ltwrapper_scriptname_result"
|
| else
|
| relink_command=
|
| func_source $dir/$noexename
|
| @@ -8341,12 +9590,12 @@ func_mode_uninstall ()
|
|
|
| # 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}"
|
| + func_append rmfiles " $odir/$name $odir/${name}S.${objext}"
|
| if test "$fast_install" = yes && test -n "$relink_command"; then
|
| - rmfiles="$rmfiles $objdir/lt-$name"
|
| + func_append rmfiles " $odir/lt-$name"
|
| fi
|
| if test "X$noexename" != "X$name" ; then
|
| - rmfiles="$rmfiles $objdir/lt-${noexename}.c"
|
| + func_append rmfiles " $odir/lt-${noexename}.c"
|
| fi
|
| fi
|
| fi
|
| @@ -8354,7 +9603,6 @@ func_mode_uninstall ()
|
| esac
|
| func_show_eval "$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
|
| @@ -8366,16 +9614,16 @@ func_mode_uninstall ()
|
| exit $exit_status
|
| }
|
|
|
| -{ test "$mode" = uninstall || test "$mode" = clean; } &&
|
| +{ test "$opt_mode" = uninstall || test "$opt_mode" = clean; } &&
|
| func_mode_uninstall ${1+"$@"}
|
|
|
| -test -z "$mode" && {
|
| +test -z "$opt_mode" && {
|
| help="$generic_help"
|
| func_fatal_help "you must specify a MODE"
|
| }
|
|
|
| test -z "$exec_cmd" && \
|
| - func_fatal_help "invalid operation mode \`$mode'"
|
| + func_fatal_help "invalid operation mode \`$opt_mode'"
|
|
|
| if test -n "$exec_cmd"; then
|
| eval exec "$exec_cmd"
|
|
|