"Fossies" - the Fresh Open Source Software Archive  

Source code changes of the file "ltmain.sh" between
mod_mono-3.12.tar.gz and mod_mono-3.13.tar.gz

About: mod_mono is an Apache 2.0/2.2/2.4.3 module that provides ASP.NET functionality.

ltmain.sh  (mod_mono-3.12):ltmain.sh  (mod_mono-3.13)
#! /bin/sh
## DO NOT EDIT - This file generated from ./build-aux/ltmain.in
## by inline-source v2014-01-03.01
# libtool (GNU libtool) 2.4.2 # libtool (GNU libtool) 2.4.6
# Provide generalized library-building support services.
# Written by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996 # Written by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, # Copyright (C) 1996-2015 Free Software Foundation, Inc.
# 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc.
# This is free software; see the source for copying conditions. There is NO # This is free software; see the source for copying conditions. There is NO
# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# GNU Libtool is free software; you can redistribute it and/or modify # GNU Libtool is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or # the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version. # (at your option) any later version.
# #
# As a special exception to the GNU General Public License, # As a special exception to the GNU General Public License,
# if you distribute this file as part of a program or library that # if you distribute this file as part of a program or library that
# is built using GNU Libtool, you may include this file under the # is built using GNU Libtool, you may include this file under the
# same distribution terms that you use for the rest of that program. # same distribution terms that you use for the rest of that program.
# #
# GNU Libtool is distributed in the hope that it will be useful, but # GNU Libtool is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of # WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details. # General Public License for more details.
# #
# You should have received a copy of the GNU General Public License # You should have received a copy of the GNU General Public License
# along with GNU Libtool; see the file COPYING. If not, a copy # along with this program. If not, see <http://www.gnu.org/licenses/>.
# can be downloaded from http://www.gnu.org/licenses/gpl.html,
# or obtained by writing to the Free Software Foundation, Inc., PROGRAM=libtool
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. PACKAGE=libtool
VERSION="2.4.6 Debian-2.4.6-2"
package_revision=2.4.6
## ------ ##
## Usage. ##
## ------ ##
# Run './libtool --help' for help with using this script from the
# command line.
## ------------------------------- ##
## User overridable command paths. ##
## ------------------------------- ##
# After configure completes, it has a better idea of some of the
# shell tools we need than the defaults used by the functions shared
# with bootstrap, so set those here where they can still be over-
# ridden by the user, but otherwise take precedence.
: ${AUTOCONF="autoconf"}
: ${AUTOMAKE="automake"}
## -------------------------- ##
## Source external libraries. ##
## -------------------------- ##
# Much of our low-level functionality needs to be sourced from external
# libraries, which are installed to $pkgauxdir.
# Set a version string for this script.
scriptversion=2015-01-20.17; # UTC
# General shell script boiler plate, and helper functions.
# Written by Gary V. Vaughan, 2004
# Copyright (C) 2004-2015 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.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
# As a special exception to the GNU General Public License, if you distribute
# this file as part of a program or library that is built using GNU Libtool,
# you may include this file under the same distribution terms that you use
# for the rest of that program.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNES FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# Please report bugs or propose patches to gary@gnu.org.
# Usage: $progname [OPTION]... [MODE-ARG]... ## ------ ##
## Usage. ##
## ------ ##
# Evaluate this file near the top of your script to gain access to
# the functions and variables defined here:
# #
# Provide generalized library-building support services. # . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh
# #
# --config show all configuration variables # If you need to override any of the default environment variable
# --debug enable verbose shell tracing # settings, do that before evaluating this file.
# -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
#
# 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.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=libtool ## -------------------- ##
PACKAGE=libtool ## Shell normalisation. ##
VERSION="2.4.2 Debian-2.4.2-1.7ubuntu1" ## -------------------- ##
TIMESTAMP=""
package_revision=1.3337
# Be Bourne compatible # Some shells need a little help to be as Bourne compatible as possible.
if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then # Before doing anything else, make sure all that help has been provided!
DUALCASE=1; export DUALCASE # for MKS sh
if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then :
emulate sh emulate sh
NULLCMD=: NULLCMD=:
# Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
# is contrary to our usage. Disable this feature. # is contrary to our usage. Disable this feature.
alias -g '${1+"$@"}'='"$@"' alias -g '${1+"$@"}'='"$@"'
setopt NO_GLOB_SUBST setopt NO_GLOB_SUBST
else else
case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac
fi 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. # NLS nuisances: We save the old values in case they are required later.
lt_user_locale= _G_user_locale=
lt_safe_locale= _G_safe_locale=
for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
do do
eval "if test \"\${$lt_var+set}\" = set; then eval "if test set = \"\${$_G_var+set}\"; then
save_$lt_var=\$$lt_var save_$_G_var=\$$_G_var
$lt_var=C $_G_var=C
export $lt_var export $_G_var
lt_user_locale=\"$lt_var=\\\$save_\$lt_var; \$lt_user_locale\" _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\"
lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\" _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\"
fi" fi"
done done
LC_ALL=C
LANGUAGE=C
export LANGUAGE LC_ALL
$lt_unset CDPATH # CDPATH.
(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh # Make sure IFS has a sensible default
# is ksh but when the shell is invoked as "sh" and the current value of sp=' '
# the _XPG environment variable is not equal to 1 (one), the special nl='
# positional parameter $0, within a function call, is the name of the '
# function. IFS="$sp $nl"
progpath="$0"
# There are apparently some retarded systems that use ';' as a PATH separator!
if test "${PATH_SEPARATOR+set}" != set; then
PATH_SEPARATOR=:
(PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && {
(PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 ||
PATH_SEPARATOR=';'
}
fi
## ------------------------- ##
## Locate command utilities. ##
## ------------------------- ##
# func_executable_p FILE
# ----------------------
# Check that FILE is an executable regular file.
func_executable_p ()
{
test -f "$1" && test -x "$1"
}
# func_path_progs PROGS_LIST CHECK_FUNC [PATH]
# --------------------------------------------
# Search for either a program that responds to --version with output
# containing "GNU", or else returned by CHECK_FUNC otherwise, by
# trying all the directories in PATH with each of the elements of
# PROGS_LIST.
#
# CHECK_FUNC should accept the path to a candidate program, and
# set $func_check_prog_result if it truncates its output less than
# $_G_path_prog_max characters.
func_path_progs ()
{
_G_progs_list=$1
_G_check_func=$2
_G_PATH=${3-"$PATH"}
_G_path_prog_max=0
_G_path_prog_found=false
_G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:}
for _G_dir in $_G_PATH; do
IFS=$_G_save_IFS
test -z "$_G_dir" && _G_dir=.
for _G_prog_name in $_G_progs_list; do
for _exeext in '' .EXE; do
_G_path_prog=$_G_dir/$_G_prog_name$_exeext
func_executable_p "$_G_path_prog" || continue
case `"$_G_path_prog" --version 2>&1` in
*GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;;
*) $_G_check_func $_G_path_prog
func_path_progs_result=$func_check_prog_result
;;
esac
$_G_path_prog_found && break 3
done
done
done
IFS=$_G_save_IFS
test -z "$func_path_progs_result" && {
echo "no acceptable sed could be found in \$PATH" >&2
exit 1
}
}
# We want to be able to use the functions in this file before configure
# has figured out where the best binaries are kept, which means we have
# to search for them ourselves - except when the results are already set
# where we skip the searches.
# Unless the user overrides by setting SED, search the path for either GNU
# sed, or the sed that truncates its output the least.
test -z "$SED" && {
_G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbb
bbbbbbb/
for _G_i in 1 2 3 4 5 6 7; do
_G_sed_script=$_G_sed_script$nl$_G_sed_script
done
echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed
_G_sed_script=
func_check_prog_sed ()
{
_G_path_prog=$1
_G_count=0
printf 0123456789 >conftest.in
while :
do
cat conftest.in conftest.in >conftest.tmp
mv conftest.tmp conftest.in
cp conftest.in conftest.nl
echo '' >> conftest.nl
"$_G_path_prog" -f conftest.sed <conftest.nl >conftest.out 2>/dev/null ||
break
diff conftest.out conftest.nl >/dev/null 2>&1 || break
_G_count=`expr $_G_count + 1`
if test "$_G_count" -gt "$_G_path_prog_max"; then
# Best one so far, save it but keep looking for a better one
func_check_prog_result=$_G_path_prog
_G_path_prog_max=$_G_count
fi
# 10*(2^10) chars as input seems more than enough
test 10 -lt "$_G_count" && break
done
rm -f conftest.in conftest.tmp conftest.nl conftest.out
}
func_path_progs "sed gsed" func_check_prog_sed $PATH:/usr/xpg4/bin
rm -f conftest.sed
SED=$func_path_progs_result
}
# Unless the user overrides by setting GREP, search the path for either GNU
# grep, or the grep that truncates its output the least.
test -z "$GREP" && {
func_check_prog_grep ()
{
_G_path_prog=$1
_G_count=0
_G_path_prog_max=0
printf 0123456789 >conftest.in
while :
do
cat conftest.in conftest.in >conftest.tmp
mv conftest.tmp conftest.in
cp conftest.in conftest.nl
echo 'GREP' >> conftest.nl
"$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' <conftest.nl >conftest.ou
t 2>/dev/null || break
diff conftest.out conftest.nl >/dev/null 2>&1 || break
_G_count=`expr $_G_count + 1`
if test "$_G_count" -gt "$_G_path_prog_max"; then
# Best one so far, save it but keep looking for a better one
func_check_prog_result=$_G_path_prog
_G_path_prog_max=$_G_count
fi
# 10*(2^10) chars as input seems more than enough
test 10 -lt "$_G_count" && break
done
rm -f conftest.in conftest.tmp conftest.nl conftest.out
}
func_path_progs "grep ggrep" func_check_prog_grep $PATH:/usr/xpg4/bin
GREP=$func_path_progs_result
}
## ------------------------------- ##
## User overridable command paths. ##
## ------------------------------- ##
# All uppercase variable names are used for environment variables. These
# variables can be overridden by the user before calling a script that
# uses them if a suitable command of that name is not already available
# in the command search PATH.
: ${CP="cp -f"} : ${CP="cp -f"}
test "${ECHO+set}" = set || ECHO=${as_echo-'printf %s\n'} : ${ECHO="printf %s\n"}
: ${EGREP="$GREP -E"}
: ${FGREP="$GREP -F"}
: ${LN_S="ln -s"}
: ${MAKE="make"} : ${MAKE="make"}
: ${MKDIR="mkdir"} : ${MKDIR="mkdir"}
: ${MV="mv -f"} : ${MV="mv -f"}
: ${RM="rm -f"} : ${RM="rm -f"}
: ${SHELL="${CONFIG_SHELL-/bin/sh}"} : ${SHELL="${CONFIG_SHELL-/bin/sh}"}
: ${Xsed="$SED -e 1s/^X//"}
# Global variables:
EXIT_SUCCESS=0
EXIT_FAILURE=1
EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing.
EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
exit_status=$EXIT_SUCCESS ## -------------------- ##
## Useful sed snippets. ##
## -------------------- ##
# Make sure IFS has a sensible default sed_dirname='s|/[^/]*$||'
lt_nl=' sed_basename='s|^.*/||'
'
IFS=" $lt_nl"
dirname="s,/[^/]*$,," # Sed substitution that helps us do robust quoting. It backslashifies
basename="s,^.*/,," # metacharacters that are still active within double-quoted strings.
sed_quote_subst='s|\([`"$\\]\)|\\\1|g'
# func_dirname file append nondir_replacement # Same as above, but do not quote variable references.
# Compute the dirname of FILE. If nonempty, add APPEND to the result, sed_double_quote_subst='s/\(["`\\]\)/\\\1/g'
# 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 # Sed substitution that turns a string into a regex matching for the
func_basename () # string literally.
{ sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g'
func_basename_result=`$ECHO "${1}" | $SED "$basename"`
} # func_basename may be replaced by extended shell implementation
# func_dirname_and_basename file append nondir_replacement # Sed substitution that converts a w32 file name or path
# perform func_basename and func_dirname in a single function # that contains forward slashes, into one that contains
# call: # (escaped) backslashes. A very naive implementation.
# dirname: Compute the dirname of FILE. If nonempty, sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
# add APPEND to the result, otherwise set result
# to NONDIR_REPLACEMENT.
# value returned in "$func_dirname_result"
# basename: Compute filename of FILE.
# value retuned in "$func_basename_result"
# Implementation must be kept synchronized with func_dirname
# and func_basename. For efficiency, we do not delegate to
# those functions but instead duplicate the functionality here.
func_dirname_and_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 # Re-'\' parameter expansions in output of sed_double_quote_subst that
# strip PREFIX and SUFFIX off of NAME. # were '\'-ed in input to the same. If an odd number of '\' preceded a
# PREFIX and SUFFIX must not contain globbing or regex special # '$' in input to sed_double_quote_subst, that '$' was protected from
# characters, hashes, percent signs, but SUFFIX may contain a leading # expansion. Since each input '\' is now two '\'s, look for any number
# dot (in which case that matches only a dot). # of runs of four '\'s followed by two '\'s and then a '$'. '\' that '$'.
# func_strip_suffix prefix name _G_bs='\\'
func_stripname () _G_bs2='\\\\'
{ _G_bs4='\\\\\\\\'
case ${2} in _G_dollar='\$'
.*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%" sed_double_backslash="\
`;; s/$_G_bs4/&\\
*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;; /g
esac s/^$_G_bs2$_G_dollar/$_G_bs&/
} # func_stripname may be replaced by extended shell implementation s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g
s/\n//g"
# These SED scripts presuppose an absolute path with a trailing slash. ## ----------------- ##
pathcar='s,^/\([^/]*\).*$,\1,' ## Global variables. ##
pathcdr='s,^/[^/]*,,' ## ----------------- ##
removedotparts=':dotsl
s@/\./@/@g # Except for the global variables explicitly listed below, the following
t dotsl # functions in the '^func_' namespace, and the '^require_' namespace
s,/\.$,/,' # variables initialised in the 'Resource management' section, sourcing
collapseslashes='s@/\{1,\}@/@g' # this file will not pollute your global namespace with anything
finalslash='s,/*$,/,' # else. There's no portable way to scope variables in Bourne shell
# though, so actually running these functions will sometimes place
# results into a variable named after the function, and often use
# temporary variables in the '^_G_' namespace. If you are careful to
# avoid using those namespaces casually in your sourcing script, things
# should continue to work as you expect. And, of course, you can freely
# overwrite any of the functions or variables defined here before
# calling anything to customize them.
# func_normal_abspath PATH EXIT_SUCCESS=0
# Remove doubled-up and trailing slashes, "." path components, EXIT_FAILURE=1
# and cancel out any ".." path components in PATH after making EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing.
# it an absolute path. EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
# 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_absp
ath_tcomponent
;;
esac
done
# Restore leading double-slash if one was found on entry.
func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspa
th_result
}
# func_relative_path SRCDIR DSTDIR # Allow overriding, eg assuming that you follow the convention of
# generates a relative path from SRCDIR to DSTDIR, with a trailing # putting '$debug_cmd' at the start of all your functions, you can get
# slash if non-empty, suitable for immediately appending a filename # bash to show function call trace with:
# without needing to append a separator. #
# value returned in "$func_relative_path_result" # debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
func_relative_path () debug_cmd=${debug_cmd-":"}
{ exit_cmd=:
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_tbi
ndir"
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
# Now calculate path; take care to avoid doubling-up slashes. # By convention, finish your script with:
func_stripname '' '/' "$func_relative_path_result" #
func_relative_path_result=$func_stripname_result # exit $exit_status
func_stripname '/' '/' "$func_relative_path_tcancelled" #
if test "x$func_stripname_result" != x ; then # so that you can set exit_status to non-zero if you want to indicate
func_relative_path_result=${func_relative_path_result}/${func_stripname_resu # something went wrong during execution without actually bailing out at
lt} # the point of failure.
fi exit_status=$EXIT_SUCCESS
# Normalisation. If bindir is libdir, return empty string, # Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
# else relative path ending with a slash; either way, target # is ksh but when the shell is invoked as "sh" and the current value of
# file name can be directly appended. # the _XPG environment variable is not equal to 1 (one), the special
if test ! -z "$func_relative_path_result"; then # positional parameter $0, within a function call, is the name of the
func_stripname './' '' "$func_relative_path_result/" # function.
func_relative_path_result=$func_stripname_result progpath=$0
fi
}
# The name of this program: # The name of this program.
func_dirname_and_basename "$progpath" progname=`$ECHO "$progpath" |$SED "$sed_basename"`
progname=$func_basename_result
# Make sure we have an absolute path for reexecution: # Make sure we have an absolute progpath for reexecution:
case $progpath in case $progpath in
[\\/]*|[A-Za-z]:\\*) ;; [\\/]*|[A-Za-z]:\\*) ;;
*[\\/]*) *[\\/]*)
progdir=$func_dirname_result progdir=`$ECHO "$progpath" |$SED "$sed_dirname"`
progdir=`cd "$progdir" && pwd` progdir=`cd "$progdir" && pwd`
progpath="$progdir/$progname" progpath=$progdir/$progname
;; ;;
*) *)
save_IFS="$IFS" _G_IFS=$IFS
IFS=${PATH_SEPARATOR-:} IFS=${PATH_SEPARATOR-:}
for progdir in $PATH; do for progdir in $PATH; do
IFS="$save_IFS" IFS=$_G_IFS
test -x "$progdir/$progname" && break test -x "$progdir/$progname" && break
done done
IFS="$save_IFS" IFS=$_G_IFS
test -n "$progdir" || progdir=`pwd` test -n "$progdir" || progdir=`pwd`
progpath="$progdir/$progname" progpath=$progdir/$progname
;; ;;
esac esac
# Sed substitution that helps us do robust quoting. It backslashifies ## ----------------- ##
# metacharacters that are still active within double-quoted strings. ## Standard options. ##
Xsed="${SED}"' -e 1s/^X//' ## ----------------- ##
sed_quote_subst='s/\([`"$\\]\)/\\\1/g'
# The following options affect the operation of the functions defined
# Same as above, but do not quote variable references. # below, and should be set appropriately depending on run-time para-
double_quote_subst='s/\(["`\\]\)/\\\1/g' # meters passed on the command line.
# 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.
# Since each input `\' is now two `\'s, look for any number of runs of
# four `\'s followed by two `\'s and then a '$'. `\' that '$'.
bs='\\'
bs2='\\\\'
bs4='\\\\\\\\'
dollar='\$'
sed_double_backslash="\
s/$bs4/&\\
/g
s/^$bs2$dollar/$bs&/
s/\\([^$bs]\\)$bs2$dollar/\\1$bs2$bs$dollar/g
s/\n//g"
# Standard options:
opt_dry_run=false opt_dry_run=false
opt_help=false
opt_quiet=false opt_quiet=false
opt_verbose=false opt_verbose=false
opt_warning=:
# func_echo arg... # Categories 'all' and 'none' are always available. Append any others
# Echo program name prefixed message, along with the current mode # you will pass as the first argument to func_warning from your own
# name if it has been set yet. # code.
func_echo () warning_categories=
{
$ECHO "$progname: ${opt_mode+$opt_mode: }$*" # By default, display warnings according to 'opt_warning_types'. Set
# 'warning_func' to ':' to elide all warnings, or func_fatal_error to
# treat the next displayed warning as a fatal error.
warning_func=func_warn_and_continue
# Set to 'all' to display all warnings, 'none' to suppress all
# warnings, or a space delimited list of some subset of
# 'warning_categories' to display only the listed warnings.
opt_warning_types=all
## -------------------- ##
## Resource management. ##
## -------------------- ##
# This section contains definitions for functions that each ensure a
# particular resource (a file, or a non-empty configuration variable for
# example) is available, and if appropriate to extract default values
# from pertinent package files. Call them using their associated
# 'require_*' variable to ensure that they are executed, at most, once.
#
# It's entirely deliberate that calling these functions can set
# variables that don't obey the namespace limitations obeyed by the rest
# of this file, in order that that they be as useful as possible to
# callers.
# require_term_colors
# -------------------
# Allow display of bold text on terminals that support it.
require_term_colors=func_require_term_colors
func_require_term_colors ()
{
$debug_cmd
test -t 1 && {
# COLORTERM and USE_ANSI_COLORS environment variables take
# precedence, because most terminfo databases neglect to describe
# whether color sequences are supported.
test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"}
if test 1 = "$USE_ANSI_COLORS"; then
# Standard ANSI escape sequences
tc_reset=''
tc_bold=''; tc_standout=''
tc_red=''; tc_green=''
tc_blue=''; tc_cyan=''
else
# Otherwise trust the terminfo database after all.
test -n "`tput sgr0 2>/dev/null`" && {
tc_reset=`tput sgr0`
test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold`
tc_standout=$tc_bold
test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso`
test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1`
test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2`
test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4`
test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5`
}
fi
}
require_term_colors=:
} }
# func_verbose arg... ## ----------------- ##
# Echo program name prefixed message in verbose mode only. ## Function library. ##
func_verbose () ## ----------------- ##
{
$opt_verbose && func_echo ${1+"$@"} # This section contains a variety of useful functions to call in your
# scripts. Take note of the portable wrappers for features provided by
# some modern shells, which will fall back to slower equivalents on
# less featureful shells.
# func_append VAR VALUE
# ---------------------
# Append VALUE onto the existing contents of VAR.
# We should try to minimise forks, especially on Windows where they are
# unreasonably slow, so skip the feature probes when bash or zsh are
# being used:
if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then
: ${_G_HAVE_ARITH_OP="yes"}
: ${_G_HAVE_XSI_OPS="yes"}
# The += operator was introduced in bash 3.1
case $BASH_VERSION in
[12].* | 3.0 | 3.0*) ;;
*)
: ${_G_HAVE_PLUSEQ_OP="yes"}
;;
esac
fi
# A bug in bash halts the script if the last line of a function # _G_HAVE_PLUSEQ_OP
# fails when set -e is in force, so we need another command to # Can be empty, in which case the shell is probed, "yes" if += is
# work around that: # useable or anything else if it does not work.
: test -z "$_G_HAVE_PLUSEQ_OP" \
} && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \
&& _G_HAVE_PLUSEQ_OP=yes
if test yes = "$_G_HAVE_PLUSEQ_OP"
then
# This is an XSI compatible shell, allowing a faster implementation...
eval 'func_append ()
{
$debug_cmd
# func_echo_all arg... eval "$1+=\$2"
# Invoke $ECHO with all args, space-separated. }'
func_echo_all () else
{ # ...otherwise fall back to using expr, which is often a shell builtin.
$ECHO "$*" func_append ()
} {
$debug_cmd
# func_error arg... eval "$1=\$$1\$2"
# Echo program name prefixed message to standard error. }
func_error () fi
{
$ECHO "$progname: ${opt_mode+$opt_mode: }"${1+"$@"} 1>&2
}
# func_warning arg... # func_append_quoted VAR VALUE
# Echo program name prefixed warning message to standard error. # ----------------------------
func_warning () # Quote VALUE and append to the end of shell variable VAR, separated
{ # by a space.
$opt_warning && $ECHO "$progname: ${opt_mode+$opt_mode: }warning: "${1+"$@"} if test yes = "$_G_HAVE_PLUSEQ_OP"; then
1>&2 eval 'func_append_quoted ()
{
$debug_cmd
# bash bug again: func_quote_for_eval "$2"
: eval "$1+=\\ \$func_quote_for_eval_result"
} }'
else
func_append_quoted ()
{
$debug_cmd
# func_fatal_error arg... func_quote_for_eval "$2"
# Echo program name prefixed message to standard error, and exit. eval "$1=\$$1\\ \$func_quote_for_eval_result"
func_fatal_error () }
{ fi
func_error ${1+"$@"}
exit $EXIT_FAILURE
}
# func_fatal_help arg... # func_append_uniq VAR VALUE
# Echo program name prefixed message to standard error, followed by # --------------------------
# a help hint, and exit. # Append unique VALUE onto the existing contents of VAR, assuming
func_fatal_help () # entries are delimited by the first character of VALUE. For example:
{ #
func_error ${1+"$@"} # func_append_uniq options " --another-option option-argument"
func_fatal_error "$help" #
# will only append to $options if " --another-option option-argument "
# is not already present somewhere in $options already (note spaces at
# each end implied by leading space in second argument).
func_append_uniq ()
{
$debug_cmd
eval _G_current_value='`$ECHO $'$1'`'
_G_delim=`expr "$2" : '\(.\)'`
case $_G_delim$_G_current_value$_G_delim in
*"$2$_G_delim"*) ;;
*) func_append "$@" ;;
esac
} }
help="Try \`$progname --help' for more information." ## default
# func_grep expression filename # func_arith TERM...
# Check whether EXPRESSION matches any line of FILENAME, without output. # ------------------
func_grep () # Set func_arith_result to the result of evaluating TERMs.
test -z "$_G_HAVE_ARITH_OP" \
&& (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \
&& _G_HAVE_ARITH_OP=yes
if test yes = "$_G_HAVE_ARITH_OP"; then
eval 'func_arith ()
{
$debug_cmd
func_arith_result=$(( $* ))
}'
else
func_arith ()
{
$debug_cmd
func_arith_result=`expr "$@"`
}
fi
# func_basename FILE
# ------------------
# Set func_basename_result to FILE with everything up to and including
# the last / stripped.
if test yes = "$_G_HAVE_XSI_OPS"; then
# If this shell supports suffix pattern removal, then use it to avoid
# forking. Hide the definitions single quotes in case the shell chokes
# on unsupported syntax...
_b='func_basename_result=${1##*/}'
_d='case $1 in
*/*) func_dirname_result=${1%/*}$2 ;;
* ) func_dirname_result=$3 ;;
esac'
else
# ...otherwise fall back to using sed.
_b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`'
_d='func_dirname_result=`$ECHO "$1" |$SED "$sed_dirname"`
if test "X$func_dirname_result" = "X$1"; then
func_dirname_result=$3
else
func_append func_dirname_result "$2"
fi'
fi
eval 'func_basename ()
{ {
$debug_cmd
'"$_b"'
}'
# func_dirname FILE APPEND NONDIR_REPLACEMENT
# -------------------------------------------
# Compute the dirname of FILE. If nonempty, add APPEND to the result,
# otherwise set result to NONDIR_REPLACEMENT.
eval 'func_dirname ()
{
$debug_cmd
'"$_d"'
}'
# func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT
# --------------------------------------------------------
# Perform func_basename and func_dirname in a single function
# call:
# dirname: Compute the dirname of FILE. If nonempty,
# add APPEND to the result, otherwise set result
# to NONDIR_REPLACEMENT.
# value returned in "$func_dirname_result"
# basename: Compute filename of FILE.
# value retuned in "$func_basename_result"
# For efficiency, we do not delegate to the functions above but instead
# duplicate the functionality here.
eval 'func_dirname_and_basename ()
{
$debug_cmd
'"$_b"'
'"$_d"'
}'
# func_echo ARG...
# ----------------
# Echo program name prefixed message.
func_echo ()
{
$debug_cmd
_G_message=$*
func_echo_IFS=$IFS
IFS=$nl
for _G_line in $_G_message; do
IFS=$func_echo_IFS
$ECHO "$progname: $_G_line"
done
IFS=$func_echo_IFS
}
# func_echo_all ARG...
# --------------------
# Invoke $ECHO with all args, space-separated.
func_echo_all ()
{
$ECHO "$*"
}
# func_echo_infix_1 INFIX ARG...
# ------------------------------
# Echo program name, followed by INFIX on the first line, with any
# additional lines not showing INFIX.
func_echo_infix_1 ()
{
$debug_cmd
$require_term_colors
_G_infix=$1; shift
_G_indent=$_G_infix
_G_prefix="$progname: $_G_infix: "
_G_message=$*
# Strip color escape sequences before counting printable length
for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$t
c_blue" "$tc_cyan"
do
test -n "$_G_tc" && {
_G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"`
_G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"`
}
done
_G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`" " ## exclude f
rom sc_prohibit_nested_quotes
func_echo_infix_1_IFS=$IFS
IFS=$nl
for _G_line in $_G_message; do
IFS=$func_echo_infix_1_IFS
$ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2
_G_prefix=$_G_indent
done
IFS=$func_echo_infix_1_IFS
}
# func_error ARG...
# -----------------
# Echo program name prefixed message to standard error.
func_error ()
{
$debug_cmd
$require_term_colors
func_echo_infix_1 " $tc_standout${tc_red}error$tc_reset" "$*" >&2
}
# func_fatal_error ARG...
# -----------------------
# Echo program name prefixed message to standard error, and exit.
func_fatal_error ()
{
$debug_cmd
func_error "$*"
exit $EXIT_FAILURE
}
# func_grep EXPRESSION FILENAME
# -----------------------------
# Check whether EXPRESSION matches any line of FILENAME, without output.
func_grep ()
{
$debug_cmd
$GREP "$1" "$2" >/dev/null 2>&1 $GREP "$1" "$2" >/dev/null 2>&1
} }
# func_mkdir_p directory-path # func_len STRING
# Make sure the entire path to DIRECTORY-PATH is available. # ---------------
func_mkdir_p () # Set func_len_result to the length of STRING. STRING may not
# start with a hyphen.
test -z "$_G_HAVE_XSI_OPS" \
&& (eval 'x=a/b/c;
test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
&& _G_HAVE_XSI_OPS=yes
if test yes = "$_G_HAVE_XSI_OPS"; then
eval 'func_len ()
{
$debug_cmd
func_len_result=${#1}
}'
else
func_len ()
{
$debug_cmd
func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len`
}
fi
# func_mkdir_p DIRECTORY-PATH
# ---------------------------
# Make sure the entire path to DIRECTORY-PATH is available.
func_mkdir_p ()
{
$debug_cmd
_G_directory_path=$1
_G_dir_list=
if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then
# Protect directory names starting with '-'
case $_G_directory_path in
-*) _G_directory_path=./$_G_directory_path ;;
esac
# While some portion of DIR does not yet exist...
while test ! -d "$_G_directory_path"; do
# ...make a list in topmost first order. Use a colon delimited
# list incase some portion of path contains whitespace.
_G_dir_list=$_G_directory_path:$_G_dir_list
# If the last portion added has no slash in it, the list is done
case $_G_directory_path in */*) ;; *) break ;; esac
# ...otherwise throw away the child directory and loop
_G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"`
done
_G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'`
func_mkdir_p_IFS=$IFS; IFS=:
for _G_dir in $_G_dir_list; do
IFS=$func_mkdir_p_IFS
# mkdir can fail with a 'File exist' error if two processes
# try to create one of the directories concurrently. Don't
# stop in that case!
$MKDIR "$_G_dir" 2>/dev/null || :
done
IFS=$func_mkdir_p_IFS
# Bail out if we (or some other process) failed to create a directory.
test -d "$_G_directory_path" || \
func_fatal_error "Failed to create '$1'"
fi
}
# func_mktempdir [BASENAME]
# -------------------------
# Make a temporary directory that won't clash with other running
# libtool processes, and avoids race conditions if possible. If
# given, BASENAME is the basename for that directory.
func_mktempdir ()
{
$debug_cmd
_G_template=${TMPDIR-/tmp}/${1-$progname}
if test : = "$opt_dry_run"; then
# Return a directory name, but don't create it in dry-run mode
_G_tmpdir=$_G_template-$$
else
# If mktemp works, use that first and foremost
_G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null`
if test ! -d "$_G_tmpdir"; then
# Failing that, at least try and use $RANDOM to avoid a race
_G_tmpdir=$_G_template-${RANDOM-0}$$
func_mktempdir_umask=`umask`
umask 0077
$MKDIR "$_G_tmpdir"
umask $func_mktempdir_umask
fi
# If we're not in dry-run mode, bomb out on failure
test -d "$_G_tmpdir" || \
func_fatal_error "cannot create temporary directory '$_G_tmpdir'"
fi
$ECHO "$_G_tmpdir"
}
# 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.
func_normal_abspath ()
{
$debug_cmd
# These SED scripts presuppose an absolute path with a trailing slash.
_G_pathcar='s|^/\([^/]*\).*$|\1|'
_G_pathcdr='s|^/[^/]*||'
_G_removedotparts=':dotsl
s|/\./|/|g
t dotsl
s|/\.$|/|'
_G_collapseslashes='s|/\{1,\}|/|g'
_G_finalslash='s|/*$|/|'
# 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 "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_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 "$_G_pathcar"`
func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
-e "$_G_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_append func_normal_abspath_result "/$func_normal_abspath_tcompone
nt"
;;
esac
done
# Restore leading double-slash if one was found on entry.
func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abs
path_result
}
# func_notquiet ARG...
# --------------------
# Echo program name prefixed message only when not in quiet mode.
func_notquiet ()
{
$debug_cmd
$opt_quiet || func_echo ${1+"$@"}
# A bug in bash halts the script if the last line of a function
# fails when set -e is in force, so we need another command to
# work around that:
:
}
# func_relative_path SRCDIR DSTDIR
# --------------------------------
# Set func_relative_path_result to the relative path from SRCDIR to DSTDIR.
func_relative_path ()
{
$debug_cmd
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_t
bindir"
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 -z "$func_relative_path_tlibdir"; 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
# 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 -n "$func_stripname_result"; then
func_append func_relative_path_result "/$func_stripname_result"
fi
# Normalisation. If bindir is libdir, return '.' else relative path.
if test -n "$func_relative_path_result"; then
func_stripname './' '' "$func_relative_path_result"
func_relative_path_result=$func_stripname_result
fi
test -n "$func_relative_path_result" || func_relative_path_result=.
:
}
# func_quote_for_eval ARG...
# --------------------------
# Aesthetically quote ARGs to be evaled later.
# This function returns two values:
# i) func_quote_for_eval_result
# double-quoted, suitable for a subsequent eval
# ii) func_quote_for_eval_unquoted_result
# has all characters that are still active within double
# quotes backslashified.
func_quote_for_eval ()
{
$debug_cmd
func_quote_for_eval_unquoted_result=
func_quote_for_eval_result=
while test 0 -lt $#; do
case $1 in
*[\\\`\"\$]*)
_G_unquoted_arg=`printf '%s\n' "$1" |$SED "$sed_quote_subst"` ;;
*)
_G_unquoted_arg=$1 ;;
esac
if test -n "$func_quote_for_eval_unquoted_result"; then
func_append func_quote_for_eval_unquoted_result " $_G_unquoted_arg"
else
func_append func_quote_for_eval_unquoted_result "$_G_unquoted_arg"
fi
case $_G_unquoted_arg in
# Double-quote args containing shell metacharacters to delay
# word splitting, command substitution and variable expansion
# for a subsequent eval.
# Many Bourne shells cannot handle close brackets correctly
# in scan sets, so we specify it separately.
*[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
_G_quoted_arg=\"$_G_unquoted_arg\"
;;
*)
_G_quoted_arg=$_G_unquoted_arg
;;
esac
if test -n "$func_quote_for_eval_result"; then
func_append func_quote_for_eval_result " $_G_quoted_arg"
else
func_append func_quote_for_eval_result "$_G_quoted_arg"
fi
shift
done
}
# func_quote_for_expand ARG
# -------------------------
# Aesthetically quote ARG to be evaled later; same as above,
# but do not quote variable references.
func_quote_for_expand ()
{
$debug_cmd
case $1 in
*[\\\`\"]*)
_G_arg=`$ECHO "$1" | $SED \
-e "$sed_double_quote_subst" -e "$sed_double_backslash"` ;;
*)
_G_arg=$1 ;;
esac
case $_G_arg in
# Double-quote args containing shell metacharacters to delay
# word splitting and command substitution for a subsequent eval.
# Many Bourne shells cannot handle close brackets correctly
# in scan sets, so we specify it separately.
*[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
_G_arg=\"$_G_arg\"
;;
esac
func_quote_for_expand_result=$_G_arg
}
# func_stripname PREFIX SUFFIX NAME
# ---------------------------------
# strip PREFIX and SUFFIX from NAME, and store in func_stripname_result.
# 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).
if test yes = "$_G_HAVE_XSI_OPS"; then
eval 'func_stripname ()
{
$debug_cmd
# pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
# positional parameters, so assign one to ordinary variable first.
func_stripname_result=$3
func_stripname_result=${func_stripname_result#"$1"}
func_stripname_result=${func_stripname_result%"$2"}
}'
else
func_stripname ()
{
$debug_cmd
case $2 in
.*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%
"`;;
*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;;
esac
}
fi
# func_show_eval CMD [FAIL_EXP]
# -----------------------------
# Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is
# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP
# is given, then evaluate it.
func_show_eval ()
{
$debug_cmd
_G_cmd=$1
_G_fail_exp=${2-':'}
func_quote_for_expand "$_G_cmd"
eval "func_notquiet $func_quote_for_expand_result"
$opt_dry_run || {
eval "$_G_cmd"
_G_status=$?
if test 0 -ne "$_G_status"; then
eval "(exit $_G_status); $_G_fail_exp"
fi
}
}
# func_show_eval_locale CMD [FAIL_EXP]
# ------------------------------------
# Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is
# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP
# is given, then evaluate it. Use the saved locale for evaluation.
func_show_eval_locale ()
{
$debug_cmd
_G_cmd=$1
_G_fail_exp=${2-':'}
$opt_quiet || {
func_quote_for_expand "$_G_cmd"
eval "func_echo $func_quote_for_expand_result"
}
$opt_dry_run || {
eval "$_G_user_locale
$_G_cmd"
_G_status=$?
eval "$_G_safe_locale"
if test 0 -ne "$_G_status"; then
eval "(exit $_G_status); $_G_fail_exp"
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 ()
{
$debug_cmd
case $1 in
[0-9]* | *[!a-zA-Z0-9_]*)
func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z
0-9_]/_/g'`
;;
* )
func_tr_sh_result=$1
;;
esac
}
# func_verbose ARG...
# -------------------
# Echo program name prefixed message in verbose mode only.
func_verbose ()
{
$debug_cmd
$opt_verbose && func_echo "$*"
:
}
# func_warn_and_continue ARG...
# -----------------------------
# Echo program name prefixed warning message to standard error.
func_warn_and_continue ()
{
$debug_cmd
$require_term_colors
func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2
}
# func_warning CATEGORY ARG...
# ----------------------------
# Echo program name prefixed warning message to standard error. Warning
# messages can be filtered according to CATEGORY, where this function
# elides messages where CATEGORY is not listed in the global variable
# 'opt_warning_types'.
func_warning ()
{
$debug_cmd
# CATEGORY must be in the warning_categories list!
case " $warning_categories " in
*" $1 "*) ;;
*) func_internal_error "invalid warning category '$1'" ;;
esac
_G_category=$1
shift
case " $opt_warning_types " in
*" $_G_category "*) $warning_func ${1+"$@"} ;;
esac
}
# func_sort_ver VER1 VER2
# -----------------------
# 'sort -V' is not generally available.
# Note this deviates from the version comparison in automake
# in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
# but this should suffice as we won't be specifying old
# version formats or redundant trailing .0 in bootstrap.conf.
# If we did want full compatibility then we should probably
# use m4_version_compare from autoconf.
func_sort_ver ()
{
$debug_cmd
printf '%s\n%s\n' "$1" "$2" \
| sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n
-k 9,9n
}
# func_lt_ver PREV CURR
# ---------------------
# Return true if PREV and CURR are in the correct order according to
# func_sort_ver, otherwise false. Use it like this:
#
# func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..."
func_lt_ver ()
{
$debug_cmd
test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q`
}
# Local variables:
# mode: shell-script
# sh-indentation: 2
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
# time-stamp-time-zone: "UTC"
# End:
#! /bin/sh
# Set a version string for this script.
scriptversion=2014-01-07.03; # UTC
# A portable, pluggable option parser for Bourne shell.
# Written by Gary V. Vaughan, 2010
# Copyright (C) 2010-2015 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.
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# Please report bugs or propose patches to gary@gnu.org.
## ------ ##
## Usage. ##
## ------ ##
# This file is a library for parsing options in your shell scripts along
# with assorted other useful supporting features that you can make use
# of too.
#
# For the simplest scripts you might need only:
#
# #!/bin/sh
# . relative/path/to/funclib.sh
# . relative/path/to/options-parser
# scriptversion=1.0
# func_options ${1+"$@"}
# eval set dummy "$func_options_result"; shift
# ...rest of your script...
#
# In order for the '--version' option to work, you will need to have a
# suitably formatted comment like the one at the top of this file
# starting with '# Written by ' and ending with '# warranty; '.
#
# For '-h' and '--help' to work, you will also need a one line
# description of your script's purpose in a comment directly above the
# '# Written by ' line, like the one at the top of this file.
#
# The default options also support '--debug', which will turn on shell
# execution tracing (see the comment above debug_cmd below for another
# use), and '--verbose' and the func_verbose function to allow your script
# to display verbose messages only when your user has specified
# '--verbose'.
#
# After sourcing this file, you can plug processing for additional
# options by amending the variables from the 'Configuration' section
# below, and following the instructions in the 'Option parsing'
# section further down.
## -------------- ##
## Configuration. ##
## -------------- ##
# You should override these variables in your script after sourcing this
# file so that they reflect the customisations you have added to the
# option parser.
# The usage line for option parsing errors and the start of '-h' and
# '--help' output messages. You can embed shell variables for delayed
# expansion at the time the message is displayed, but you will need to
# quote other shell meta-characters carefully to prevent them being
# expanded when the contents are evaled.
usage='$progpath [OPTION]...'
# Short help message in response to '-h' and '--help'. Add to this or
# override it after sourcing this library to reflect the full set of
# options your script accepts.
usage_message="\
--debug enable verbose shell tracing
-W, --warnings=CATEGORY
report the warnings falling in CATEGORY [all]
-v, --verbose verbosely report processing
--version print version information and exit
-h, --help print short or long help message and exit
"
# Additional text appended to 'usage_message' in response to '--help'.
long_help_message="
Warning categories include:
'all' show all warnings
'none' turn off all the warnings
'error' warnings are treated as fatal errors"
# Help message printed before fatal option parsing errors.
fatal_help="Try '\$progname --help' for more information."
## ------------------------- ##
## Hook function management. ##
## ------------------------- ##
# This section contains functions for adding, removing, and running hooks
# to the main code. A hook is just a named list of of function, that can
# be run in order later on.
# func_hookable FUNC_NAME
# -----------------------
# Declare that FUNC_NAME will run hooks added with
# 'func_add_hook FUNC_NAME ...'.
func_hookable ()
{
$debug_cmd
func_append hookable_fns " $1"
}
# func_add_hook FUNC_NAME HOOK_FUNC
# ---------------------------------
# Request that FUNC_NAME call HOOK_FUNC before it returns. FUNC_NAME must
# first have been declared "hookable" by a call to 'func_hookable'.
func_add_hook ()
{
$debug_cmd
case " $hookable_fns " in
*" $1 "*) ;;
*) func_fatal_error "'$1' does not accept hook functions." ;;
esac
eval func_append ${1}_hooks '" $2"'
}
# func_remove_hook FUNC_NAME HOOK_FUNC
# ------------------------------------
# Remove HOOK_FUNC from the list of functions called by FUNC_NAME.
func_remove_hook ()
{
$debug_cmd
eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`'
}
# func_run_hooks FUNC_NAME [ARG]...
# ---------------------------------
# Run all hook functions registered to FUNC_NAME.
# It is assumed that the list of hook functions contains nothing more
# than a whitespace-delimited list of legal shell function names, and
# no effort is wasted trying to catch shell meta-characters or preserve
# whitespace.
func_run_hooks ()
{
$debug_cmd
case " $hookable_fns " in
*" $1 "*) ;;
*) func_fatal_error "'$1' does not support hook funcions.n" ;;
esac
eval _G_hook_fns=\$$1_hooks; shift
for _G_hook in $_G_hook_fns; do
eval $_G_hook '"$@"'
# store returned options list back into positional
# parameters for next 'cmd' execution.
eval _G_hook_result=\$${_G_hook}_result
eval set dummy "$_G_hook_result"; shift
done
func_quote_for_eval ${1+"$@"}
func_run_hooks_result=$func_quote_for_eval_result
}
## --------------- ##
## Option parsing. ##
## --------------- ##
# In order to add your own option parsing hooks, you must accept the
# full positional parameter list in your hook function, remove any
# options that you action, and then pass back the remaining unprocessed
# options in '<hooked_function_name>_result', escaped suitably for
# 'eval'. Like this:
#
# my_options_prep ()
# {
# $debug_cmd
#
# # Extend the existing usage message.
# usage_message=$usage_message'
# -s, --silent don'\''t print informational messages
# '
#
# func_quote_for_eval ${1+"$@"}
# my_options_prep_result=$func_quote_for_eval_result
# }
# func_add_hook func_options_prep my_options_prep
#
#
# my_silent_option ()
# {
# $debug_cmd
#
# # Note that for efficiency, we parse as many options as we can
# # recognise in a loop before passing the remainder back to the
# # caller on the first unrecognised argument we encounter.
# while test $# -gt 0; do
# opt=$1; shift
# case $opt in
# --silent|-s) opt_silent=: ;;
# # Separate non-argument short options:
# -s*) func_split_short_opt "$_G_opt"
# set dummy "$func_split_short_opt_name" \
# "-$func_split_short_opt_arg" ${1+"$@"}
# shift
# ;;
# *) set dummy "$_G_opt" "$*"; shift; break ;;
# esac
# done
#
# func_quote_for_eval ${1+"$@"}
# my_silent_option_result=$func_quote_for_eval_result
# }
# func_add_hook func_parse_options my_silent_option
#
#
# my_option_validation ()
# {
# $debug_cmd
#
# $opt_silent && $opt_verbose && func_fatal_help "\
# '--silent' and '--verbose' options are mutually exclusive."
#
# func_quote_for_eval ${1+"$@"}
# my_option_validation_result=$func_quote_for_eval_result
# }
# func_add_hook func_validate_options my_option_validation
#
# You'll alse need to manually amend $usage_message to reflect the extra
# options you parse. It's preferable to append if you can, so that
# multiple option parsing hooks can be added safely.
# func_options [ARG]...
# ---------------------
# All the functions called inside func_options are hookable. See the
# individual implementations for details.
func_hookable func_options
func_options ()
{
$debug_cmd
func_options_prep ${1+"$@"}
eval func_parse_options \
${func_options_prep_result+"$func_options_prep_result"}
eval func_validate_options \
${func_parse_options_result+"$func_parse_options_result"}
eval func_run_hooks func_options \
${func_validate_options_result+"$func_validate_options_result"}
# save modified positional parameters for caller
func_options_result=$func_run_hooks_result
}
# func_options_prep [ARG]...
# --------------------------
# All initialisations required before starting the option parse loop.
# Note that when calling hook functions, we pass through the list of
# positional parameters. If a hook function modifies that list, and
# needs to propogate that back to rest of this script, then the complete
# modified list must be put in 'func_run_hooks_result' before
# returning.
func_hookable func_options_prep
func_options_prep ()
{
$debug_cmd
# Option defaults:
opt_verbose=false
opt_warning_types=
func_run_hooks func_options_prep ${1+"$@"}
# save modified positional parameters for caller
func_options_prep_result=$func_run_hooks_result
}
# func_parse_options [ARG]...
# ---------------------------
# The main option parsing loop.
func_hookable func_parse_options
func_parse_options ()
{ {
my_directory_path="$1" $debug_cmd
my_dir_list=
if test -n "$my_directory_path" && test "$opt_dry_run" != ":"; then func_parse_options_result=
# Protect directory names starting with `-' # this just eases exit handling
case $my_directory_path in while test $# -gt 0; do
-*) my_directory_path="./$my_directory_path" ;; # Defer to hook functions for initial option parsing, so they
esac # get priority in the event of reusing an option name.
func_run_hooks func_parse_options ${1+"$@"}
# While some portion of DIR does not yet exist... # Adjust func_parse_options positional parameters to match
while test ! -d "$my_directory_path"; do eval set dummy "$func_run_hooks_result"; shift
# ...make a list in topmost first order. Use a colon delimited
# list incase some portion of path contains whitespace.
my_dir_list="$my_directory_path:$my_dir_list"
# If the last portion added has no slash in it, the list is done # Break out of the loop if we already parsed every option.
case $my_directory_path in */*) ;; *) break ;; esac test $# -gt 0 || break
# ...otherwise throw away the child directory and loop _G_opt=$1
my_directory_path=`$ECHO "$my_directory_path" | $SED -e "$dirname"` shift
done case $_G_opt in
my_dir_list=`$ECHO "$my_dir_list" | $SED 's,:*$,,'` --debug|-x) debug_cmd='set -x'
func_echo "enabling shell trace mode"
$debug_cmd
;;
--no-warnings|--no-warning|--no-warn)
set dummy --warnings none ${1+"$@"}
shift
;;
save_mkdir_p_IFS="$IFS"; IFS=':' --warnings|--warning|-W)
for my_dir in $my_dir_list; do test $# = 0 && func_missing_arg $_G_opt && break
IFS="$save_mkdir_p_IFS" case " $warning_categories $1" in
# mkdir can fail with a `File exist' error if two processes *" $1 "*)
# try to create one of the directories concurrently. Don't # trailing space prevents matching last $1 above
# stop in that case! func_append_uniq opt_warning_types " $1"
$MKDIR "$my_dir" 2>/dev/null || : ;;
done *all)
IFS="$save_mkdir_p_IFS" opt_warning_types=$warning_categories
;;
*none)
opt_warning_types=none
warning_func=:
;;
*error)
opt_warning_types=$warning_categories
warning_func=func_fatal_error
;;
*)
func_fatal_error \
"unsupported warning category: '$1'"
;;
esac
shift
;;
--verbose|-v) opt_verbose=: ;;
--version) func_version ;;
-\?|-h) func_usage ;;
--help) func_help ;;
# Separate optargs to long options (plugins may need this):
--*=*) func_split_equals "$_G_opt"
set dummy "$func_split_equals_lhs" \
"$func_split_equals_rhs" ${1+"$@"}
shift
;;
# Separate optargs to short options:
-W*)
func_split_short_opt "$_G_opt"
set dummy "$func_split_short_opt_name" \
"$func_split_short_opt_arg" ${1+"$@"}
shift
;;
# Separate non-argument short options:
-\?*|-h*|-v*|-x*)
func_split_short_opt "$_G_opt"
set dummy "$func_split_short_opt_name" \
"-$func_split_short_opt_arg" ${1+"$@"}
shift
;;
--) break ;;
-*) func_fatal_help "unrecognised option: '$_G_opt'" ;;
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
esac
done
# Bail out if we (or some other process) failed to create a directory. # save modified positional parameters for caller
test -d "$my_directory_path" || \ func_quote_for_eval ${1+"$@"}
func_fatal_error "Failed to create \`$1'" func_parse_options_result=$func_quote_for_eval_result
fi
} }
# func_mktempdir [string] # func_validate_options [ARG]...
# Make a temporary directory that won't clash with other running # ------------------------------
# libtool processes, and avoids race conditions if possible. If # Perform any sanity checks on option settings and/or unconsumed
# given, STRING is the basename for that directory. # arguments.
func_mktempdir () func_hookable func_validate_options
func_validate_options ()
{ {
my_template="${TMPDIR-/tmp}/${1-$progname}" $debug_cmd
if test "$opt_dry_run" = ":"; then # Display all warnings if -W was not given.
# Return a directory name, but don't create it in dry-run mode test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
my_tmpdir="${my_template}-$$"
else
# If mktemp works, use that first and foremost func_run_hooks func_validate_options ${1+"$@"}
my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null`
if test ! -d "$my_tmpdir"; then # Bail if the options were screwed!
# Failing that, at least try and use $RANDOM to avoid a race $exit_cmd $EXIT_FAILURE
my_tmpdir="${my_template}-${RANDOM-0}$$"
save_mktempdir_umask=`umask` # save modified positional parameters for caller
umask 0077 func_validate_options_result=$func_run_hooks_result
$MKDIR "$my_tmpdir" }
umask $save_mktempdir_umask
fi
# If we're not in dry-run mode, bomb out on failure ## ----------------- ##
test -d "$my_tmpdir" || \ ## Helper functions. ##
func_fatal_error "cannot create temporary directory \`$my_tmpdir'" ## ----------------- ##
fi
$ECHO "$my_tmpdir" # This section contains the helper functions used by the rest of the
} # hookable option parser framework in ascii-betical order.
# func_quote_for_eval arg # func_fatal_help ARG...
# Aesthetically quote ARG to be evaled later. # ----------------------
# This function returns two values: FUNC_QUOTE_FOR_EVAL_RESULT # Echo program name prefixed message to standard error, followed by
# is double-quoted, suitable for a subsequent eval, whereas # a help hint, and exit.
# FUNC_QUOTE_FOR_EVAL_UNQUOTED_RESULT has merely all characters func_fatal_help ()
# which are still active within double quotes backslashified.
func_quote_for_eval ()
{ {
case $1 in $debug_cmd
*[\\\`\"\$]*)
func_quote_for_eval_unquoted_result=`$ECHO "$1" | $SED "$sed_quote_subst"
` ;;
*)
func_quote_for_eval_unquoted_result="$1" ;;
esac
case $func_quote_for_eval_unquoted_result in eval \$ECHO \""Usage: $usage"\"
# Double-quote args containing shell metacharacters to delay eval \$ECHO \""$fatal_help"\"
# word splitting, command substitution and and variable func_error ${1+"$@"}
# expansion for a subsequent eval. exit $EXIT_FAILURE
# Many Bourne shells cannot handle close brackets correctly
# in scan sets, so we specify it separately.
*[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
func_quote_for_eval_result="\"$func_quote_for_eval_unquoted_result\""
;;
*)
func_quote_for_eval_result="$func_quote_for_eval_unquoted_result"
esac
} }
# func_quote_for_expand arg # func_help
# Aesthetically quote ARG to be evaled later; same as above, # ---------
# but do not quote variable references. # Echo long help message to standard output and exit.
func_quote_for_expand () func_help ()
{ {
case $1 in $debug_cmd
*[\\\`\"]*)
my_arg=`$ECHO "$1" | $SED \
-e "$double_quote_subst" -e "$sed_double_backslash"` ;;
*)
my_arg="$1" ;;
esac
case $my_arg in
# Double-quote args containing shell metacharacters to delay
# word splitting and command substitution for a subsequent eval.
# Many Bourne shells cannot handle close brackets correctly
# in scan sets, so we specify it separately.
*[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
my_arg="\"$my_arg\""
;;
esac
func_quote_for_expand_result="$my_arg" func_usage_message
$ECHO "$long_help_message"
exit 0
} }
# func_show_eval cmd [fail_exp] # func_missing_arg ARGNAME
# Unless opt_silent is true, then output CMD. Then, if opt_dryrun is # ------------------------
# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # Echo program name prefixed message to standard error and set global
# is given, then evaluate it. # exit_cmd.
func_show_eval () func_missing_arg ()
{ {
my_cmd="$1" $debug_cmd
my_fail_exp="${2-:}"
${opt_silent-false} || {
func_quote_for_expand "$my_cmd"
eval "func_echo $func_quote_for_expand_result"
}
if ${opt_dry_run-false}; then :; else func_error "Missing argument for '$1'."
eval "$my_cmd" exit_cmd=exit
my_status=$?
if test "$my_status" -eq 0; then :; else
eval "(exit $my_status); $my_fail_exp"
fi
fi
} }
# func_show_eval_locale cmd [fail_exp] # func_split_equals STRING
# Unless opt_silent is true, then output CMD. Then, if opt_dryrun is # ------------------------
# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # Set func_split_equals_lhs and func_split_equals_rhs shell variables after
# is given, then evaluate it. Use the saved locale for evaluation. # splitting STRING at the '=' sign.
func_show_eval_locale () test -z "$_G_HAVE_XSI_OPS" \
{ && (eval 'x=a/b/c;
my_cmd="$1" test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
my_fail_exp="${2-:}" && _G_HAVE_XSI_OPS=yes
if test yes = "$_G_HAVE_XSI_OPS"
then
# This is an XSI compatible shell, allowing a faster implementation...
eval 'func_split_equals ()
{
$debug_cmd
${opt_silent-false} || { func_split_equals_lhs=${1%%=*}
func_quote_for_expand "$my_cmd" func_split_equals_rhs=${1#*=}
eval "func_echo $func_quote_for_expand_result" test "x$func_split_equals_lhs" = "x$1" \
} && func_split_equals_rhs=
}'
else
# ...otherwise fall back to using expr, which is often a shell builtin.
func_split_equals ()
{
$debug_cmd
if ${opt_dry_run-false}; then :; else func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'`
eval "$lt_user_locale func_split_equals_rhs=
$my_cmd" test "x$func_split_equals_lhs" = "x$1" \
my_status=$? || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'`
eval "$lt_safe_locale" }
if test "$my_status" -eq 0; then :; else fi #func_split_equals
eval "(exit $my_status); $my_fail_exp"
fi
fi
}
# func_tr_sh # func_split_short_opt SHORTOPT
# Turn $1 into a string suitable for a shell variable name. # -----------------------------
# Result is stored in $func_tr_sh_result. All characters # Set func_split_short_opt_name and func_split_short_opt_arg shell
# not in the set a-zA-Z0-9_ are replaced with '_'. Further, # variables after splitting SHORTOPT after the 2nd character.
# if $1 begins with a digit, a '_' is prepended as well. if test yes = "$_G_HAVE_XSI_OPS"
func_tr_sh () then
{ # This is an XSI compatible shell, allowing a faster implementation...
case $1 in eval 'func_split_short_opt ()
[0-9]* | *[!a-zA-Z0-9_]*) {
func_tr_sh_result=`$ECHO "$1" | $SED 's/^\([0-9]\)/_\1/; s/[^a-zA-Z0-9_]/_/g $debug_cmd
'`
;;
* )
func_tr_sh_result=$1
;;
esac
}
# func_version func_split_short_opt_arg=${1#??}
# Echo version message to standard output and exit. func_split_short_opt_name=${1%"$func_split_short_opt_arg"}
func_version () }'
{ else
$opt_debug # ...otherwise fall back to using expr, which is often a shell builtin.
func_split_short_opt ()
{
$debug_cmd
$SED -n '/(C)/!b go func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'`
:more func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'`
/\./!{ }
N fi #func_split_short_opt
s/\n# / /
b more
}
:go
/^# '$PROGRAM' (GNU /,/# warranty; / {
s/^# //
s/^# *$//
s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/
p
}' < "$progpath"
exit $?
}
# func_usage # func_usage
# ----------
# Echo short help message to standard output and exit. # Echo short help message to standard output and exit.
func_usage () func_usage ()
{ {
$opt_debug $debug_cmd
$SED -n '/^# Usage:/,/^# *.*--help/ { func_usage_message
s/^# // $ECHO "Run '$progname --help |${PAGER-more}' for full usage"
s/^# *$// exit 0
s/\$progname/'$progname'/
p
}' < "$progpath"
echo
$ECHO "run \`$progname --help | more' for full usage"
exit $?
} }
# func_help [NOEXIT] # func_usage_message
# Echo long help message to standard output and exit, # ------------------
# unless 'noexit' is passed as argument. # Echo short help message to standard output.
func_help () func_usage_message ()
{ {
$opt_debug $debug_cmd
$SED -n '/^# Usage:/,/# Report bugs to/ { eval \$ECHO \""Usage: $usage"\"
:print echo
s/^# // $SED -n 's|^# ||
s/^# *$// /^Written by/{
s*\$progname*'$progname'* x;p;x
s*\$host*'"$host"'* }
s*\$SHELL*'"$SHELL"'* h
s*\$LTCC*'"$LTCC"'* /^Written by/q' < "$progpath"
s*\$LTCFLAGS*'"$LTCFLAGS"'* echo
s*\$LD*'"$LD"'* eval \$ECHO \""$usage_message"\"
s/\$with_gnu_ld/'"$with_gnu_ld"'/
s/\$automake_version/'"`(${AUTOMAKE-automake} --version) 2>/dev/null |$SE
D 1q`"'/
s/\$autoconf_version/'"`(${AUTOCONF-autoconf} --version) 2>/dev/null |$SE
D 1q`"'/
p
d
}
/^# .* home page:/b print
/^# General help using/b print
' < "$progpath"
ret=$?
if test -z "$1"; then
exit $ret
fi
} }
# func_missing_arg argname # func_version
# Echo program name prefixed message to standard error and set global # ------------
# exit_cmd. # Echo version message to standard output and exit.
func_missing_arg () func_version ()
{ {
$opt_debug $debug_cmd
func_error "missing argument for $1." printf '%s\n' "$progname $scriptversion"
exit_cmd=exit $SED -n '
/(C)/!b go
:more
/\./!{
N
s|\n# | |
b more
}
:go
/^# Written by /,/# warranty; / {
s|^# ||
s|^# *$||
s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2|
p
}
/^# Written by / {
s|^# ||
p
}
/^warranty; /q' < "$progpath"
exit $?
} }
# func_split_short_opt shortopt # Local variables:
# Set func_split_short_opt_name and func_split_short_opt_arg shell # mode: shell-script
# variables after splitting SHORTOPT after the 2nd character. # sh-indentation: 2
func_split_short_opt () # eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
# time-stamp-time-zone: "UTC"
# End:
# Set a version string.
scriptversion='(GNU libtool) 2.4.6'
# func_echo ARG...
# ----------------
# Libtool also displays the current mode in messages, so override
# funclib.sh func_echo with this custom definition.
func_echo ()
{ {
my_sed_short_opt='1s/^\(..\).*$/\1/;q' $debug_cmd
my_sed_short_rest='1s/^..\(.*\)$/\1/;q'
func_split_short_opt_name=`$ECHO "$1" | $SED "$my_sed_short_opt"` _G_message=$*
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=: func_echo_IFS=$IFS
IFS=$nl
for _G_line in $_G_message; do
IFS=$func_echo_IFS
$ECHO "$progname${opt_mode+: $opt_mode}: $_G_line"
done
IFS=$func_echo_IFS
}
magic="%%%MAGIC variable%%%" # func_warning ARG...
magic_exe="%%%MAGIC EXE variable%%%" # -------------------
# Libtool warnings are not categorized, so override funclib.sh
# func_warning with this simpler definition.
func_warning ()
{
$debug_cmd
# Global variables. $warning_func ${1+"$@"}
nonopt= }
preserve_args=
lo2o="s/\\.lo\$/.${objext}/"
o2lo="s/\\.${objext}\$/.lo/"
extracted_archives=
extracted_serial=0
# 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 ## Options parsing. ##
# left over by shells. ## ---------------- ##
exec_cmd=
# Hook in the functions to make sure our own options are parsed during
# the option parsing loop.
usage='$progpath [OPTION]... [MODE-ARG]...'
# Short help message in response to '-h'.
usage_message="Options:
--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
--no-warnings equivalent to '-Wnone'
--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 more informational messages than default
--version print version information
-W, --warnings=CATEGORY report the warnings falling in CATEGORY [all]
-h, --help, --help-all print short, long, or detailed help message
"
# func_append var value # Additional text appended to 'usage_message' in response to '--help'.
# Append VALUE to the end of shell variable VAR. func_help ()
func_append ()
{ {
eval "${1}=\$${1}\${2}" $debug_cmd
} # func_append may be replaced by extended shell implementation
# func_append_quoted var value func_usage_message
# Quote VALUE and append to the end of shell variable VAR, separated $ECHO "$long_help_message
# 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... MODE must be one of the following:
func_arith ()
{
func_arith_result=`expr "${@}"`
} # func_arith may be replaced by extended shell implementation
# func_len string clean remove files from the build directory
# STRING may not start with a hyphen. compile compile a source file into a libtool object
func_len () execute automatically set library path, then run a program
{ finish complete the installation of libtool libraries
func_len_result=`expr "${1}" : ".*" 2>/dev/null || echo $max_cmd_len` install install libraries or executables
} # func_len may be replaced by extended shell implementation link create a library or an executable
uninstall remove libraries from an installed directory
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)
version: $progname $scriptversion Debian-2.4.6-2
automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q`
Report bugs to <bug-libtool@gnu.org>.
GNU libtool home page: <http://www.gnu.org/s/libtool/>.
General help using GNU software: <http://www.gnu.org/gethelp/>."
exit 0
}
# func_lo2o OBJECT-NAME
# ---------------------
# Transform OBJECT-NAME from a '.lo' suffix to the platform specific
# object suffix.
# func_lo2o object lo2o=s/\\.lo\$/.$objext/
func_lo2o () o2lo=s/\\.$objext\$/.lo/
{
func_lo2o_result=`$ECHO "${1}" | $SED "$lo2o"`
} # func_lo2o may be replaced by extended shell implementation
# func_xform libobj-or-source if test yes = "$_G_HAVE_XSI_OPS"; then
func_xform () eval 'func_lo2o ()
{ {
func_xform_result=`$ECHO "${1}" | $SED 's/\.[^.]*$/.lo/'` case $1 in
} # func_xform may be replaced by extended shell implementation *.lo) func_lo2o_result=${1%.lo}.$objext ;;
* ) func_lo2o_result=$1 ;;
esac
}'
# func_xform LIBOBJ-OR-SOURCE
# ---------------------------
# Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise)
# suffix to a '.lo' libtool-object suffix.
eval 'func_xform ()
{
func_xform_result=${1%.*}.lo
}'
else
# ...otherwise fall back to using sed.
func_lo2o ()
{
func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"`
}
func_xform ()
{
func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'`
}
fi
# func_fatal_configuration arg... # func_fatal_configuration ARG...
# -------------------------------
# Echo program name prefixed message to standard error, followed by # Echo program name prefixed message to standard error, followed by
# a configuration failure hint, and exit. # a configuration failure hint, and exit.
func_fatal_configuration () func_fatal_configuration ()
{ {
func_error ${1+"$@"} func__fatal_error ${1+"$@"} \
func_error "See the $PACKAGE documentation for more information." "See the $PACKAGE documentation for more information." \
func_fatal_error "Fatal configuration error." "Fatal configuration error."
} }
# func_config # func_config
# -----------
# Display the configuration for all the tags in this script. # Display the configuration for all the tags in this script.
func_config () func_config ()
{ {
re_begincf='^# ### BEGIN LIBTOOL' re_begincf='^# ### BEGIN LIBTOOL'
re_endcf='^# ### END LIBTOOL' re_endcf='^# ### END LIBTOOL'
# Default configuration. # Default configuration.
$SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath"
# Now print the configurations for the tags. # Now print the configurations for the tags.
for tagname in $taglist; do for tagname in $taglist; do
$SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagn ame\$/p" < "$progpath" $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagn ame\$/p" < "$progpath"
done done
exit $? exit $?
} }
# func_features # func_features
# -------------
# Display the features supported by this script. # Display the features supported by this script.
func_features () func_features ()
{ {
echo "host: $host" echo "host: $host"
if test "$build_libtool_libs" = yes; then if test yes = "$build_libtool_libs"; then
echo "enable shared libraries" echo "enable shared libraries"
else else
echo "disable shared libraries" echo "disable shared libraries"
fi fi
if test "$build_old_libs" = yes; then if test yes = "$build_old_libs"; then
echo "enable static libraries" echo "enable static libraries"
else else
echo "disable static libraries" echo "disable static libraries"
fi fi
exit $? exit $?
} }
# func_enable_tag tagname # func_enable_tag TAGNAME
# -----------------------
# Verify that TAGNAME is valid, and either flag an error and exit, or # Verify that TAGNAME is valid, and either flag an error and exit, or
# enable the TAGNAME tag. We also add TAGNAME to the global $taglist # enable the TAGNAME tag. We also add TAGNAME to the global $taglist
# variable here. # variable here.
func_enable_tag () func_enable_tag ()
{ {
# Global variable: # Global variable:
tagname="$1" tagname=$1
re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
sed_extractcf="/$re_begincf/,/$re_endcf/p" sed_extractcf=/$re_begincf/,/$re_endcf/p
# Validate tagname. # Validate tagname.
case $tagname in case $tagname in
*[!-_A-Za-z0-9,/]*) *[!-_A-Za-z0-9,/]*)
func_fatal_error "invalid tag name: $tagname" func_fatal_error "invalid tag name: $tagname"
;; ;;
esac esac
# Don't test for the "default" C tag, as we know it's # Don't test for the "default" C tag, as we know it's
# there but not specially marked. # there but not specially marked.
case $tagname in case $tagname in
CC) ;; CC) ;;
*) *)
if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
taglist="$taglist $tagname" taglist="$taglist $tagname"
# Evaluate the configuration. Be careful to quote the path # Evaluate the configuration. Be careful to quote the path
# and the sed script, to avoid splitting on whitespace, but # and the sed script, to avoid splitting on whitespace, but
# also don't use non-portable quotes within backquotes within # also don't use non-portable quotes within backquotes within
# quotes we have to do it in 2 steps: # quotes we have to do it in 2 steps:
extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
eval "$extractedcf" eval "$extractedcf"
else else
func_error "ignoring unknown tag $tagname" func_error "ignoring unknown tag $tagname"
fi fi
;; ;;
esac esac
} }
# func_check_version_match # func_check_version_match
# ------------------------
# Ensure that we are using m4 macros, and libtool script from the same # Ensure that we are using m4 macros, and libtool script from the same
# release of libtool. # release of libtool.
func_check_version_match () func_check_version_match ()
{ {
if test "$package_revision" != "$macro_revision"; then if test "$package_revision" != "$macro_revision"; then
if test "$VERSION" != "$macro_version"; then if test "$VERSION" != "$macro_version"; then
if test -z "$macro_version"; then if test -z "$macro_version"; then
cat >&2 <<_LT_EOF cat >&2 <<_LT_EOF
$progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: Version mismatch error. This is $PACKAGE $VERSION, but the
$progname: definition of this LT_INIT comes from an older release. $progname: definition of this LT_INIT comes from an older release.
$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
$progname: and run autoconf again. $progname: and run autoconf again.
_LT_EOF _LT_EOF
else else
cat >&2 <<_LT_EOF cat >&2 <<_LT_EOF
$progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: Version mismatch error. This is $PACKAGE $VERSION, but the
$progname: definition of this LT_INIT comes from $PACKAGE $macro_version. $progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
$progname: and run autoconf again. $progname: and run autoconf again.
_LT_EOF _LT_EOF
fi fi
else else
cat >&2 <<_LT_EOF cat >&2 <<_LT_EOF
$progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package _revision, $progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package _revision,
$progname: but the definition of this LT_INIT comes from revision $macro_revisio n. $progname: but the definition of this LT_INIT comes from revision $macro_revisio n.
$progname: You should recreate aclocal.m4 with macros from revision $package_rev ision $progname: You should recreate aclocal.m4 with macros from revision $package_rev ision
$progname: of $PACKAGE $VERSION and run autoconf again. $progname: of $PACKAGE $VERSION and run autoconf again.
_LT_EOF _LT_EOF
fi fi
exit $EXIT_MISMATCH exit $EXIT_MISMATCH
fi fi
} }
# Shorthand for --mode=foo, only valid as the first argument # libtool_options_prep [ARG]...
case $1 in # -----------------------------
clean|clea|cle|cl) # Preparation for options parsed by libtool.
shift; set dummy --mode clean ${1+"$@"}; shift libtool_options_prep ()
;;
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
# 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 $debug_mode
while test $# -gt 0; do
opt="$1"
shift
case $opt in
--debug|-x) opt_debug='set -x'
func_echo "enabling shell trace mode"
$opt_debug
;;
--dry-run|--dryrun|-n)
opt_dry_run=:
;;
--config)
opt_config=:
func_config
;;
--dlopen|-dlopen)
optarg="$1"
opt_dlopen="${opt_dlopen+$opt_dlopen
}$optarg"
shift
;;
--preserve-dup-deps)
opt_preserve_dup_deps=:
;;
--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"
;;
--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:
--*=*)
func_split_long_opt "$opt"
set dummy "$func_split_long_opt_name" "$func_split_long_o
pt_arg" ${1+"$@"}
shift
;;
# Separate non-argument short options:
-\?*|-h*|-n*|-v*)
func_split_short_opt "$opt"
set dummy "$func_split_short_opt_name" "-$func_split_shor
t_opt_arg" ${1+"$@"}
shift
;;
--) break ;;
-*) func_fatal_help "unrecognized option \`$opt'" ;;
*) set dummy "$opt" ${1+"$@"}; shift; break ;;
esac
done
# Validate options: # Option defaults:
opt_config=false
# save first non-option argument opt_dlopen=
if test "$#" -gt 0; then opt_dry_run=false
nonopt="$opt" opt_help=false
shift opt_mode=
fi opt_preserve_dup_deps=false
opt_quiet=false
# preserve --debug nonopt=
test "$opt_debug" = : || func_append preserve_args " --debug" preserve_args=
case $host in # Shorthand for --mode=foo, only valid as the first argument
*cygwin* | *mingw* | *pw32* | *cegcc*) case $1 in
# don't eliminate duplications in $postdeps and $predeps clean|clea|cle|cl)
opt_duplicate_compiler_generated_deps=: shift; set dummy --mode clean ${1+"$@"}; shift
;; ;;
*) compile|compil|compi|comp|com|co|c)
opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps shift; set dummy --mode compile ${1+"$@"}; shift
;; ;;
esac 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
# Pass back the list of options.
func_quote_for_eval ${1+"$@"}
libtool_options_prep_result=$func_quote_for_eval_result
}
func_add_hook func_options_prep libtool_options_prep
# libtool_parse_options [ARG]...
# ---------------------------------
# Provide handling for libtool specific options.
libtool_parse_options ()
{
$debug_cmd
# Perform our own loop to consume as many options as possible in
# each iteration.
while test $# -gt 0; do
_G_opt=$1
shift
case $_G_opt in
--dry-run|--dryrun|-n)
opt_dry_run=:
;;
--config) func_config ;;
--dlopen|-dlopen)
opt_dlopen="${opt_dlopen+$opt_dlopen
}$1"
shift
;;
--preserve-dup-deps)
opt_preserve_dup_deps=: ;;
--features) func_features ;;
--finish) set dummy --mode finish ${1+"$@"}; shift ;;
--help) opt_help=: ;;
--help-all) opt_help=': help-all' ;;
--mode) test $# = 0 && func_missing_arg $_G_opt && break
opt_mode=$1
case $1 in
# Valid mode arguments:
clean|compile|execute|finish|install|link|relink|unins
tall) ;;
# Catch anything else as an error
*) func_error "invalid argument for $_G_opt"
exit_cmd=exit
break
;;
esac
shift
;;
--no-silent|--no-quiet)
opt_quiet=false
func_append preserve_args " $_G_opt"
;;
--no-warnings|--no-warning|--no-warn)
opt_warning=false
func_append preserve_args " $_G_opt"
;;
--no-verbose)
opt_verbose=false
func_append preserve_args " $_G_opt"
;;
--silent|--quiet)
opt_quiet=:
opt_verbose=false
func_append preserve_args " $_G_opt"
;;
--tag) test $# = 0 && func_missing_arg $_G_opt && break
opt_tag=$1
func_append preserve_args " $_G_opt $1"
func_enable_tag "$1"
shift
;;
--verbose|-v) opt_quiet=false
opt_verbose=:
func_append preserve_args " $_G_opt"
;;
$opt_help || { # An option not handled by this hook function:
# Sanity checks first: *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
func_check_version_match esac
done
if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then # save modified positional parameters for caller
func_fatal_configuration "not configured to build any kind of library" func_quote_for_eval ${1+"$@"}
libtool_parse_options_result=$func_quote_for_eval_result
}
func_add_hook func_parse_options libtool_parse_options
# libtool_validate_options [ARG]...
# ---------------------------------
# Perform any sanity checks on option settings and/or unconsumed
# arguments.
libtool_validate_options ()
{
# save first non-option argument
if test 0 -lt $#; then
nonopt=$1
shift
fi fi
# Darwin sucks # preserve --debug
eval std_shrext=\"$shrext_cmds\" test : = "$debug_cmd" || func_append preserve_args " --debug"
# Only execute mode is allowed to have -dlopen flags. case $host in
if test -n "$opt_dlopen" && test "$opt_mode" != execute; then # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452
func_error "unrecognized option \`-dlopen'" # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788
$ECHO "$help" 1>&2 *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*)
exit $EXIT_FAILURE # don't eliminate duplications in $postdeps and $predeps
fi opt_duplicate_compiler_generated_deps=:
;;
*)
opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
;;
esac
# Change the help message to a mode-specific one. $opt_help || {
generic_help="$help" # Sanity checks first:
help="Try \`$progname --help --mode=$opt_mode' for more information." func_check_version_match
}
test yes != "$build_libtool_libs" \
&& test yes != "$build_old_libs" \
&& func_fatal_configuration "not configured to build any kind of library
"
# Darwin sucks
eval std_shrext=\"$shrext_cmds\"
# Only execute mode is allowed to have -dlopen flags.
if test -n "$opt_dlopen" && test execute != "$opt_mode"; 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=$opt_mode' for more information."
}
# Bail if the options were screwed # Pass back the unparsed argument list
$exit_cmd $EXIT_FAILURE func_quote_for_eval ${1+"$@"}
} libtool_validate_options_result=$func_quote_for_eval_result
}
func_add_hook func_validate_options libtool_validate_options
# Process options as early as possible so that --help and --version
# can return quickly.
func_options ${1+"$@"}
eval set dummy "$func_options_result"; shift
## ----------- ## ## ----------- ##
## Main. ## ## Main. ##
## ----------- ## ## ----------- ##
magic='%%%MAGIC variable%%%'
magic_exe='%%%MAGIC EXE variable%%%'
# Global variables.
extracted_archives=
extracted_serial=0
# 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=
# A function that is used when there is no print builtin or printf.
func_fallback_echo ()
{
eval 'cat <<_LTECHO_EOF
$1
_LTECHO_EOF'
}
# func_generated_by_libtool
# True iff stdin has been generated by Libtool. This function is only
# a basic sanity check; it will hardly flush out determined imposters.
func_generated_by_libtool_p ()
{
$GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
}
# func_lalib_p file # func_lalib_p file
# True iff FILE is a libtool `.la' library or `.lo' object file. # True iff FILE is a libtool '.la' library or '.lo' object file.
# This function is only a basic sanity check; it will hardly flush out # This function is only a basic sanity check; it will hardly flush out
# determined imposters. # determined imposters.
func_lalib_p () func_lalib_p ()
{ {
test -f "$1" && test -f "$1" &&
$SED -e 4q "$1" 2>/dev/null \ $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p
| $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
} }
# func_lalib_unsafe_p file # func_lalib_unsafe_p file
# True iff FILE is a libtool `.la' library or `.lo' object file. # True iff FILE is a libtool '.la' library or '.lo' object file.
# This function implements the same check as func_lalib_p without # This function implements the same check as func_lalib_p without
# resorting to external programs. To this end, it redirects stdin and # resorting to external programs. To this end, it redirects stdin and
# closes it afterwards, without saving the original file descriptor. # closes it afterwards, without saving the original file descriptor.
# As a safety measure, use it only where a negative result would be # As a safety measure, use it only where a negative result would be
# fatal anyway. Works if `file' does not exist. # fatal anyway. Works if 'file' does not exist.
func_lalib_unsafe_p () func_lalib_unsafe_p ()
{ {
lalib_p=no lalib_p=no
if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then
for lalib_p_l in 1 2 3 4 for lalib_p_l in 1 2 3 4
do do
read lalib_p_line read lalib_p_line
case "$lalib_p_line" in case $lalib_p_line in
\#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;;
esac esac
done done
exec 0<&5 5<&- exec 0<&5 5<&-
fi fi
test "$lalib_p" = yes test yes = "$lalib_p"
} }
# func_ltwrapper_script_p file # func_ltwrapper_script_p file
# True iff FILE is a libtool wrapper script # True iff FILE is a libtool wrapper script
# This function is only a basic sanity check; it will hardly flush out # This function is only a basic sanity check; it will hardly flush out
# determined imposters. # determined imposters.
func_ltwrapper_script_p () func_ltwrapper_script_p ()
{ {
func_lalib_p "$1" test -f "$1" &&
$lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p
} }
# func_ltwrapper_executable_p file # func_ltwrapper_executable_p file
# True iff FILE is a libtool wrapper executable # True iff FILE is a libtool wrapper executable
# This function is only a basic sanity check; it will hardly flush out # This function is only a basic sanity check; it will hardly flush out
# determined imposters. # determined imposters.
func_ltwrapper_executable_p () func_ltwrapper_executable_p ()
{ {
func_ltwrapper_exec_suffix= func_ltwrapper_exec_suffix=
case $1 in case $1 in
skipping to change at line 1257 skipping to change at line 2475
} }
# func_ltwrapper_scriptname file # func_ltwrapper_scriptname file
# Assumes file is an ltwrapper_executable # Assumes file is an ltwrapper_executable
# uses $file to determine the appropriate filename for a # uses $file to determine the appropriate filename for a
# temporary ltwrapper_script. # temporary ltwrapper_script.
func_ltwrapper_scriptname () func_ltwrapper_scriptname ()
{ {
func_dirname_and_basename "$1" "" "." func_dirname_and_basename "$1" "" "."
func_stripname '' '.exe' "$func_basename_result" func_stripname '' '.exe' "$func_basename_result"
func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripn ame_result}_ltshwrapper" func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripna me_result}_ltshwrapper
} }
# func_ltwrapper_p file # func_ltwrapper_p file
# True iff FILE is a libtool wrapper script or wrapper executable # True iff FILE is a libtool wrapper script or wrapper executable
# This function is only a basic sanity check; it will hardly flush out # This function is only a basic sanity check; it will hardly flush out
# determined imposters. # determined imposters.
func_ltwrapper_p () func_ltwrapper_p ()
{ {
func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1"
} }
# func_execute_cmds commands fail_cmd # func_execute_cmds commands fail_cmd
# Execute tilde-delimited COMMANDS. # Execute tilde-delimited COMMANDS.
# If FAIL_CMD is given, eval that upon failure. # If FAIL_CMD is given, eval that upon failure.
# FAIL_CMD may read-access the current command in variable CMD! # FAIL_CMD may read-access the current command in variable CMD!
func_execute_cmds () func_execute_cmds ()
{ {
$opt_debug $debug_cmd
save_ifs=$IFS; IFS='~' save_ifs=$IFS; IFS='~'
for cmd in $1; do for cmd in $1; do
IFS=$save_ifs IFS=$sp$nl
eval cmd=\"$cmd\" eval cmd=\"$cmd\"
IFS=$save_ifs
func_show_eval "$cmd" "${2-:}" func_show_eval "$cmd" "${2-:}"
done done
IFS=$save_ifs IFS=$save_ifs
} }
# func_source file # func_source file
# Source FILE, adding directory component if necessary. # Source FILE, adding directory component if necessary.
# Note that it is not necessary on cygwin/mingw to append a dot to # Note that it is not necessary on cygwin/mingw to append a dot to
# FILE even if both FILE and FILE.exe exist: automatic-append-.exe # FILE even if both FILE and FILE.exe exist: automatic-append-.exe
# behavior happens only for exec(3), not for open(2)! Also, sourcing # behavior happens only for exec(3), not for open(2)! Also, sourcing
# `FILE.' does not work on cygwin managed mounts. # 'FILE.' does not work on cygwin managed mounts.
func_source () func_source ()
{ {
$opt_debug $debug_cmd
case $1 in case $1 in
*/* | *\\*) . "$1" ;; */* | *\\*) . "$1" ;;
*) . "./$1" ;; *) . "./$1" ;;
esac esac
} }
# func_resolve_sysroot PATH # func_resolve_sysroot PATH
# Replace a leading = in PATH with a sysroot. Store the result into # Replace a leading = in PATH with a sysroot. Store the result into
# func_resolve_sysroot_result # func_resolve_sysroot_result
func_resolve_sysroot () func_resolve_sysroot ()
skipping to change at line 1319 skipping to change at line 2540
func_resolve_sysroot_result=$lt_sysroot$func_stripname_result func_resolve_sysroot_result=$lt_sysroot$func_stripname_result
;; ;;
esac esac
} }
# func_replace_sysroot PATH # func_replace_sysroot PATH
# If PATH begins with the sysroot, replace it with = and # If PATH begins with the sysroot, replace it with = and
# store the result into func_replace_sysroot_result. # store the result into func_replace_sysroot_result.
func_replace_sysroot () func_replace_sysroot ()
{ {
case "$lt_sysroot:$1" in case $lt_sysroot:$1 in
?*:"$lt_sysroot"*) ?*:"$lt_sysroot"*)
func_stripname "$lt_sysroot" '' "$1" func_stripname "$lt_sysroot" '' "$1"
func_replace_sysroot_result="=$func_stripname_result" func_replace_sysroot_result='='$func_stripname_result
;; ;;
*) *)
# Including no sysroot. # Including no sysroot.
func_replace_sysroot_result=$1 func_replace_sysroot_result=$1
;; ;;
esac esac
} }
# func_infer_tag arg # func_infer_tag arg
# Infer tagged configuration to use if any are available and # Infer tagged configuration to use if any are available and
# if one wasn't chosen via the "--tag" command line option. # if one wasn't chosen via the "--tag" command line option.
# Only attempt this if the compiler in the base compile # Only attempt this if the compiler in the base compile
# command doesn't match the default compiler. # command doesn't match the default compiler.
# arg is usually of the form 'gcc ...' # arg is usually of the form 'gcc ...'
func_infer_tag () func_infer_tag ()
{ {
$opt_debug $debug_cmd
if test -n "$available_tags" && test -z "$tagname"; then if test -n "$available_tags" && test -z "$tagname"; then
CC_quoted= CC_quoted=
for arg in $CC; do for arg in $CC; do
func_append_quoted CC_quoted "$arg" func_append_quoted CC_quoted "$arg"
done done
CC_expanded=`func_echo_all $CC` CC_expanded=`func_echo_all $CC`
CC_quoted_expanded=`func_echo_all $CC_quoted` CC_quoted_expanded=`func_echo_all $CC_quoted`
case $@ in case $@ in
# Blanks in the command may have been stripped by the calling shell, # Blanks in the command may have been stripped by the calling shell,
# but not from the CC environment variable when configure was run. # but not from the CC environment variable when configure was run.
" $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
" $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_e xpanded "*) ;; " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_e xpanded "*) ;;
# Blanks at the start of $base_compile will cause this to fail # Blanks at the start of $base_compile will cause this to fail
# if we don't check for them as well. # if we don't check for them as well.
*) *)
for z in $available_tags; do for z in $available_tags; do
if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/nu ll; then if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/nu ll; then
# Evaluate the configuration. # Evaluate the configuration.
eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### E ND LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
CC_quoted= CC_quoted=
for arg in $CC; do for arg in $CC; do
# Double-quote args containing other shell metacharacters. # Double-quote args containing other shell metacharacters.
func_append_quoted CC_quoted "$arg" func_append_quoted CC_quoted "$arg"
done done
CC_expanded=`func_echo_all $CC` CC_expanded=`func_echo_all $CC`
CC_quoted_expanded=`func_echo_all $CC_quoted` CC_quoted_expanded=`func_echo_all $CC_quoted`
case "$@ " in case "$@ " in
" $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
" $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quo ted_expanded "*) " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quo ted_expanded "*)
skipping to change at line 1383 skipping to change at line 2605
break break
;; ;;
esac esac
fi fi
done done
# If $tagname still isn't set, then no tagged configuration # If $tagname still isn't set, then no tagged configuration
# was found and let the user know that the "--tag" command # was found and let the user know that the "--tag" command
# line option must be used. # line option must be used.
if test -z "$tagname"; then if test -z "$tagname"; then
func_echo "unable to infer tagged configuration" func_echo "unable to infer tagged configuration"
func_fatal_error "specify a tag with \`--tag'" func_fatal_error "specify a tag with '--tag'"
# else # else
# func_verbose "using $tagname tagged configuration" # func_verbose "using $tagname tagged configuration"
fi fi
;; ;;
esac esac
fi fi
} }
# func_write_libtool_object output_name pic_name nonpic_name # func_write_libtool_object output_name pic_name nonpic_name
# Create a libtool object file (analogous to a ".la" file), # Create a libtool object file (analogous to a ".la" file),
# but don't create it if we're doing a dry run. # but don't create it if we're doing a dry run.
func_write_libtool_object () func_write_libtool_object ()
{ {
write_libobj=${1} write_libobj=$1
if test "$build_libtool_libs" = yes; then if test yes = "$build_libtool_libs"; then
write_lobj=\'${2}\' write_lobj=\'$2\'
else else
write_lobj=none write_lobj=none
fi fi
if test "$build_old_libs" = yes; then if test yes = "$build_old_libs"; then
write_oldobj=\'${3}\' write_oldobj=\'$3\'
else else
write_oldobj=none write_oldobj=none
fi fi
$opt_dry_run || { $opt_dry_run || {
cat >${write_libobj}T <<EOF cat >${write_libobj}T <<EOF
# $write_libobj - a libtool object file # $write_libobj - a libtool object file
# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION # Generated by $PROGRAM (GNU $PACKAGE) $VERSION
# #
# Please DO NOT delete this file! # Please DO NOT delete this file!
# It is necessary for linking the library. # It is necessary for linking the library.
# Name of the PIC object. # Name of the PIC object.
pic_object=$write_lobj pic_object=$write_lobj
# Name of the non-PIC object # Name of the non-PIC object
non_pic_object=$write_oldobj non_pic_object=$write_oldobj
EOF EOF
$MV "${write_libobj}T" "${write_libobj}" $MV "${write_libobj}T" "$write_libobj"
} }
} }
################################################## ##################################################
# FILE NAME AND PATH CONVERSION HELPER FUNCTIONS # # FILE NAME AND PATH CONVERSION HELPER FUNCTIONS #
################################################## ##################################################
# func_convert_core_file_wine_to_w32 ARG # func_convert_core_file_wine_to_w32 ARG
# Helper function used by file name conversion functions when $build is *nix, # 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 # and $host is mingw, cygwin, or some other w32 environment. Relies on a
# correctly configured wine environment available, with the winepath program # correctly configured wine environment available, with the winepath program
# in $build's $PATH. # in $build's $PATH.
# #
# ARG is the $build file name to be converted to w32 format. # 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 # Result is available in $func_convert_core_file_wine_to_w32_result, and will
# be empty on error (or when ARG is empty) # be empty on error (or when ARG is empty)
func_convert_core_file_wine_to_w32 () func_convert_core_file_wine_to_w32 ()
{ {
$opt_debug $debug_cmd
func_convert_core_file_wine_to_w32_result="$1"
func_convert_core_file_wine_to_w32_result=$1
if test -n "$1"; then if test -n "$1"; then
# Unfortunately, winepath does not exit with a non-zero error code, so we # 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 # 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 # 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 # *an error message* to stdout. So we must check for both error code of
# zero AND non-empty stdout, which explains the odd construction: # zero AND non-empty stdout, which explains the odd construction:
func_convert_core_file_wine_to_w32_tmp=`winepath -w "$1" 2>/dev/null` 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}"; t hen if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; the n
func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_ wine_to_w32_tmp" | func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_ wine_to_w32_tmp" |
$SED -e "$lt_sed_naive_backslashify"` $SED -e "$sed_naive_backslashify"`
else else
func_convert_core_file_wine_to_w32_result= func_convert_core_file_wine_to_w32_result=
fi fi
fi fi
} }
# end: func_convert_core_file_wine_to_w32 # end: func_convert_core_file_wine_to_w32
# func_convert_core_path_wine_to_w32 ARG # func_convert_core_path_wine_to_w32 ARG
# Helper function used by path conversion functions when $build is *nix, and # 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 # $host is mingw, cygwin, or some other w32 environment. Relies on a correctly
# configured wine environment available, with the winepath program in $build's # configured wine environment available, with the winepath program in $build's
# $PATH. Assumes ARG has no leading or trailing path separator characters. # $PATH. Assumes ARG has no leading or trailing path separator characters.
# #
# ARG is path to be converted from $build format to win32. # ARG is path to be converted from $build format to win32.
# Result is available in $func_convert_core_path_wine_to_w32_result. # Result is available in $func_convert_core_path_wine_to_w32_result.
# Unconvertible file (directory) names in ARG are skipped; if no directory names # Unconvertible file (directory) names in ARG are skipped; if no directory names
# are convertible, then the result may be empty. # are convertible, then the result may be empty.
func_convert_core_path_wine_to_w32 () func_convert_core_path_wine_to_w32 ()
{ {
$opt_debug $debug_cmd
# unfortunately, winepath doesn't convert paths, only file names # unfortunately, winepath doesn't convert paths, only file names
func_convert_core_path_wine_to_w32_result="" func_convert_core_path_wine_to_w32_result=
if test -n "$1"; then if test -n "$1"; then
oldIFS=$IFS oldIFS=$IFS
IFS=: IFS=:
for func_convert_core_path_wine_to_w32_f in $1; do for func_convert_core_path_wine_to_w32_f in $1; do
IFS=$oldIFS IFS=$oldIFS
func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f" 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 -n "$func_convert_core_file_wine_to_w32_result"; then
if test -z "$func_convert_core_path_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_win e_to_w32_result" func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine _to_w32_result
else else
func_append func_convert_core_path_wine_to_w32_result ";$func_convert_ core_file_wine_to_w32_result" func_append func_convert_core_path_wine_to_w32_result ";$func_convert_ core_file_wine_to_w32_result"
fi fi
fi fi
done done
IFS=$oldIFS IFS=$oldIFS
fi fi
} }
# end: func_convert_core_path_wine_to_w32 # end: func_convert_core_path_wine_to_w32
skipping to change at line 1514 skipping to change at line 2738
# or path in func_cygpath_result (input file name or path is assumed to be in # or path in func_cygpath_result (input file name or path is assumed to be in
# Cygwin format). Returns an empty string on error. # Cygwin format). Returns an empty string on error.
# #
# ARGS are passed to cygpath, with the last one being the file name or path to # ARGS are passed to cygpath, with the last one being the file name or path to
# be converted. # be converted.
# #
# Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH # Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH
# environment variable; do not put it in $PATH. # environment variable; do not put it in $PATH.
func_cygpath () func_cygpath ()
{ {
$opt_debug $debug_cmd
if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then
func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null` func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null`
if test "$?" -ne 0; then if test "$?" -ne 0; then
# on failure, ensure result is empty # on failure, ensure result is empty
func_cygpath_result= func_cygpath_result=
fi fi
else else
func_cygpath_result= func_cygpath_result=
func_error "LT_CYGPATH is empty or specifies non-existent file: \`$LT_CYGPAT H'" func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH '"
fi fi
} }
#end: func_cygpath #end: func_cygpath
# func_convert_core_msys_to_w32 ARG # func_convert_core_msys_to_w32 ARG
# Convert file name or path ARG from MSYS format to w32 format. Return # Convert file name or path ARG from MSYS format to w32 format. Return
# result in func_convert_core_msys_to_w32_result. # result in func_convert_core_msys_to_w32_result.
func_convert_core_msys_to_w32 () func_convert_core_msys_to_w32 ()
{ {
$opt_debug $debug_cmd
# awkward: cmd appends spaces to result # awkward: cmd appends spaces to result
func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null | func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null |
$SED -e 's/[ ]*$//' -e "$lt_sed_naive_backslashify"` $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"`
} }
#end: func_convert_core_msys_to_w32 #end: func_convert_core_msys_to_w32
# func_convert_file_check ARG1 ARG2 # func_convert_file_check ARG1 ARG2
# Verify that ARG1 (a file name in $build format) was converted to $host # Verify that ARG1 (a file name in $build format) was converted to $host
# format in ARG2. Otherwise, emit an error message, but continue (resetting # format in ARG2. Otherwise, emit an error message, but continue (resetting
# func_to_host_file_result to ARG1). # func_to_host_file_result to ARG1).
func_convert_file_check () func_convert_file_check ()
{ {
$opt_debug $debug_cmd
if test -z "$2" && test -n "$1" ; then
if test -z "$2" && test -n "$1"; then
func_error "Could not determine host file name corresponding to" func_error "Could not determine host file name corresponding to"
func_error " \`$1'" func_error " '$1'"
func_error "Continuing, but uninstalled executables may not work." func_error "Continuing, but uninstalled executables may not work."
# Fallback: # Fallback:
func_to_host_file_result="$1" func_to_host_file_result=$1
fi fi
} }
# end func_convert_file_check # end func_convert_file_check
# func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH # 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 # 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 # 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_to_host_file_result to a simplistic fallback value (see below).
func_convert_path_check () func_convert_path_check ()
{ {
$opt_debug $debug_cmd
if test -z "$4" && test -n "$3"; then if test -z "$4" && test -n "$3"; then
func_error "Could not determine the host path corresponding to" func_error "Could not determine the host path corresponding to"
func_error " \`$3'" func_error " '$3'"
func_error "Continuing, but uninstalled executables may not work." func_error "Continuing, but uninstalled executables may not work."
# Fallback. This is a deliberately simplistic "conversion" and # Fallback. This is a deliberately simplistic "conversion" and
# should not be "improved". See libtool.info. # should not be "improved". See libtool.info.
if test "x$1" != "x$2"; then if test "x$1" != "x$2"; then
lt_replace_pathsep_chars="s|$1|$2|g" lt_replace_pathsep_chars="s|$1|$2|g"
func_to_host_path_result=`echo "$3" | func_to_host_path_result=`echo "$3" |
$SED -e "$lt_replace_pathsep_chars"` $SED -e "$lt_replace_pathsep_chars"`
else else
func_to_host_path_result="$3" func_to_host_path_result=$3
fi fi
fi fi
} }
# end func_convert_path_check # end func_convert_path_check
# func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG # func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG
# Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT # Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT
# and appending REPL if ORIG matches BACKPAT. # and appending REPL if ORIG matches BACKPAT.
func_convert_path_front_back_pathsep () func_convert_path_front_back_pathsep ()
{ {
$opt_debug $debug_cmd
case $4 in case $4 in
$1 ) func_to_host_path_result="$3$func_to_host_path_result" $1 ) func_to_host_path_result=$3$func_to_host_path_result
;; ;;
esac esac
case $4 in case $4 in
$2 ) func_append func_to_host_path_result "$3" $2 ) func_append func_to_host_path_result "$3"
;; ;;
esac esac
} }
# end func_convert_path_front_back_pathsep # end func_convert_path_front_back_pathsep
################################################## ##################################################
# $build to $host FILE NAME CONVERSION FUNCTIONS # # $build to $host FILE NAME CONVERSION FUNCTIONS #
################################################## ##################################################
# invoked via `$to_host_file_cmd ARG' # invoked via '$to_host_file_cmd ARG'
# #
# In each case, ARG is the path to be converted from $build to $host format. # 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. # Result will be available in $func_to_host_file_result.
# func_to_host_file ARG # func_to_host_file ARG
# Converts the file name ARG from $build format to $host format. Return result # Converts the file name ARG from $build format to $host format. Return result
# in func_to_host_file_result. # in func_to_host_file_result.
func_to_host_file () func_to_host_file ()
{ {
$opt_debug $debug_cmd
$to_host_file_cmd "$1" $to_host_file_cmd "$1"
} }
# end func_to_host_file # end func_to_host_file
# func_to_tool_file ARG LAZY # func_to_tool_file ARG LAZY
# converts the file name ARG from $build format to toolchain format. Return # 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 # result in func_to_tool_file_result. If the conversion in use is listed
# in (the comma separated) LAZY, no conversion takes place. # in (the comma separated) LAZY, no conversion takes place.
func_to_tool_file () func_to_tool_file ()
{ {
$opt_debug $debug_cmd
case ,$2, in case ,$2, in
*,"$to_tool_file_cmd",*) *,"$to_tool_file_cmd",*)
func_to_tool_file_result=$1 func_to_tool_file_result=$1
;; ;;
*) *)
$to_tool_file_cmd "$1" $to_tool_file_cmd "$1"
func_to_tool_file_result=$func_to_host_file_result func_to_tool_file_result=$func_to_host_file_result
;; ;;
esac esac
} }
# end func_to_tool_file # end func_to_tool_file
# func_convert_file_noop ARG # func_convert_file_noop ARG
# Copy ARG to func_to_host_file_result. # Copy ARG to func_to_host_file_result.
func_convert_file_noop () func_convert_file_noop ()
{ {
func_to_host_file_result="$1" func_to_host_file_result=$1
} }
# end func_convert_file_noop # end func_convert_file_noop
# func_convert_file_msys_to_w32 ARG # func_convert_file_msys_to_w32 ARG
# Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic # Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic
# conversion to w32 is not available inside the cwrapper. Returns result in # conversion to w32 is not available inside the cwrapper. Returns result in
# func_to_host_file_result. # func_to_host_file_result.
func_convert_file_msys_to_w32 () func_convert_file_msys_to_w32 ()
{ {
$opt_debug $debug_cmd
func_to_host_file_result="$1"
func_to_host_file_result=$1
if test -n "$1"; then if test -n "$1"; then
func_convert_core_msys_to_w32 "$1" func_convert_core_msys_to_w32 "$1"
func_to_host_file_result="$func_convert_core_msys_to_w32_result" func_to_host_file_result=$func_convert_core_msys_to_w32_result
fi fi
func_convert_file_check "$1" "$func_to_host_file_result" func_convert_file_check "$1" "$func_to_host_file_result"
} }
# end func_convert_file_msys_to_w32 # end func_convert_file_msys_to_w32
# func_convert_file_cygwin_to_w32 ARG # func_convert_file_cygwin_to_w32 ARG
# Convert file name ARG from Cygwin to w32 format. Returns result in # Convert file name ARG from Cygwin to w32 format. Returns result in
# func_to_host_file_result. # func_to_host_file_result.
func_convert_file_cygwin_to_w32 () func_convert_file_cygwin_to_w32 ()
{ {
$opt_debug $debug_cmd
func_to_host_file_result="$1"
func_to_host_file_result=$1
if test -n "$1"; then if test -n "$1"; then
# because $build is cygwin, we call "the" cygpath in $PATH; no need to use # because $build is cygwin, we call "the" cygpath in $PATH; no need to use
# LT_CYGPATH in this case. # LT_CYGPATH in this case.
func_to_host_file_result=`cygpath -m "$1"` func_to_host_file_result=`cygpath -m "$1"`
fi fi
func_convert_file_check "$1" "$func_to_host_file_result" func_convert_file_check "$1" "$func_to_host_file_result"
} }
# end func_convert_file_cygwin_to_w32 # end func_convert_file_cygwin_to_w32
# func_convert_file_nix_to_w32 ARG # func_convert_file_nix_to_w32 ARG
# Convert file name ARG from *nix to w32 format. Requires a wine environment # 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. # and a working winepath. Returns result in func_to_host_file_result.
func_convert_file_nix_to_w32 () func_convert_file_nix_to_w32 ()
{ {
$opt_debug $debug_cmd
func_to_host_file_result="$1"
func_to_host_file_result=$1
if test -n "$1"; then if test -n "$1"; then
func_convert_core_file_wine_to_w32 "$1" func_convert_core_file_wine_to_w32 "$1"
func_to_host_file_result="$func_convert_core_file_wine_to_w32_result" func_to_host_file_result=$func_convert_core_file_wine_to_w32_result
fi fi
func_convert_file_check "$1" "$func_to_host_file_result" func_convert_file_check "$1" "$func_to_host_file_result"
} }
# end func_convert_file_nix_to_w32 # end func_convert_file_nix_to_w32
# func_convert_file_msys_to_cygwin ARG # func_convert_file_msys_to_cygwin ARG
# Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set.
# Returns result in func_to_host_file_result. # Returns result in func_to_host_file_result.
func_convert_file_msys_to_cygwin () func_convert_file_msys_to_cygwin ()
{ {
$opt_debug $debug_cmd
func_to_host_file_result="$1"
func_to_host_file_result=$1
if test -n "$1"; then if test -n "$1"; then
func_convert_core_msys_to_w32 "$1" func_convert_core_msys_to_w32 "$1"
func_cygpath -u "$func_convert_core_msys_to_w32_result" func_cygpath -u "$func_convert_core_msys_to_w32_result"
func_to_host_file_result="$func_cygpath_result" func_to_host_file_result=$func_cygpath_result
fi fi
func_convert_file_check "$1" "$func_to_host_file_result" func_convert_file_check "$1" "$func_to_host_file_result"
} }
# end func_convert_file_msys_to_cygwin # end func_convert_file_msys_to_cygwin
# func_convert_file_nix_to_cygwin ARG # func_convert_file_nix_to_cygwin ARG
# Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed # 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 a wine environment, working winepath, and LT_CYGPATH set. Returns result
# in func_to_host_file_result. # in func_to_host_file_result.
func_convert_file_nix_to_cygwin () func_convert_file_nix_to_cygwin ()
{ {
$opt_debug $debug_cmd
func_to_host_file_result="$1"
func_to_host_file_result=$1
if test -n "$1"; then if test -n "$1"; then
# convert from *nix to w32, then use cygpath to convert from w32 to cygwin. # convert from *nix to w32, then use cygpath to convert from w32 to cygwin.
func_convert_core_file_wine_to_w32 "$1" func_convert_core_file_wine_to_w32 "$1"
func_cygpath -u "$func_convert_core_file_wine_to_w32_result" func_cygpath -u "$func_convert_core_file_wine_to_w32_result"
func_to_host_file_result="$func_cygpath_result" func_to_host_file_result=$func_cygpath_result
fi fi
func_convert_file_check "$1" "$func_to_host_file_result" func_convert_file_check "$1" "$func_to_host_file_result"
} }
# end func_convert_file_nix_to_cygwin # end func_convert_file_nix_to_cygwin
############################################# #############################################
# $build to $host PATH CONVERSION FUNCTIONS # # $build to $host PATH CONVERSION FUNCTIONS #
############################################# #############################################
# invoked via `$to_host_path_cmd ARG' # invoked via '$to_host_path_cmd ARG'
# #
# In each case, ARG is the path to be converted from $build to $host format. # 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. # The result will be available in $func_to_host_path_result.
# #
# Path separators are also converted from $build format to $host format. If # 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 # ARG begins or ends with a path separator character, it is preserved (but
# converted to $host format) on output. # converted to $host format) on output.
# #
# All path conversion functions are named using the following convention: # All path conversion functions are named using the following convention:
# file name conversion function : func_convert_file_X_to_Y () # file name conversion function : func_convert_file_X_to_Y ()
skipping to change at line 1750 skipping to change at line 2986
# same. If conversion functions are added for new $build/$host combinations, # 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 # the two new functions must follow this pattern, or func_init_to_host_path_cmd
# will break. # will break.
# func_init_to_host_path_cmd # func_init_to_host_path_cmd
# Ensures that function "pointer" variable $to_host_path_cmd is set to the # Ensures that function "pointer" variable $to_host_path_cmd is set to the
# appropriate value, based on the value of $to_host_file_cmd. # appropriate value, based on the value of $to_host_file_cmd.
to_host_path_cmd= to_host_path_cmd=
func_init_to_host_path_cmd () func_init_to_host_path_cmd ()
{ {
$opt_debug $debug_cmd
if test -z "$to_host_path_cmd"; then if test -z "$to_host_path_cmd"; then
func_stripname 'func_convert_file_' '' "$to_host_file_cmd" func_stripname 'func_convert_file_' '' "$to_host_file_cmd"
to_host_path_cmd="func_convert_path_${func_stripname_result}" to_host_path_cmd=func_convert_path_$func_stripname_result
fi fi
} }
# func_to_host_path ARG # func_to_host_path ARG
# Converts the path ARG from $build format to $host format. Return result # Converts the path ARG from $build format to $host format. Return result
# in func_to_host_path_result. # in func_to_host_path_result.
func_to_host_path () func_to_host_path ()
{ {
$opt_debug $debug_cmd
func_init_to_host_path_cmd func_init_to_host_path_cmd
$to_host_path_cmd "$1" $to_host_path_cmd "$1"
} }
# end func_to_host_path # end func_to_host_path
# func_convert_path_noop ARG # func_convert_path_noop ARG
# Copy ARG to func_to_host_path_result. # Copy ARG to func_to_host_path_result.
func_convert_path_noop () func_convert_path_noop ()
{ {
func_to_host_path_result="$1" func_to_host_path_result=$1
} }
# end func_convert_path_noop # end func_convert_path_noop
# func_convert_path_msys_to_w32 ARG # func_convert_path_msys_to_w32 ARG
# Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic # Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic
# conversion to w32 is not available inside the cwrapper. Returns result in # conversion to w32 is not available inside the cwrapper. Returns result in
# func_to_host_path_result. # func_to_host_path_result.
func_convert_path_msys_to_w32 () func_convert_path_msys_to_w32 ()
{ {
$opt_debug $debug_cmd
func_to_host_path_result="$1"
func_to_host_path_result=$1
if test -n "$1"; then if test -n "$1"; then
# Remove leading and trailing path separator characters from ARG. MSYS # Remove leading and trailing path separator characters from ARG. MSYS
# behavior is inconsistent here; cygpath turns them into '.;' and ';.'; # behavior is inconsistent here; cygpath turns them into '.;' and ';.';
# and winepath ignores them completely. # and winepath ignores them completely.
func_stripname : : "$1" func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result func_to_host_path_tmp1=$func_stripname_result
func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
func_to_host_path_result="$func_convert_core_msys_to_w32_result" func_to_host_path_result=$func_convert_core_msys_to_w32_result
func_convert_path_check : ";" \ func_convert_path_check : ";" \
"$func_to_host_path_tmp1" "$func_to_host_path_result" "$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
fi fi
} }
# end func_convert_path_msys_to_w32 # end func_convert_path_msys_to_w32
# func_convert_path_cygwin_to_w32 ARG # func_convert_path_cygwin_to_w32 ARG
# Convert path ARG from Cygwin to w32 format. Returns result in # Convert path ARG from Cygwin to w32 format. Returns result in
# func_to_host_file_result. # func_to_host_file_result.
func_convert_path_cygwin_to_w32 () func_convert_path_cygwin_to_w32 ()
{ {
$opt_debug $debug_cmd
func_to_host_path_result="$1"
func_to_host_path_result=$1
if test -n "$1"; then if test -n "$1"; then
# See func_convert_path_msys_to_w32: # See func_convert_path_msys_to_w32:
func_stripname : : "$1" func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result func_to_host_path_tmp1=$func_stripname_result
func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"` func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"`
func_convert_path_check : ";" \ func_convert_path_check : ";" \
"$func_to_host_path_tmp1" "$func_to_host_path_result" "$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
fi fi
} }
# end func_convert_path_cygwin_to_w32 # end func_convert_path_cygwin_to_w32
# func_convert_path_nix_to_w32 ARG # func_convert_path_nix_to_w32 ARG
# Convert path ARG from *nix to w32 format. Requires a wine environment and # Convert path ARG from *nix to w32 format. Requires a wine environment and
# a working winepath. Returns result in func_to_host_file_result. # a working winepath. Returns result in func_to_host_file_result.
func_convert_path_nix_to_w32 () func_convert_path_nix_to_w32 ()
{ {
$opt_debug $debug_cmd
func_to_host_path_result="$1"
func_to_host_path_result=$1
if test -n "$1"; then if test -n "$1"; then
# See func_convert_path_msys_to_w32: # See func_convert_path_msys_to_w32:
func_stripname : : "$1" func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result func_to_host_path_tmp1=$func_stripname_result
func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" 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_to_host_path_result=$func_convert_core_path_wine_to_w32_result
func_convert_path_check : ";" \ func_convert_path_check : ";" \
"$func_to_host_path_tmp1" "$func_to_host_path_result" "$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
fi fi
} }
# end func_convert_path_nix_to_w32 # end func_convert_path_nix_to_w32
# func_convert_path_msys_to_cygwin ARG # func_convert_path_msys_to_cygwin ARG
# Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set.
# Returns result in func_to_host_file_result. # Returns result in func_to_host_file_result.
func_convert_path_msys_to_cygwin () func_convert_path_msys_to_cygwin ()
{ {
$opt_debug $debug_cmd
func_to_host_path_result="$1"
func_to_host_path_result=$1
if test -n "$1"; then if test -n "$1"; then
# See func_convert_path_msys_to_w32: # See func_convert_path_msys_to_w32:
func_stripname : : "$1" func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result func_to_host_path_tmp1=$func_stripname_result
func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
func_cygpath -u -p "$func_convert_core_msys_to_w32_result" func_cygpath -u -p "$func_convert_core_msys_to_w32_result"
func_to_host_path_result="$func_cygpath_result" func_to_host_path_result=$func_cygpath_result
func_convert_path_check : : \ func_convert_path_check : : \
"$func_to_host_path_tmp1" "$func_to_host_path_result" "$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" : "$1" func_convert_path_front_back_pathsep ":*" "*:" : "$1"
fi fi
} }
# end func_convert_path_msys_to_cygwin # end func_convert_path_msys_to_cygwin
# func_convert_path_nix_to_cygwin ARG # func_convert_path_nix_to_cygwin ARG
# Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a # 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 # a wine environment, working winepath, and LT_CYGPATH set. Returns result in
# func_to_host_file_result. # func_to_host_file_result.
func_convert_path_nix_to_cygwin () func_convert_path_nix_to_cygwin ()
{ {
$opt_debug $debug_cmd
func_to_host_path_result="$1"
func_to_host_path_result=$1
if test -n "$1"; then if test -n "$1"; then
# Remove leading and trailing path separator characters from # Remove leading and trailing path separator characters from
# ARG. msys behavior is inconsistent here, cygpath turns them # ARG. msys behavior is inconsistent here, cygpath turns them
# into '.;' and ';.', and winepath ignores them completely. # into '.;' and ';.', and winepath ignores them completely.
func_stripname : : "$1" func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result func_to_host_path_tmp1=$func_stripname_result
func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" 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_cygpath -u -p "$func_convert_core_path_wine_to_w32_result"
func_to_host_path_result="$func_cygpath_result" func_to_host_path_result=$func_cygpath_result
func_convert_path_check : : \ func_convert_path_check : : \
"$func_to_host_path_tmp1" "$func_to_host_path_result" "$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" : "$1" func_convert_path_front_back_pathsep ":*" "*:" : "$1"
fi fi
} }
# end func_convert_path_nix_to_cygwin # end func_convert_path_nix_to_cygwin
# func_dll_def_p FILE
# True iff FILE is a Windows DLL '.def' file.
# Keep in sync with _LT_DLL_DEF_P in libtool.m4
func_dll_def_p ()
{
$debug_cmd
func_dll_def_p_tmp=`$SED -n \
-e 's/^[ ]*//' \
-e '/^\(;.*\)*$/d' \
-e 's/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p' \
-e q \
"$1"`
test DEF = "$func_dll_def_p_tmp"
}
# func_mode_compile arg... # func_mode_compile arg...
func_mode_compile () func_mode_compile ()
{ {
$opt_debug $debug_cmd
# Get the compilation command and the source file. # Get the compilation command and the source file.
base_compile= base_compile=
srcfile="$nonopt" # always keep a non-empty value in "srcfile" srcfile=$nonopt # always keep a non-empty value in "srcfile"
suppress_opt=yes suppress_opt=yes
suppress_output= suppress_output=
arg_mode=normal arg_mode=normal
libobj= libobj=
later= later=
pie_flag= pie_flag=
for arg for arg
do do
case $arg_mode in case $arg_mode in
arg ) arg )
# do not "continue". Instead, add this to base_compile # do not "continue". Instead, add this to base_compile
lastarg="$arg" lastarg=$arg
arg_mode=normal arg_mode=normal
;; ;;
target ) target )
libobj="$arg" libobj=$arg
arg_mode=normal arg_mode=normal
continue continue
;; ;;
normal ) normal )
# Accept any command-line options. # Accept any command-line options.
case $arg in case $arg in
-o) -o)
test -n "$libobj" && \ test -n "$libobj" && \
func_fatal_error "you cannot specify \`-o' more than once" func_fatal_error "you cannot specify '-o' more than once"
arg_mode=target arg_mode=target
continue continue
;; ;;
-pie | -fpie | -fPIE) -pie | -fpie | -fPIE)
func_append pie_flag " $arg" func_append pie_flag " $arg"
continue continue
;; ;;
-shared | -static | -prefer-pic | -prefer-non-pic) -shared | -static | -prefer-pic | -prefer-non-pic)
skipping to change at line 1946 skipping to change at line 3206
-Xcompiler) -Xcompiler)
arg_mode=arg # the next one goes into the "base_compile" arg list arg_mode=arg # the next one goes into the "base_compile" arg list
continue # The current "srcfile" will either be retained or continue # The current "srcfile" will either be retained or
;; # replaced later. I would guess that would be a bug. ;; # replaced later. I would guess that would be a bug.
-Wc,*) -Wc,*)
func_stripname '-Wc,' '' "$arg" func_stripname '-Wc,' '' "$arg"
args=$func_stripname_result args=$func_stripname_result
lastarg= lastarg=
save_ifs="$IFS"; IFS=',' save_ifs=$IFS; IFS=,
for arg in $args; do for arg in $args; do
IFS="$save_ifs" IFS=$save_ifs
func_append_quoted lastarg "$arg" func_append_quoted lastarg "$arg"
done done
IFS="$save_ifs" IFS=$save_ifs
func_stripname ' ' '' "$lastarg" func_stripname ' ' '' "$lastarg"
lastarg=$func_stripname_result lastarg=$func_stripname_result
# Add the arguments to base_compile. # Add the arguments to base_compile.
func_append base_compile " $lastarg" func_append base_compile " $lastarg"
continue continue
;; ;;
*) *)
# Accept the current argument as the source file. # Accept the current argument as the source file.
# The previous "srcfile" becomes the current argument. # The previous "srcfile" becomes the current argument.
# #
lastarg="$srcfile" lastarg=$srcfile
srcfile="$arg" srcfile=$arg
;; ;;
esac # case $arg esac # case $arg
;; ;;
esac # case $arg_mode esac # case $arg_mode
# Aesthetically quote the previous argument. # Aesthetically quote the previous argument.
func_append_quoted base_compile "$lastarg" func_append_quoted base_compile "$lastarg"
done # for arg done # for arg
case $arg_mode in case $arg_mode in
arg) arg)
func_fatal_error "you must specify an argument for -Xcompile" func_fatal_error "you must specify an argument for -Xcompile"
;; ;;
target) target)
func_fatal_error "you must specify a target with \`-o'" func_fatal_error "you must specify a target with '-o'"
;; ;;
*) *)
# Get the name of the library object. # Get the name of the library object.
test -z "$libobj" && { test -z "$libobj" && {
func_basename "$srcfile" func_basename "$srcfile"
libobj="$func_basename_result" libobj=$func_basename_result
} }
;; ;;
esac esac
# Recognize several different file suffixes. # Recognize several different file suffixes.
# If the user specifies -o file.o, it is replaced with file.lo # If the user specifies -o file.o, it is replaced with file.lo
case $libobj in case $libobj in
*.[cCFSifmso] | \ *.[cCFSifmso] | \
*.ada | *.adb | *.ads | *.asm | \ *.ada | *.adb | *.ads | *.asm | \
*.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \
*.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup) *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup)
func_xform "$libobj" func_xform "$libobj"
libobj=$func_xform_result libobj=$func_xform_result
;; ;;
esac esac
case $libobj in case $libobj in
*.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;;
*) *)
func_fatal_error "cannot determine name of library object from \`$libobj'" func_fatal_error "cannot determine name of library object from '$libobj'"
;; ;;
esac esac
func_infer_tag $base_compile func_infer_tag $base_compile
for arg in $later; do for arg in $later; do
case $arg in case $arg in
-shared) -shared)
test "$build_libtool_libs" != yes && \ test yes = "$build_libtool_libs" \
func_fatal_configuration "can not build a shared library" || func_fatal_configuration "cannot build a shared library"
build_old_libs=no build_old_libs=no
continue continue
;; ;;
-static) -static)
build_libtool_libs=no build_libtool_libs=no
build_old_libs=yes build_old_libs=yes
continue continue
;; ;;
skipping to change at line 2042 skipping to change at line 3302
-prefer-non-pic) -prefer-non-pic)
pic_mode=no pic_mode=no
continue continue
;; ;;
esac esac
done done
func_quote_for_eval "$libobj" func_quote_for_eval "$libobj"
test "X$libobj" != "X$func_quote_for_eval_result" \ test "X$libobj" != "X$func_quote_for_eval_result" \
&& $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \
&& func_warning "libobj name \`$libobj' may not contain shell special char acters." && func_warning "libobj name '$libobj' may not contain shell special chara cters."
func_dirname_and_basename "$obj" "/" "" func_dirname_and_basename "$obj" "/" ""
objname="$func_basename_result" objname=$func_basename_result
xdir="$func_dirname_result" xdir=$func_dirname_result
lobj=${xdir}$objdir/$objname lobj=$xdir$objdir/$objname
test -z "$base_compile" && \ test -z "$base_compile" && \
func_fatal_help "you must specify a compilation command" func_fatal_help "you must specify a compilation command"
# Delete any leftover library objects. # Delete any leftover library objects.
if test "$build_old_libs" = yes; then if test yes = "$build_old_libs"; then
removelist="$obj $lobj $libobj ${libobj}T" removelist="$obj $lobj $libobj ${libobj}T"
else else
removelist="$lobj $libobj ${libobj}T" removelist="$lobj $libobj ${libobj}T"
fi fi
# On Cygwin there's no "real" PIC flag so we must build both object types # On Cygwin there's no "real" PIC flag so we must build both object types
case $host_os in case $host_os in
cygwin* | mingw* | pw32* | os2* | cegcc*) cygwin* | mingw* | pw32* | os2* | cegcc*)
pic_mode=default pic_mode=default
;; ;;
esac esac
if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then
# non-PIC code in shared libraries is not supported # non-PIC code in shared libraries is not supported
pic_mode=default pic_mode=default
fi fi
# Calculate the filename of the output object if compiler does # Calculate the filename of the output object if compiler does
# not support -o with -c # not support -o with -c
if test "$compiler_c_o" = no; then if test no = "$compiler_c_o"; then
output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.${objext} output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext
lockfile="$output_obj.lock" lockfile=$output_obj.lock
else else
output_obj= output_obj=
need_locks=no need_locks=no
lockfile= lockfile=
fi fi
# Lock this critical section if it is needed # Lock this critical section if it is needed
# We use this script file to make the link, it avoids creating a new file # We use this script file to make the link, it avoids creating a new file
if test "$need_locks" = yes; then if test yes = "$need_locks"; then
until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
func_echo "Waiting for $lockfile to be removed" func_echo "Waiting for $lockfile to be removed"
sleep 2 sleep 2
done done
elif test "$need_locks" = warn; then elif test warn = "$need_locks"; then
if test -f "$lockfile"; then if test -f "$lockfile"; then
$ECHO "\ $ECHO "\
*** ERROR, $lockfile exists and contains: *** ERROR, $lockfile exists and contains:
`cat $lockfile 2>/dev/null` `cat $lockfile 2>/dev/null`
This indicates that another process is trying to use the same This indicates that another process is trying to use the same
temporary object file, and libtool could not work around it because temporary object file, and libtool could not work around it because
your compiler does not support \`-c' and \`-o' together. If you your compiler does not support '-c' and '-o' together. If you
repeat this compilation, it may succeed, by chance, but you had better repeat this compilation, it may succeed, by chance, but you had better
avoid parallel builds (make -j) in this platform, or get a better avoid parallel builds (make -j) in this platform, or get a better
compiler." compiler."
$opt_dry_run || $RM $removelist $opt_dry_run || $RM $removelist
exit $EXIT_FAILURE exit $EXIT_FAILURE
fi fi
func_append removelist " $output_obj" func_append removelist " $output_obj"
$ECHO "$srcfile" > "$lockfile" $ECHO "$srcfile" > "$lockfile"
fi fi
skipping to change at line 2117 skipping to change at line 3377
$opt_dry_run || $RM $removelist $opt_dry_run || $RM $removelist
func_append removelist " $lockfile" func_append removelist " $lockfile"
trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15
func_to_tool_file "$srcfile" func_convert_file_msys_to_w32 func_to_tool_file "$srcfile" func_convert_file_msys_to_w32
srcfile=$func_to_tool_file_result srcfile=$func_to_tool_file_result
func_quote_for_eval "$srcfile" func_quote_for_eval "$srcfile"
qsrcfile=$func_quote_for_eval_result qsrcfile=$func_quote_for_eval_result
# Only build a PIC object if we are building libtool libraries. # Only build a PIC object if we are building libtool libraries.
if test "$build_libtool_libs" = yes; then if test yes = "$build_libtool_libs"; then
# Without this assignment, base_compile gets emptied. # Without this assignment, base_compile gets emptied.
fbsd_hideous_sh_bug=$base_compile fbsd_hideous_sh_bug=$base_compile
if test "$pic_mode" != no; then if test no != "$pic_mode"; then
command="$base_compile $qsrcfile $pic_flag" command="$base_compile $qsrcfile $pic_flag"
else else
# Don't build PIC code # Don't build PIC code
command="$base_compile $qsrcfile" command="$base_compile $qsrcfile"
fi fi
func_mkdir_p "$xdir$objdir" func_mkdir_p "$xdir$objdir"
if test -z "$output_obj"; then if test -z "$output_obj"; then
# Place PIC objects in $objdir # Place PIC objects in $objdir
func_append command " -o $lobj" func_append command " -o $lobj"
fi fi
func_show_eval_locale "$command" \ func_show_eval_locale "$command" \
'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE'
if test "$need_locks" = warn && if test warn = "$need_locks" &&
test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
$ECHO "\ $ECHO "\
*** ERROR, $lockfile contains: *** ERROR, $lockfile contains:
`cat $lockfile 2>/dev/null` `cat $lockfile 2>/dev/null`
but it should contain: but it should contain:
$srcfile $srcfile
This indicates that another process is trying to use the same This indicates that another process is trying to use the same
temporary object file, and libtool could not work around it because temporary object file, and libtool could not work around it because
your compiler does not support \`-c' and \`-o' together. If you your compiler does not support '-c' and '-o' together. If you
repeat this compilation, it may succeed, by chance, but you had better repeat this compilation, it may succeed, by chance, but you had better
avoid parallel builds (make -j) in this platform, or get a better avoid parallel builds (make -j) in this platform, or get a better
compiler." compiler."
$opt_dry_run || $RM $removelist $opt_dry_run || $RM $removelist
exit $EXIT_FAILURE exit $EXIT_FAILURE
fi fi
# Just move the object if needed, then go on to compile the next one # Just move the object if needed, then go on to compile the next one
if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then
func_show_eval '$MV "$output_obj" "$lobj"' \ func_show_eval '$MV "$output_obj" "$lobj"' \
'error=$?; $opt_dry_run || $RM $removelist; exit $error' 'error=$?; $opt_dry_run || $RM $removelist; exit $error'
fi fi
# Allow error messages only from the first compilation. # Allow error messages only from the first compilation.
if test "$suppress_opt" = yes; then if test yes = "$suppress_opt"; then
suppress_output=' >/dev/null 2>&1' suppress_output=' >/dev/null 2>&1'
fi fi
fi fi
# Only build a position-dependent object if we build old libraries. # Only build a position-dependent object if we build old libraries.
if test "$build_old_libs" = yes; then if test yes = "$build_old_libs"; then
if test "$pic_mode" != yes; then if test yes != "$pic_mode"; then
# Don't build PIC code # Don't build PIC code
command="$base_compile $qsrcfile$pie_flag" command="$base_compile $qsrcfile$pie_flag"
else else
command="$base_compile $qsrcfile $pic_flag" command="$base_compile $qsrcfile $pic_flag"
fi fi
if test "$compiler_c_o" = yes; then if test yes = "$compiler_c_o"; then
func_append command " -o $obj" func_append command " -o $obj"
fi fi
# Suppress compiler output if we already did a PIC compilation. # Suppress compiler output if we already did a PIC compilation.
func_append command "$suppress_output" func_append command "$suppress_output"
func_show_eval_locale "$command" \ func_show_eval_locale "$command" \
'$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE'
if test "$need_locks" = warn && if test warn = "$need_locks" &&
test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
$ECHO "\ $ECHO "\
*** ERROR, $lockfile contains: *** ERROR, $lockfile contains:
`cat $lockfile 2>/dev/null` `cat $lockfile 2>/dev/null`
but it should contain: but it should contain:
$srcfile $srcfile
This indicates that another process is trying to use the same This indicates that another process is trying to use the same
temporary object file, and libtool could not work around it because temporary object file, and libtool could not work around it because
your compiler does not support \`-c' and \`-o' together. If you your compiler does not support '-c' and '-o' together. If you
repeat this compilation, it may succeed, by chance, but you had better repeat this compilation, it may succeed, by chance, but you had better
avoid parallel builds (make -j) in this platform, or get a better avoid parallel builds (make -j) in this platform, or get a better
compiler." compiler."
$opt_dry_run || $RM $removelist $opt_dry_run || $RM $removelist
exit $EXIT_FAILURE exit $EXIT_FAILURE
fi fi
# Just move the object if needed # Just move the object if needed
if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then
func_show_eval '$MV "$output_obj" "$obj"' \ func_show_eval '$MV "$output_obj" "$obj"' \
'error=$?; $opt_dry_run || $RM $removelist; exit $error' 'error=$?; $opt_dry_run || $RM $removelist; exit $error'
fi fi
fi fi
$opt_dry_run || { $opt_dry_run || {
func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" func_write_libtool_object "$libobj" "$objdir/$objname" "$objname"
# Unlock the critical section if it was locked # Unlock the critical section if it was locked
if test "$need_locks" != no; then if test no != "$need_locks"; then
removelist=$lockfile removelist=$lockfile
$RM "$lockfile" $RM "$lockfile"
fi fi
} }
exit $EXIT_SUCCESS exit $EXIT_SUCCESS
} }
$opt_help || { $opt_help || {
test "$opt_mode" = compile && func_mode_compile ${1+"$@"} test compile = "$opt_mode" && func_mode_compile ${1+"$@"}
} }
func_mode_help () func_mode_help ()
{ {
# We need to display help for each of the modes. # We need to display help for each of the modes.
case $opt_mode in case $opt_mode in
"") "")
# Generic help is extracted from the usage comments # Generic help is extracted from the usage comments
# at the start of this file. # at the start of this file.
func_help func_help
;; ;;
clean) clean)
$ECHO \ $ECHO \
"Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... "Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE...
Remove files from the build directory. Remove files from the build directory.
RM is the name of the program to use to delete files associated with each FILE RM is the name of the program to use to delete files associated with each FILE
(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed
to RM. to RM.
If FILE is a libtool library, object or program, all the files associated If FILE is a libtool library, object or program, all the files associated
with it are deleted. Otherwise, only FILE itself is deleted using RM." with it are deleted. Otherwise, only FILE itself is deleted using RM."
;; ;;
compile) compile)
$ECHO \ $ECHO \
"Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE "Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE
Compile a source file into a libtool library object. Compile a source file into a libtool library object.
This mode accepts the following additional options: This mode accepts the following additional options:
-o OUTPUT-FILE set the output file name to OUTPUT-FILE -o OUTPUT-FILE set the output file name to OUTPUT-FILE
-no-suppress do not suppress compiler output for multiple passes -no-suppress do not suppress compiler output for multiple passes
-prefer-pic try to build PIC objects only -prefer-pic try to build PIC objects only
-prefer-non-pic try to build non-PIC objects only -prefer-non-pic try to build non-PIC objects only
-shared do not build a \`.o' file suitable for static linking -shared do not build a '.o' file suitable for static linking
-static only 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 -Wc,FLAG pass FLAG directly to the compiler
COMPILE-COMMAND is a command to be used in creating a \`standard' object file COMPILE-COMMAND is a command to be used in creating a 'standard' object file
from the given SOURCEFILE. from the given SOURCEFILE.
The output file name is determined by removing the directory component from The output file name is determined by removing the directory component from
SOURCEFILE, then substituting the C source code suffix \`.c' with the SOURCEFILE, then substituting the C source code suffix '.c' with the
library object suffix, \`.lo'." library object suffix, '.lo'."
;; ;;
execute) execute)
$ECHO \ $ECHO \
"Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... "Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]...
Automatically set library path, then run a program. Automatically set library path, then run a program.
This mode accepts the following additional options: This mode accepts the following additional options:
-dlopen FILE add the directory containing FILE to the library path -dlopen FILE add the directory containing FILE to the library path
This mode sets the library path environment variable according to \`-dlopen' This mode sets the library path environment variable according to '-dlopen'
flags. flags.
If any of the ARGS are libtool executable wrappers, then they are translated If any of the ARGS are libtool executable wrappers, then they are translated
into their corresponding uninstalled binary, and any of their required library into their corresponding uninstalled binary, and any of their required library
directories are added to the library path. directories are added to the library path.
Then, COMMAND is executed, with ARGS as arguments." Then, COMMAND is executed, with ARGS as arguments."
;; ;;
finish) finish)
$ECHO \ $ECHO \
"Usage: $progname [OPTION]... --mode=finish [LIBDIR]... "Usage: $progname [OPTION]... --mode=finish [LIBDIR]...
Complete the installation of libtool libraries. Complete the installation of libtool libraries.
Each LIBDIR is a directory that contains libtool libraries. Each LIBDIR is a directory that contains libtool libraries.
The commands that this mode executes may require superuser privileges. Use The commands that this mode executes may require superuser privileges. Use
the \`--dry-run' option if you just want to see what would be executed." the '--dry-run' option if you just want to see what would be executed."
;; ;;
install) install)
$ECHO \ $ECHO \
"Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... "Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND...
Install executables or libraries. Install executables or libraries.
INSTALL-COMMAND is the installation command. The first component should be INSTALL-COMMAND is the installation command. The first component should be
either the \`install' or \`cp' program. either the 'install' or 'cp' program.
The following components of INSTALL-COMMAND are treated specially: The following components of INSTALL-COMMAND are treated specially:
-inst-prefix-dir 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 The rest of the components are interpreted as arguments to that command (only
BSD-compatible install options are recognized)." BSD-compatible install options are recognized)."
;; ;;
link) link)
skipping to change at line 2344 skipping to change at line 3604
LINK-COMMAND is a command using the C compiler that you would use to create LINK-COMMAND is a command using the C compiler that you would use to create
a program from several object files. a program from several object files.
The following components of LINK-COMMAND are treated specially: The following components of LINK-COMMAND are treated specially:
-all-static do not do any dynamic linking at all -all-static do not do any dynamic linking at all
-avoid-version do not add a version suffix if possible -avoid-version do not add a version suffix if possible
-bindir BINDIR specify path to binaries directory (for systems where -bindir BINDIR specify path to binaries directory (for systems where
libraries must be found in the PATH setting at runtime) libraries must be found in the PATH setting at runtime)
-dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened 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 -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) -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3)
-export-symbols SYMFILE -export-symbols SYMFILE
try to export only the symbols listed in SYMFILE try to export only the symbols listed in SYMFILE
-export-symbols-regex REGEX -export-symbols-regex REGEX
try to export only the symbols matching REGEX try to export only the symbols matching REGEX
-LLIBDIR search LIBDIR for required installed libraries -LLIBDIR search LIBDIR for required installed libraries
-lNAME OUTPUT-FILE requires the installed library libNAME -lNAME OUTPUT-FILE requires the installed library libNAME
-module build a library that can dlopened -module build a library that can dlopened
-no-fast-install disable the fast-install mode -no-fast-install disable the fast-install mode
-no-install link a not-installable executable -no-install link a not-installable executable
-no-undefined declare that a library does not refer to external symbols -no-undefined declare that a library does not refer to external symbols
-o OUTPUT-FILE create OUTPUT-FILE from the specified objects -o OUTPUT-FILE create OUTPUT-FILE from the specified objects
-objectlist FILE Use a list of object files found in FILE to specify objects -objectlist FILE use a list of object files found in FILE to specify objects
-os2dllname NAME force a short DLL name on OS/2 (no effect on other OSes)
-precious-files-regex REGEX -precious-files-regex REGEX
don't remove output files matching REGEX don't remove output files matching REGEX
-release RELEASE specify package release information -release RELEASE specify package release information
-rpath LIBDIR the created library will eventually be installed in LIBDIR -rpath LIBDIR the created library will eventually be installed in LIBDIR
-R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries
-shared only do dynamic linking of libtool libraries -shared only do dynamic linking of libtool libraries
-shrext SUFFIX override the standard shared library file extension -shrext SUFFIX override the standard shared library file extension
-static do not do any dynamic linking of uninstalled libtool librari es -static do not do any dynamic linking of uninstalled libtool librari es
-static-libtool-libs -static-libtool-libs
do not do any dynamic linking of libtool libraries do not do any dynamic linking of libtool libraries
-version-info CURRENT[:REVISION[:AGE]] -version-info CURRENT[:REVISION[:AGE]]
specify library version info [each variable defaults to 0] specify library version info [each variable defaults to 0]
-weak LIBNAME declare that the target provides the LIBNAME interface -weak LIBNAME declare that the target provides the LIBNAME interface
-Wc,FLAG -Wc,FLAG
-Xcompiler FLAG pass linker-specific FLAG directly to the compiler -Xcompiler FLAG pass linker-specific FLAG directly to the compiler
-Wl,FLAG -Wl,FLAG
-Xlinker FLAG pass linker-specific FLAG directly to the linker -Xlinker FLAG pass linker-specific FLAG directly to the linker
-XCClinker FLAG pass link-specific FLAG to the compiler driver (CC) -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC)
All other options (arguments beginning with \`-') are ignored. All other options (arguments beginning with '-') are ignored.
Every other argument is treated as a filename. Files ending in \`.la' are Every other argument is treated as a filename. Files ending in '.la' are
treated as uninstalled libtool libraries, other files are standard or library treated as uninstalled libtool libraries, other files are standard or library
object files. object files.
If the OUTPUT-FILE ends in \`.la', then a libtool library is created, If the OUTPUT-FILE ends in '.la', then a libtool library is created,
only library objects (\`.lo' files) may be specified, and \`-rpath' is only library objects ('.lo' files) may be specified, and '-rpath' is
required, except when creating a convenience library. required, except when creating a convenience library.
If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created If OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created
using \`ar' and \`ranlib', or on Windows using \`lib'. using 'ar' and 'ranlib', or on Windows using 'lib'.
If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file
is created, otherwise an executable program is created." is created, otherwise an executable program is created."
;; ;;
uninstall) uninstall)
$ECHO \ $ECHO \
"Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... "Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE...
Remove libraries from an installation directory. Remove libraries from an installation directory.
RM is the name of the program to use to delete files associated with each FILE RM is the name of the program to use to delete files associated with each FILE
(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed
to RM. to RM.
If FILE is a libtool library, all the files associated with it are deleted. If FILE is a libtool library, all the files associated with it are deleted.
Otherwise, only FILE itself is deleted using RM." Otherwise, only FILE itself is deleted using RM."
;; ;;
*) *)
func_fatal_help "invalid operation mode \`$opt_mode'" func_fatal_help "invalid operation mode '$opt_mode'"
;; ;;
esac esac
echo echo
$ECHO "Try \`$progname --help' for more information about other modes." $ECHO "Try '$progname --help' for more information about other modes."
} }
# Now that we've collected a possible --mode arg, show help if necessary # Now that we've collected a possible --mode arg, show help if necessary
if $opt_help; then if $opt_help; then
if test "$opt_help" = :; then if test : = "$opt_help"; then
func_mode_help func_mode_help
else else
{ {
func_help noexit func_help noexit
for opt_mode in compile link execute install finish uninstall clean; do for opt_mode in compile link execute install finish uninstall clean; do
func_mode_help func_mode_help
done done
} | sed -n '1p; 2,$s/^Usage:/ or: /p' } | $SED -n '1p; 2,$s/^Usage:/ or: /p'
{ {
func_help noexit func_help noexit
for opt_mode in compile link execute install finish uninstall clean; do for opt_mode in compile link execute install finish uninstall clean; do
echo echo
func_mode_help func_mode_help
done done
} | } |
sed '1d $SED '1d
/^When reporting/,/^Report/{ /^When reporting/,/^Report/{
H H
d d
} }
$x $x
/information about other modes/d /information about other modes/d
/more detailed .*MODE/d /more detailed .*MODE/d
s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/' s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/'
fi fi
exit $? exit $?
fi fi
# func_mode_execute arg... # func_mode_execute arg...
func_mode_execute () func_mode_execute ()
{ {
$opt_debug $debug_cmd
# The first argument is the command name. # The first argument is the command name.
cmd="$nonopt" cmd=$nonopt
test -z "$cmd" && \ test -z "$cmd" && \
func_fatal_help "you must specify a COMMAND" func_fatal_help "you must specify a COMMAND"
# Handle -dlopen flags immediately. # Handle -dlopen flags immediately.
for file in $opt_dlopen; do for file in $opt_dlopen; do
test -f "$file" \ test -f "$file" \
|| func_fatal_help "\`$file' is not a file" || func_fatal_help "'$file' is not a file"
dir= dir=
case $file in case $file in
*.la) *.la)
func_resolve_sysroot "$file" func_resolve_sysroot "$file"
file=$func_resolve_sysroot_result file=$func_resolve_sysroot_result
# Check to see that this really is a libtool archive. # Check to see that this really is a libtool archive.
func_lalib_unsafe_p "$file" \ func_lalib_unsafe_p "$file" \
|| func_fatal_help "\`$lib' is not a valid libtool archive" || func_fatal_help "'$lib' is not a valid libtool archive"
# Read the libtool library. # Read the libtool library.
dlname= dlname=
library_names= library_names=
func_source "$file" func_source "$file"
# Skip this library if it cannot be dlopened. # Skip this library if it cannot be dlopened.
if test -z "$dlname"; then if test -z "$dlname"; then
# Warn if it was a shared library. # Warn if it was a shared library.
test -n "$library_names" && \ test -n "$library_names" && \
func_warning "\`$file' was not linked with \`-export-dynamic'" func_warning "'$file' was not linked with '-export-dynamic'"
continue continue
fi fi
func_dirname "$file" "" "." func_dirname "$file" "" "."
dir="$func_dirname_result" dir=$func_dirname_result
if test -f "$dir/$objdir/$dlname"; then if test -f "$dir/$objdir/$dlname"; then
func_append dir "/$objdir" func_append dir "/$objdir"
else else
if test ! -f "$dir/$dlname"; then if test ! -f "$dir/$dlname"; then
func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir '" func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'"
fi fi
fi fi
;; ;;
*.lo) *.lo)
# Just add the directory containing the .lo file. # Just add the directory containing the .lo file.
func_dirname "$file" "" "." func_dirname "$file" "" "."
dir="$func_dirname_result" dir=$func_dirname_result
;; ;;
*) *)
func_warning "\`-dlopen' is ignored for non-libtool libraries and objects " func_warning "'-dlopen' is ignored for non-libtool libraries and objects"
continue continue
;; ;;
esac esac
# Get the absolute pathname. # Get the absolute pathname.
absdir=`cd "$dir" && pwd` absdir=`cd "$dir" && pwd`
test -n "$absdir" && dir="$absdir" test -n "$absdir" && dir=$absdir
# Now add the directory to shlibpath_var. # Now add the directory to shlibpath_var.
if eval "test -z \"\$$shlibpath_var\""; then if eval "test -z \"\$$shlibpath_var\""; then
eval "$shlibpath_var=\"\$dir\"" eval "$shlibpath_var=\"\$dir\""
else else
eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\""
fi fi
done done
# This variable tells wrapper scripts just to set shlibpath_var # This variable tells wrapper scripts just to set shlibpath_var
# rather than running their programs. # rather than running their programs.
libtool_execute_magic="$magic" libtool_execute_magic=$magic
# Check if any of the arguments is a wrapper script. # Check if any of the arguments is a wrapper script.
args= args=
for file for file
do do
case $file in case $file in
-* | *.la | *.lo ) ;; -* | *.la | *.lo ) ;;
*) *)
# Do a test to see if this is really a libtool program. # Do a test to see if this is really a libtool program.
if func_ltwrapper_script_p "$file"; then if func_ltwrapper_script_p "$file"; then
func_source "$file" func_source "$file"
# Transform arg to wrapped name. # Transform arg to wrapped name.
file="$progdir/$program" file=$progdir/$program
elif func_ltwrapper_executable_p "$file"; then elif func_ltwrapper_executable_p "$file"; then
func_ltwrapper_scriptname "$file" func_ltwrapper_scriptname "$file"
func_source "$func_ltwrapper_scriptname_result" func_source "$func_ltwrapper_scriptname_result"
# Transform arg to wrapped name. # Transform arg to wrapped name.
file="$progdir/$program" file=$progdir/$program
fi fi
;; ;;
esac esac
# Quote arguments (to preserve shell metacharacters). # Quote arguments (to preserve shell metacharacters).
func_append_quoted args "$file" func_append_quoted args "$file"
done done
if test "X$opt_dry_run" = Xfalse; then if $opt_dry_run; then
# Display what would be done.
if test -n "$shlibpath_var"; then
eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\""
echo "export $shlibpath_var"
fi
$ECHO "$cmd$args"
exit $EXIT_SUCCESS
else
if test -n "$shlibpath_var"; then if test -n "$shlibpath_var"; then
# Export the shlibpath_var. # Export the shlibpath_var.
eval "export $shlibpath_var" eval "export $shlibpath_var"
fi fi
# Restore saved environment variables # Restore saved environment variables
for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
do do
eval "if test \"\${save_$lt_var+set}\" = set; then eval "if test \"\${save_$lt_var+set}\" = set; then
$lt_var=\$save_$lt_var; export $lt_var $lt_var=\$save_$lt_var; export $lt_var
else else
$lt_unset $lt_var $lt_unset $lt_var
fi" fi"
done done
# Now prepare to actually exec the command. # Now prepare to actually exec the command.
exec_cmd="\$cmd$args" exec_cmd=\$cmd$args
else
# Display what would be done.
if test -n "$shlibpath_var"; then
eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\""
echo "export $shlibpath_var"
fi
$ECHO "$cmd$args"
exit $EXIT_SUCCESS
fi fi
} }
test "$opt_mode" = execute && func_mode_execute ${1+"$@"} test execute = "$opt_mode" && func_mode_execute ${1+"$@"}
# func_mode_finish arg... # func_mode_finish arg...
func_mode_finish () func_mode_finish ()
{ {
$opt_debug $debug_cmd
libs= libs=
libdirs= libdirs=
admincmds= admincmds=
for opt in "$nonopt" ${1+"$@"} for opt in "$nonopt" ${1+"$@"}
do do
if test -d "$opt"; then if test -d "$opt"; then
func_append libdirs " $opt" func_append libdirs " $opt"
elif test -f "$opt"; then elif test -f "$opt"; then
if func_lalib_unsafe_p "$opt"; then if func_lalib_unsafe_p "$opt"; then
func_append libs " $opt" func_append libs " $opt"
else else
func_warning "\`$opt' is not a valid libtool archive" func_warning "'$opt' is not a valid libtool archive"
fi fi
else else
func_fatal_error "invalid argument \`$opt'" func_fatal_error "invalid argument '$opt'"
fi fi
done done
if test -n "$libs"; then if test -n "$libs"; then
if test -n "$lt_sysroot"; then if test -n "$lt_sysroot"; then
sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"` sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"`
sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;" sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;"
else else
sysroot_cmd= sysroot_cmd=
fi fi
# Remove sysroot references # Remove sysroot references
if $opt_dry_run; then if $opt_dry_run; then
for lib in $libs; do for lib in $libs; do
echo "removing references to $lt_sysroot and \`=' prefixes from $lib" echo "removing references to $lt_sysroot and '=' prefixes from $lib"
done done
else else
tmpdir=`func_mktempdir` tmpdir=`func_mktempdir`
for lib in $libs; do for lib in $libs; do
sed -e "${sysroot_cmd} s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \ $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \
> $tmpdir/tmp-la > $tmpdir/tmp-la
mv -f $tmpdir/tmp-la $lib mv -f $tmpdir/tmp-la $lib
done done
${RM}r "$tmpdir" ${RM}r "$tmpdir"
fi fi
fi fi
if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
for libdir in $libdirs; do for libdir in $libdirs; do
if test -n "$finish_cmds"; then if test -n "$finish_cmds"; then
skipping to change at line 2647 skipping to change at line 3910
if test -n "$finish_eval"; then if test -n "$finish_eval"; then
# Do the single finish_eval. # Do the single finish_eval.
eval cmds=\"$finish_eval\" eval cmds=\"$finish_eval\"
$opt_dry_run || eval "$cmds" || func_append admincmds " $opt_dry_run || eval "$cmds" || func_append admincmds "
$cmds" $cmds"
fi fi
done done
fi fi
# Exit here if they wanted silent mode. # Exit here if they wanted silent mode.
$opt_silent && exit $EXIT_SUCCESS $opt_quiet && exit $EXIT_SUCCESS
if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
echo "-------------------------------------------------------------------- --" echo "-------------------------------------------------------------------- --"
echo "Libraries have been installed in:" echo "Libraries have been installed in:"
for libdir in $libdirs; do for libdir in $libdirs; do
$ECHO " $libdir" $ECHO " $libdir"
done done
echo echo
echo "If you ever happen to want to link against installed libraries" 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 "in a given directory, LIBDIR, you must either use libtool, and"
echo "specify the full pathname of the library, or use the \`-LLIBDIR'" echo "specify the full pathname of the library, or use the '-LLIBDIR'"
echo "flag during linking and do at least one of the following:" echo "flag during linking and do at least one of the following:"
if test -n "$shlibpath_var"; then if test -n "$shlibpath_var"; then
echo " - add LIBDIR to the \`$shlibpath_var' environment variable" echo " - add LIBDIR to the '$shlibpath_var' environment variable"
echo " during execution" echo " during execution"
fi fi
if test -n "$runpath_var"; then if test -n "$runpath_var"; then
echo " - add LIBDIR to the \`$runpath_var' environment variable" echo " - add LIBDIR to the '$runpath_var' environment variable"
echo " during linking" echo " during linking"
fi fi
if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_flag_spec"; then
libdir=LIBDIR libdir=LIBDIR
eval flag=\"$hardcode_libdir_flag_spec\" eval flag=\"$hardcode_libdir_flag_spec\"
$ECHO " - use the \`$flag' linker flag" $ECHO " - use the '$flag' linker flag"
fi fi
if test -n "$admincmds"; then if test -n "$admincmds"; then
$ECHO " - have your system administrator run these commands:$admincmds" $ECHO " - have your system administrator run these commands:$admincmds"
fi fi
if test -f /etc/ld.so.conf; then if test -f /etc/ld.so.conf; then
echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf '" echo " - have your system administrator add LIBDIR to '/etc/ld.so.conf' "
fi fi
echo echo
echo "See any operating system documentation about shared libraries for" echo "See any operating system documentation about shared libraries for"
case $host in case $host in
solaris2.[6789]|solaris2.1[0-9]) solaris2.[6789]|solaris2.1[0-9])
echo "more information, such as the ld(1), crle(1) and ld.so(8) manual" echo "more information, such as the ld(1), crle(1) and ld.so(8) manual"
echo "pages." echo "pages."
;; ;;
*) *)
echo "more information, such as the ld(1) and ld.so(8) manual pages." echo "more information, such as the ld(1) and ld.so(8) manual pages."
;; ;;
esac esac
echo "-------------------------------------------------------------------- --" echo "-------------------------------------------------------------------- --"
fi fi
exit $EXIT_SUCCESS exit $EXIT_SUCCESS
} }
test "$opt_mode" = finish && func_mode_finish ${1+"$@"} test finish = "$opt_mode" && func_mode_finish ${1+"$@"}
# func_mode_install arg... # func_mode_install arg...
func_mode_install () func_mode_install ()
{ {
$opt_debug $debug_cmd
# There may be an optional sh(1) argument at the beginning of # There may be an optional sh(1) argument at the beginning of
# install_prog (especially on Windows NT). # install_prog (especially on Windows NT).
if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh || if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" ||
# Allow the use of GNU shtool's install command. # Allow the use of GNU shtool's install command.
case $nonopt in *shtool*) :;; *) false;; esac; then case $nonopt in *shtool*) :;; *) false;; esac
then
# Aesthetically quote it. # Aesthetically quote it.
func_quote_for_eval "$nonopt" func_quote_for_eval "$nonopt"
install_prog="$func_quote_for_eval_result " install_prog="$func_quote_for_eval_result "
arg=$1 arg=$1
shift shift
else else
install_prog= install_prog=
arg=$nonopt arg=$nonopt
fi fi
skipping to change at line 2734 skipping to change at line 3999
*[\\\ /]cp\ *) install_cp=: ;; *[\\\ /]cp\ *) install_cp=: ;;
*) install_cp=false ;; *) install_cp=false ;;
esac esac
# We need to accept at least all the BSD install flags. # We need to accept at least all the BSD install flags.
dest= dest=
files= files=
opts= opts=
prev= prev=
install_type= install_type=
isdir=no isdir=false
stripme= stripme=
no_mode=: no_mode=:
for arg for arg
do do
arg2= arg2=
if test -n "$dest"; then if test -n "$dest"; then
func_append files " $dest" func_append files " $dest"
dest=$arg dest=$arg
continue continue
fi fi
case $arg in case $arg in
-d) isdir=yes ;; -d) isdir=: ;;
-f) -f)
if $install_cp; then :; else if $install_cp; then :; else
prev=$arg prev=$arg
fi fi
;; ;;
-g | -m | -o) -g | -m | -o)
prev=$arg prev=$arg
;; ;;
-s) -s)
stripme=" -s" stripme=" -s"
continue continue
;; ;;
-*) -*)
;; ;;
*) *)
# If the previous option needed an argument, then skip it. # If the previous option needed an argument, then skip it.
if test -n "$prev"; then if test -n "$prev"; then
if test "x$prev" = x-m && test -n "$install_override_mode"; then if test X-m = "X$prev" && test -n "$install_override_mode"; then
arg2=$install_override_mode arg2=$install_override_mode
no_mode=false no_mode=false
fi fi
prev= prev=
else else
dest=$arg dest=$arg
continue continue
fi fi
;; ;;
esac esac
skipping to change at line 2790 skipping to change at line 4055
if test -n "$arg2"; then if test -n "$arg2"; then
func_quote_for_eval "$arg2" func_quote_for_eval "$arg2"
fi fi
func_append install_shared_prog " $func_quote_for_eval_result" func_append install_shared_prog " $func_quote_for_eval_result"
done done
test -z "$install_prog" && \ test -z "$install_prog" && \
func_fatal_help "you must specify an install program" func_fatal_help "you must specify an install program"
test -n "$prev" && \ test -n "$prev" && \
func_fatal_help "the \`$prev' option requires an argument" func_fatal_help "the '$prev' option requires an argument"
if test -n "$install_override_mode" && $no_mode; then if test -n "$install_override_mode" && $no_mode; then
if $install_cp; then :; else if $install_cp; then :; else
func_quote_for_eval "$install_override_mode" func_quote_for_eval "$install_override_mode"
func_append install_shared_prog " -m $func_quote_for_eval_result" func_append install_shared_prog " -m $func_quote_for_eval_result"
fi fi
fi fi
if test -z "$files"; then if test -z "$files"; then
if test -z "$dest"; then if test -z "$dest"; then
skipping to change at line 2812 skipping to change at line 4077
else else
func_fatal_help "you must specify a destination" func_fatal_help "you must specify a destination"
fi fi
fi fi
# Strip any trailing slash from the destination. # Strip any trailing slash from the destination.
func_stripname '' '/' "$dest" func_stripname '' '/' "$dest"
dest=$func_stripname_result dest=$func_stripname_result
# Check to see that the destination is a directory. # Check to see that the destination is a directory.
test -d "$dest" && isdir=yes test -d "$dest" && isdir=:
if test "$isdir" = yes; then if $isdir; then
destdir="$dest" destdir=$dest
destname= destname=
else else
func_dirname_and_basename "$dest" "" "." func_dirname_and_basename "$dest" "" "."
destdir="$func_dirname_result" destdir=$func_dirname_result
destname="$func_basename_result" destname=$func_basename_result
# Not a directory, so check to see that there is only one file specified. # Not a directory, so check to see that there is only one file specified.
set dummy $files; shift set dummy $files; shift
test "$#" -gt 1 && \ test "$#" -gt 1 && \
func_fatal_help "\`$dest' is not a directory" func_fatal_help "'$dest' is not a directory"
fi fi
case $destdir in case $destdir in
[\\/]* | [A-Za-z]:[\\/]*) ;; [\\/]* | [A-Za-z]:[\\/]*) ;;
*) *)
for file in $files; do for file in $files; do
case $file in case $file in
*.lo) ;; *.lo) ;;
*) *)
func_fatal_help "\`$destdir' must be an absolute directory name" func_fatal_help "'$destdir' must be an absolute directory name"
;; ;;
esac esac
done done
;; ;;
esac esac
# This variable tells wrapper scripts just to set variables rather # This variable tells wrapper scripts just to set variables rather
# than running their programs. # than running their programs.
libtool_install_magic="$magic" libtool_install_magic=$magic
staticlibs= staticlibs=
future_libdirs= future_libdirs=
current_libdirs= current_libdirs=
for file in $files; do for file in $files; do
# Do each installation. # Do each installation.
case $file in case $file in
*.$libext) *.$libext)
# Do the static libraries later. # Do the static libraries later.
func_append staticlibs " $file" func_append staticlibs " $file"
;; ;;
*.la) *.la)
func_resolve_sysroot "$file" func_resolve_sysroot "$file"
file=$func_resolve_sysroot_result file=$func_resolve_sysroot_result
# Check to see that this really is a libtool archive. # Check to see that this really is a libtool archive.
func_lalib_unsafe_p "$file" \ func_lalib_unsafe_p "$file" \
|| func_fatal_help "\`$file' is not a valid libtool archive" || func_fatal_help "'$file' is not a valid libtool archive"
library_names= library_names=
old_library= old_library=
relink_command= relink_command=
func_source "$file" func_source "$file"
# Add the libdir to current_libdirs if it is the destination. # Add the libdir to current_libdirs if it is the destination.
if test "X$destdir" = "X$libdir"; then if test "X$destdir" = "X$libdir"; then
case "$current_libdirs " in case "$current_libdirs " in
*" $libdir "*) ;; *" $libdir "*) ;;
skipping to change at line 2884 skipping to change at line 4149
esac esac
else else
# Note the libdir as a future libdir. # Note the libdir as a future libdir.
case "$future_libdirs " in case "$future_libdirs " in
*" $libdir "*) ;; *" $libdir "*) ;;
*) func_append future_libdirs " $libdir" ;; *) func_append future_libdirs " $libdir" ;;
esac esac
fi fi
func_dirname "$file" "/" "" func_dirname "$file" "/" ""
dir="$func_dirname_result" dir=$func_dirname_result
func_append dir "$objdir" func_append dir "$objdir"
if test -n "$relink_command"; then if test -n "$relink_command"; then
# Determine the prefix the user has applied to our future dir. # Determine the prefix the user has applied to our future dir.
inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"` inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"`
# Don't allow the user to place us outside of our expected # Don't allow the user to place us outside of our expected
# location b/c this prevents finding dependent libraries that # location b/c this prevents finding dependent libraries that
# are installed to the same prefix. # are installed to the same prefix.
# At present, this check doesn't affect windows .dll's that # At present, this check doesn't affect windows .dll's that
# are installed into $libdir/../bin (currently, that works fine) # are installed into $libdir/../bin (currently, that works fine)
# but it's something to keep an eye on. # but it's something to keep an eye on.
test "$inst_prefix_dir" = "$destdir" && \ test "$inst_prefix_dir" = "$destdir" && \
func_fatal_error "error: cannot install \`$file' to a directory not e nding in $libdir" func_fatal_error "error: cannot install '$file' to a directory not en ding in $libdir"
if test -n "$inst_prefix_dir"; then if test -n "$inst_prefix_dir"; then
# Stick the inst_prefix_dir data into the link command. # Stick the inst_prefix_dir data into the link command.
relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%- inst-prefix-dir $inst_prefix_dir%"` relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%- inst-prefix-dir $inst_prefix_dir%"`
else else
relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%% "` relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%% "`
fi fi
func_warning "relinking \`$file'" func_warning "relinking '$file'"
func_show_eval "$relink_command" \ func_show_eval "$relink_command" \
'func_fatal_error "error: relink \`$file'\'' with the above command b efore installing it"' 'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"'
fi fi
# See the names of the shared library. # See the names of the shared library.
set dummy $library_names; shift set dummy $library_names; shift
if test -n "$1"; then if test -n "$1"; then
realname="$1" realname=$1
shift shift
srcname="$realname" srcname=$realname
test -n "$relink_command" && srcname="$realname"T test -n "$relink_command" && srcname=${realname}T
# Install the shared library and build the symlinks. # Install the shared library and build the symlinks.
func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \ func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \
'exit $?' 'exit $?'
tstripme="$stripme" tstripme=$stripme
case $host_os in case $host_os in
cygwin* | mingw* | pw32* | cegcc*) cygwin* | mingw* | pw32* | cegcc*)
case $realname in case $realname in
*.dll.a) *.dll.a)
tstripme="" tstripme=
;;
esac
;;
os2*)
case $realname in
*_dll.a)
tstripme=
;; ;;
esac esac
;; ;;
esac esac
if test -n "$tstripme" && test -n "$striplib"; then if test -n "$tstripme" && test -n "$striplib"; then
func_show_eval "$striplib $destdir/$realname" 'exit $?' func_show_eval "$striplib $destdir/$realname" 'exit $?'
fi fi
if test "$#" -gt 0; then if test "$#" -gt 0; then
# Delete the old symlinks, and create new ones. # Delete the old symlinks, and create new ones.
# Try `ln -sf' first, because the `ln' binary might depend on # Try 'ln -sf' first, because the 'ln' binary might depend on
# the symlink we replace! Solaris /bin/ln does not understand -f, # the symlink we replace! Solaris /bin/ln does not understand -f,
# so we also need to try rm && ln -s. # so we also need to try rm && ln -s.
for linkname for linkname
do do
test "$linkname" != "$realname" \ test "$linkname" != "$realname" \
&& func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })"
done done
fi fi
# Do each command in the postinstall commands. # Do each command in the postinstall commands.
lib="$destdir/$realname" lib=$destdir/$realname
func_execute_cmds "$postinstall_cmds" 'exit $?' func_execute_cmds "$postinstall_cmds" 'exit $?'
fi fi
# Install the pseudo-library for information purposes. # Install the pseudo-library for information purposes.
func_basename "$file" func_basename "$file"
name="$func_basename_result" name=$func_basename_result
instname="$dir/$name"i instname=$dir/${name}i
func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' func_show_eval "$install_prog $instname $destdir/$name" 'exit $?'
# Maybe install the static library, too. # Maybe install the static library, too.
test -n "$old_library" && func_append staticlibs " $dir/$old_library" test -n "$old_library" && func_append staticlibs " $dir/$old_library"
;; ;;
*.lo) *.lo)
# Install (i.e. copy) a libtool object. # Install (i.e. copy) a libtool object.
# Figure out destination file name, if it wasn't already specified. # Figure out destination file name, if it wasn't already specified.
if test -n "$destname"; then if test -n "$destname"; then
destfile="$destdir/$destname" destfile=$destdir/$destname
else else
func_basename "$file" func_basename "$file"
destfile="$func_basename_result" destfile=$func_basename_result
destfile="$destdir/$destfile" destfile=$destdir/$destfile
fi fi
# Deduce the name of the destination old-style object file. # Deduce the name of the destination old-style object file.
case $destfile in case $destfile in
*.lo) *.lo)
func_lo2o "$destfile" func_lo2o "$destfile"
staticdest=$func_lo2o_result staticdest=$func_lo2o_result
;; ;;
*.$objext) *.$objext)
staticdest="$destfile" staticdest=$destfile
destfile= destfile=
;; ;;
*) *)
func_fatal_help "cannot copy a libtool object to \`$destfile'" func_fatal_help "cannot copy a libtool object to '$destfile'"
;; ;;
esac esac
# Install the libtool object if requested. # Install the libtool object if requested.
test -n "$destfile" && \ test -n "$destfile" && \
func_show_eval "$install_prog $file $destfile" 'exit $?' func_show_eval "$install_prog $file $destfile" 'exit $?'
# Install the old object if enabled. # Install the old object if enabled.
if test "$build_old_libs" = yes; then if test yes = "$build_old_libs"; then
# Deduce the name of the old-style object file. # Deduce the name of the old-style object file.
func_lo2o "$file" func_lo2o "$file"
staticobj=$func_lo2o_result staticobj=$func_lo2o_result
func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?'
fi fi
exit $EXIT_SUCCESS exit $EXIT_SUCCESS
;; ;;
*) *)
# Figure out destination file name, if it wasn't already specified. # Figure out destination file name, if it wasn't already specified.
if test -n "$destname"; then if test -n "$destname"; then
destfile="$destdir/$destname" destfile=$destdir/$destname
else else
func_basename "$file" func_basename "$file"
destfile="$func_basename_result" destfile=$func_basename_result
destfile="$destdir/$destfile" destfile=$destdir/$destfile
fi fi
# If the file is missing, and there is a .exe on the end, strip it # If the file is missing, and there is a .exe on the end, strip it
# because it is most likely a libtool script we actually want to # because it is most likely a libtool script we actually want to
# install # install
stripped_ext="" stripped_ext=
case $file in case $file in
*.exe) *.exe)
if test ! -f "$file"; then if test ! -f "$file"; then
func_stripname '' '.exe' "$file" func_stripname '' '.exe' "$file"
file=$func_stripname_result file=$func_stripname_result
stripped_ext=".exe" stripped_ext=.exe
fi fi
;; ;;
esac esac
# Do a test to see if this is really a libtool program. # Do a test to see if this is really a libtool program.
case $host in case $host in
*cygwin* | *mingw*) *cygwin* | *mingw*)
if func_ltwrapper_executable_p "$file"; then if func_ltwrapper_executable_p "$file"; then
func_ltwrapper_scriptname "$file" func_ltwrapper_scriptname "$file"
wrapper=$func_ltwrapper_scriptname_result wrapper=$func_ltwrapper_scriptname_result
skipping to change at line 3053 skipping to change at line 4325
;; ;;
esac esac
if func_ltwrapper_script_p "$wrapper"; then if func_ltwrapper_script_p "$wrapper"; then
notinst_deplibs= notinst_deplibs=
relink_command= relink_command=
func_source "$wrapper" func_source "$wrapper"
# Check the variables that should have been set. # Check the variables that should have been set.
test -z "$generated_by_libtool_version" && \ test -z "$generated_by_libtool_version" && \
func_fatal_error "invalid libtool wrapper script \`$wrapper'" func_fatal_error "invalid libtool wrapper script '$wrapper'"
finalize=yes finalize=:
for lib in $notinst_deplibs; do for lib in $notinst_deplibs; do
# Check to see that each library is installed. # Check to see that each library is installed.
libdir= libdir=
if test -f "$lib"; then if test -f "$lib"; then
func_source "$lib" func_source "$lib"
fi fi
libfile="$libdir/"`$ECHO "$lib" | $SED 's%^.*/%%g'` ### testsuite: sk ip nested quoting test libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'`
if test -n "$libdir" && test ! -f "$libfile"; then if test -n "$libdir" && test ! -f "$libfile"; then
func_warning "\`$lib' has not been installed in \`$libdir'" func_warning "'$lib' has not been installed in '$libdir'"
finalize=no finalize=false
fi fi
done done
relink_command= relink_command=
func_source "$wrapper" func_source "$wrapper"
outputname= outputname=
if test "$fast_install" = no && test -n "$relink_command"; then if test no = "$fast_install" && test -n "$relink_command"; then
$opt_dry_run || { $opt_dry_run || {
if test "$finalize" = yes; then if $finalize; then
tmpdir=`func_mktempdir` tmpdir=`func_mktempdir`
func_basename "$file$stripped_ext" func_basename "$file$stripped_ext"
file="$func_basename_result" file=$func_basename_result
outputname="$tmpdir/$file" outputname=$tmpdir/$file
# Replace the output file specification. # Replace the output file specification.
relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$out putname"'%g'` relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$out putname"'%g'`
$opt_silent || { $opt_quiet || {
func_quote_for_expand "$relink_command" func_quote_for_expand "$relink_command"
eval "func_echo $func_quote_for_expand_result" eval "func_echo $func_quote_for_expand_result"
} }
if eval "$relink_command"; then : if eval "$relink_command"; then :
else else
func_error "error: relink \`$file' with the above command befor e installing it" func_error "error: relink '$file' with the above command before installing it"
$opt_dry_run || ${RM}r "$tmpdir" $opt_dry_run || ${RM}r "$tmpdir"
continue continue
fi fi
file="$outputname" file=$outputname
else else
func_warning "cannot relink \`$file'" func_warning "cannot relink '$file'"
fi fi
} }
else else
# Install the binary that we compiled earlier. # Install the binary that we compiled earlier.
file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"` file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"`
fi fi
fi fi
# remove .exe since cygwin /usr/bin/install will append another # remove .exe since cygwin /usr/bin/install will append another
# one anyway # one anyway
skipping to change at line 3132 skipping to change at line 4404
func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?'
$opt_dry_run || if test -n "$outputname"; then $opt_dry_run || if test -n "$outputname"; then
${RM}r "$tmpdir" ${RM}r "$tmpdir"
fi fi
;; ;;
esac esac
done done
for file in $staticlibs; do for file in $staticlibs; do
func_basename "$file" func_basename "$file"
name="$func_basename_result" name=$func_basename_result
# Set up the ranlib parameters. # Set up the ranlib parameters.
oldlib="$destdir/$name" oldlib=$destdir/$name
func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 func_to_tool_file "$oldlib" func_convert_file_msys_to_w32
tool_oldlib=$func_to_tool_file_result tool_oldlib=$func_to_tool_file_result
func_show_eval "$install_prog \$file \$oldlib" 'exit $?' func_show_eval "$install_prog \$file \$oldlib" 'exit $?'
if test -n "$stripme" && test -n "$old_striplib"; then if test -n "$stripme" && test -n "$old_striplib"; then
func_show_eval "$old_striplib $tool_oldlib" 'exit $?' func_show_eval "$old_striplib $tool_oldlib" 'exit $?'
fi fi
# Do each command in the postinstall commands. # Do each command in the postinstall commands.
func_execute_cmds "$old_postinstall_cmds" 'exit $?' func_execute_cmds "$old_postinstall_cmds" 'exit $?'
done done
test -n "$future_libdirs" && \ test -n "$future_libdirs" && \
func_warning "remember to run \`$progname --finish$future_libdirs'" func_warning "remember to run '$progname --finish$future_libdirs'"
if test -n "$current_libdirs"; then if test -n "$current_libdirs"; then
# Maybe just do a dry run. # Maybe just do a dry run.
$opt_dry_run && current_libdirs=" -n$current_libdirs" $opt_dry_run && current_libdirs=" -n$current_libdirs"
exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs' exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs'
else else
exit $EXIT_SUCCESS exit $EXIT_SUCCESS
fi fi
} }
test "$opt_mode" = install && func_mode_install ${1+"$@"} test install = "$opt_mode" && func_mode_install ${1+"$@"}
# func_generate_dlsyms outputname originator pic_p # func_generate_dlsyms outputname originator pic_p
# Extract symbols from dlprefiles and create ${outputname}S.o with # Extract symbols from dlprefiles and create ${outputname}S.o with
# a dlpreopen symbol table. # a dlpreopen symbol table.
func_generate_dlsyms () func_generate_dlsyms ()
{ {
$opt_debug $debug_cmd
my_outputname="$1"
my_originator="$2" my_outputname=$1
my_pic_p="${3-no}" my_originator=$2
my_prefix=`$ECHO "$my_originator" | sed 's%[^a-zA-Z0-9]%_%g'` my_pic_p=${3-false}
my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'`
my_dlsyms= my_dlsyms=
if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
if test -n "$NM" && test -n "$global_symbol_pipe"; then if test -n "$NM" && test -n "$global_symbol_pipe"; then
my_dlsyms="${my_outputname}S.c" my_dlsyms=${my_outputname}S.c
else else
func_error "not configured to extract global symbols from dlpreopened fil es" func_error "not configured to extract global symbols from dlpreopened fil es"
fi fi
fi fi
if test -n "$my_dlsyms"; then if test -n "$my_dlsyms"; then
case $my_dlsyms in case $my_dlsyms in
"") ;; "") ;;
*.c) *.c)
# Discover the nlist of each of the dlfiles. # Discover the nlist of each of the dlfiles.
nlist="$output_objdir/${my_outputname}.nm" nlist=$output_objdir/$my_outputname.nm
func_show_eval "$RM $nlist ${nlist}S ${nlist}T" func_show_eval "$RM $nlist ${nlist}S ${nlist}T"
# Parse the name list into a source file. # Parse the name list into a source file.
func_verbose "creating $output_objdir/$my_dlsyms" func_verbose "creating $output_objdir/$my_dlsyms"
$opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\
/* $my_dlsyms - symbol resolution table for \`$my_outputname' dlsym emulation. * /* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */
/ /* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */
/* Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION */
#ifdef __cplusplus #ifdef __cplusplus
extern \"C\" { extern \"C\" {
#endif #endif
#if defined(__GNUC__) && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC_ _ > 4)) #if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4))
#pragma GCC diagnostic ignored \"-Wstrict-prototypes\" #pragma GCC diagnostic ignored \"-Wstrict-prototypes\"
#endif #endif
/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. * / /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. * /
#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE) #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
/* DATA imports from DLLs on WIN32 con't be const, because runtime /* DATA imports from DLLs on WIN32 can't be const, because runtime
relocations are performed -- see ld's documentation on pseudo-relocs. */ relocations are performed -- see ld's documentation on pseudo-relocs. */
# define LT_DLSYM_CONST # define LT_DLSYM_CONST
#elif defined(__osf__) #elif defined __osf__
/* This system does not cope well with relocations in const data. */ /* This system does not cope well with relocations in const data. */
# define LT_DLSYM_CONST # define LT_DLSYM_CONST
#else #else
# define LT_DLSYM_CONST const # define LT_DLSYM_CONST const
#endif #endif
#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
/* External symbol declarations for the compiler. */\ /* External symbol declarations for the compiler. */\
" "
if test "$dlself" = yes; then if test yes = "$dlself"; then
func_verbose "generating symbol list for \`$output'" func_verbose "generating symbol list for '$output'"
$opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist"
# Add our own program objects to the symbol list. # Add our own program objects to the symbol list.
progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP` progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP`
for progfile in $progfiles; do for progfile in $progfiles; do
func_to_tool_file "$progfile" func_convert_file_msys_to_w32 func_to_tool_file "$progfile" func_convert_file_msys_to_w32
func_verbose "extracting global C symbols from \`$func_to_tool_file_r esult'" func_verbose "extracting global C symbols from '$func_to_tool_file_re sult'"
$opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_ pipe >> '$nlist'" $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_ pipe >> '$nlist'"
done done
if test -n "$exclude_expsyms"; then if test -n "$exclude_expsyms"; then
$opt_dry_run || { $opt_dry_run || {
eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T'
eval '$MV "$nlist"T "$nlist"' eval '$MV "$nlist"T "$nlist"'
} }
fi fi
if test -n "$export_symbols_regex"; then if test -n "$export_symbols_regex"; then
$opt_dry_run || { $opt_dry_run || {
eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T'
eval '$MV "$nlist"T "$nlist"' eval '$MV "$nlist"T "$nlist"'
} }
fi fi
# Prepare the list of exported symbols # Prepare the list of exported symbols
if test -z "$export_symbols"; then if test -z "$export_symbols"; then
export_symbols="$output_objdir/$outputname.exp" export_symbols=$output_objdir/$outputname.exp
$opt_dry_run || { $opt_dry_run || {
$RM $export_symbols $RM $export_symbols
eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$ nlist" > "$export_symbols"'
case $host in case $host in
*cygwin* | *mingw* | *cegcc* ) *cygwin* | *mingw* | *cegcc* )
eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"'
;; ;;
esac esac
} }
else else
$opt_dry_run || { $opt_dry_run || {
eval "${SED} -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlis t"T' eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlis t"T'
eval '$MV "$nlist"T "$nlist"' eval '$MV "$nlist"T "$nlist"'
case $host in case $host in
*cygwin* | *mingw* | *cegcc* ) *cygwin* | *mingw* | *cegcc* )
eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' eval 'cat "$nlist" >> "$output_objdir/$outputname.def"'
;; ;;
esac esac
} }
fi fi
fi fi
for dlprefile in $dlprefiles; do for dlprefile in $dlprefiles; do
func_verbose "extracting global C symbols from \`$dlprefile'" func_verbose "extracting global C symbols from '$dlprefile'"
func_basename "$dlprefile" func_basename "$dlprefile"
name="$func_basename_result" name=$func_basename_result
case $host in case $host in
*cygwin* | *mingw* | *cegcc* ) *cygwin* | *mingw* | *cegcc* )
# if an import library, we need to obtain dlname # if an import library, we need to obtain dlname
if func_win32_import_lib_p "$dlprefile"; then if func_win32_import_lib_p "$dlprefile"; then
func_tr_sh "$dlprefile" func_tr_sh "$dlprefile"
eval "curr_lafile=\$libfile_$func_tr_sh_result" eval "curr_lafile=\$libfile_$func_tr_sh_result"
dlprefile_dlbasename="" dlprefile_dlbasename=
if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then
# Use subshell, to avoid clobbering current variable values # Use subshell, to avoid clobbering current variable values
dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"` dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"`
if test -n "$dlprefile_dlname" ; then if test -n "$dlprefile_dlname"; then
func_basename "$dlprefile_dlname" func_basename "$dlprefile_dlname"
dlprefile_dlbasename="$func_basename_result" dlprefile_dlbasename=$func_basename_result
else else
# no lafile. user explicitly requested -dlpreopen <import lib rary>. # no lafile. user explicitly requested -dlpreopen <import lib rary>.
$sharedlib_from_linklib_cmd "$dlprefile" $sharedlib_from_linklib_cmd "$dlprefile"
dlprefile_dlbasename=$sharedlib_from_linklib_result dlprefile_dlbasename=$sharedlib_from_linklib_result
fi fi
fi fi
$opt_dry_run || { $opt_dry_run || {
if test -n "$dlprefile_dlbasename" ; then if test -n "$dlprefile_dlbasename"; then
eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"' eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"'
else else
func_warning "Could not compute DLL name from $name" func_warning "Could not compute DLL name from $name"
eval '$ECHO ": $name " >> "$nlist"' eval '$ECHO ": $name " >> "$nlist"'
fi fi
func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32
eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_s ymbol_pipe | eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_s ymbol_pipe |
$SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist' " $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist' "
} }
else # not an import lib else # not an import lib
skipping to change at line 3357 skipping to change at line 4632
else else
$GREP -v "^: " < "$nlist" > "$nlist"S $GREP -v "^: " < "$nlist" > "$nlist"S
fi fi
if test -f "$nlist"S; then if test -f "$nlist"S; then
eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dl syms"' eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dl syms"'
else else
echo '/* NONE */' >> "$output_objdir/$my_dlsyms" echo '/* NONE */' >> "$output_objdir/$my_dlsyms"
fi fi
func_show_eval '$RM "${nlist}I"'
if test -n "$global_symbol_to_import"; then
eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I'
fi
echo >> "$output_objdir/$my_dlsyms" "\ echo >> "$output_objdir/$my_dlsyms" "\
/* The mapping between symbol names and symbols. */ /* The mapping between symbol names and symbols. */
typedef struct { typedef struct {
const char *name; const char *name;
void *address; void *address;
} lt_dlsymlist; } lt_dlsymlist;
extern LT_DLSYM_CONST lt_dlsymlist extern LT_DLSYM_CONST lt_dlsymlist
lt_${my_prefix}_LTX_preloaded_symbols[]; lt_${my_prefix}_LTX_preloaded_symbols[];\
"
if test -s "$nlist"I; then
echo >> "$output_objdir/$my_dlsyms" "\
static void lt_syminit(void)
{
LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols;
for (; symbol->name; ++symbol)
{"
$SED 's/.*/ if (STREQ (symbol->name, \"&\")) symbol->address = (
void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms"
echo >> "$output_objdir/$my_dlsyms" "\
}
}"
fi
echo >> "$output_objdir/$my_dlsyms" "\
LT_DLSYM_CONST lt_dlsymlist LT_DLSYM_CONST lt_dlsymlist
lt_${my_prefix}_LTX_preloaded_symbols[] = lt_${my_prefix}_LTX_preloaded_symbols[] =
{\ { {\"$my_originator\", (void *) 0},"
{ \"$my_originator\", (void *) 0 },"
if test -s "$nlist"I; then
echo >> "$output_objdir/$my_dlsyms" "\
{\"@INIT@\", (void *) &lt_syminit},"
fi
case $need_lib_prefix in case $need_lib_prefix in
no) no)
eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir /$my_dlsyms" eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir /$my_dlsyms"
;; ;;
*) *)
eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$ou tput_objdir/$my_dlsyms" eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$ou tput_objdir/$my_dlsyms"
;; ;;
esac esac
echo >> "$output_objdir/$my_dlsyms" "\ echo >> "$output_objdir/$my_dlsyms" "\
skipping to change at line 3411 skipping to change at line 4710
# compiling the symbol table file with pic_flag works around # compiling the symbol table file with pic_flag works around
# a FreeBSD bug that causes programs to crash when -lm is # a FreeBSD bug that causes programs to crash when -lm is
# linked before any other PIC object. But we must not use # linked before any other PIC object. But we must not use
# pic_flag when linking with -static. The problem exists in # pic_flag when linking with -static. The problem exists in
# FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. # 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" ;; pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;;
*-*-hpux*) *-*-hpux*)
pic_flag_for_symtable=" $pic_flag" ;; pic_flag_for_symtable=" $pic_flag" ;;
*) *)
if test "X$my_pic_p" != Xno; then $my_pic_p && pic_flag_for_symtable=" $pic_flag"
pic_flag_for_symtable=" $pic_flag"
fi
;; ;;
esac esac
;; ;;
esac esac
symtab_cflags= symtab_cflags=
for arg in $LTCFLAGS; do for arg in $LTCFLAGS; do
case $arg in case $arg in
-pie | -fpie | -fPIE) ;; -pie | -fpie | -fPIE) ;;
*) func_append symtab_cflags " $arg" ;; *) func_append symtab_cflags " $arg" ;;
esac esac
done done
# Now compile the dynamic symbol file. # Now compile the dynamic symbol file.
func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_f lag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_f lag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?'
# Clean up the generated files. # Clean up the generated files.
func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${n list}T"' func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${n list}T" "${nlist}I"'
# Transform the symbol file into the correct name. # Transform the symbol file into the correct name.
symfileobj="$output_objdir/${my_outputname}S.$objext" symfileobj=$output_objdir/${my_outputname}S.$objext
case $host in case $host in
*cygwin* | *mingw* | *cegcc* ) *cygwin* | *mingw* | *cegcc* )
if test -f "$output_objdir/$my_outputname.def"; then if test -f "$output_objdir/$my_outputname.def"; then
compile_command=`$ECHO "$compile_command" | $SED "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@%$outp ut_objdir/$my_outputname.def $symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$outp ut_objdir/$my_outputname.def $symfileobj%"`
else else
compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfil eobj%"` compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfil eobj%"`
finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symf ileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symf ileobj%"`
fi fi
;; ;;
*) *)
compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileo bj%"` compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileo bj%"`
finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfil eobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfil eobj%"`
;; ;;
esac esac
;; ;;
*) *)
func_fatal_error "unknown suffix for \`$my_dlsyms'" func_fatal_error "unknown suffix for '$my_dlsyms'"
;; ;;
esac esac
else else
# We keep going just in case the user didn't refer to # We keep going just in case the user didn't refer to
# lt_preloaded_symbols. The linker will fail if global_symbol_pipe # lt_preloaded_symbols. The linker will fail if global_symbol_pipe
# really was required. # really was required.
# Nullify the symbol file. # Nullify the symbol file.
compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"` compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"`
finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"` finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"`
fi fi
} }
# 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 ()
{
$debug_cmd
func_to_tool_file "$1" func_convert_file_msys_to_w32
func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_s
ymbol_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 ()
{
$debug_cmd
func_to_tool_file "$1" func_convert_file_msys_to_w32
func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_sy
mbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
test -n "$func_cygming_ms_implib_tmp"
}
# func_win32_libid arg # func_win32_libid arg
# return the library type of file 'arg' # return the library type of file 'arg'
# #
# Need a lot of goo to handle *both* DLLs and import libs # Need a lot of goo to handle *both* DLLs and import libs
# Has to be a shell function in order to 'eat' the argument # Has to be a shell function in order to 'eat' the argument
# that is supplied when $file_magic_command is called. # that is supplied when $file_magic_command is called.
# Despite the name, also deal with 64 bit binaries. # Despite the name, also deal with 64 bit binaries.
func_win32_libid () func_win32_libid ()
{ {
$opt_debug $debug_cmd
win32_libid_type="unknown"
win32_libid_type=unknown
win32_fileres=`file -L $1 2>/dev/null` win32_fileres=`file -L $1 2>/dev/null`
case $win32_fileres in case $win32_fileres in
*ar\ archive\ import\ library*) # definitely import *ar\ archive\ import\ library*) # definitely import
win32_libid_type="x86 archive import" win32_libid_type="x86 archive import"
;; ;;
*ar\ archive*) # could be an import, or static *ar\ archive*) # could be an import, or static
# Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD. # 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 | if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null |
$EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86 -64)' >/dev/null; then $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 case $nm_interface in
win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" | "MS dumpbin")
$SED -n -e ' if func_cygming_ms_implib_p "$1" ||
func_cygming_gnu_implib_p "$1"
then
win32_nmres=import
else
win32_nmres=
fi
;;
*)
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{ 1,100{
/ I /{ / I /{
s,.*,import, s|.*|import|
p p
q q
} }
}'` }'`
;;
esac
case $win32_nmres in case $win32_nmres in
import*) win32_libid_type="x86 archive import";; import*) win32_libid_type="x86 archive import";;
*) win32_libid_type="x86 archive static";; *) win32_libid_type="x86 archive static";;
esac esac
fi fi
;; ;;
*DLL*) *DLL*)
win32_libid_type="x86 DLL" win32_libid_type="x86 DLL"
;; ;;
*executable*) # but shell scripts are "executable" too... *executable*) # but shell scripts are "executable" too...
skipping to change at line 3526 skipping to change at line 4863
# #
# Platform-specific function to extract the # Platform-specific function to extract the
# name of the DLL associated with the specified # name of the DLL associated with the specified
# import library ARG. # import library ARG.
# Invoked by eval'ing the libtool variable # Invoked by eval'ing the libtool variable
# $sharedlib_from_linklib_cmd # $sharedlib_from_linklib_cmd
# Result is available in the variable # Result is available in the variable
# $sharedlib_from_linklib_result # $sharedlib_from_linklib_result
func_cygming_dll_for_implib () func_cygming_dll_for_implib ()
{ {
$opt_debug $debug_cmd
sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"` sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"`
} }
# func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs # func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs
# #
# The is the core of a fallback implementation of a # The is the core of a fallback implementation of a
# platform-specific function to extract the name of the # platform-specific function to extract the name of the
# DLL associated with the specified import library LIBNAME. # DLL associated with the specified import library LIBNAME.
# #
# SECTION_NAME is either .idata$6 or .idata$7, depending # SECTION_NAME is either .idata$6 or .idata$7, depending
# on the platform and compiler that created the implib. # on the platform and compiler that created the implib.
# #
# Echos the name of the DLL associated with the # Echos the name of the DLL associated with the
# specified import library. # specified import library.
func_cygming_dll_for_implib_fallback_core () func_cygming_dll_for_implib_fallback_core ()
{ {
$opt_debug $debug_cmd
match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"` match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"`
$OBJDUMP -s --section "$1" "$2" 2>/dev/null | $OBJDUMP -s --section "$1" "$2" 2>/dev/null |
$SED '/^Contents of section '"$match_literal"':/{ $SED '/^Contents of section '"$match_literal"':/{
# Place marker at beginning of archive member dllname section # Place marker at beginning of archive member dllname section
s/.*/====MARK====/ s/.*/====MARK====/
p p
d d
} }
# These lines can sometimes be longer than 43 characters, but # These lines can sometimes be longer than 43 characters, but
# are always uninteresting # are always uninteresting
skipping to change at line 3579 skipping to change at line 4918
x x
s/\n//g s/\n//g
# Remove the marker # Remove the marker
s/^====MARK====// s/^====MARK====//
# Remove trailing dots and whitespace # Remove trailing dots and whitespace
s/[\. \t]*$// s/[\. \t]*$//
# Print # Print
/./p' | /./p' |
# we now have a list, one entry per line, of the stringified # we now have a list, one entry per line, of the stringified
# contents of the appropriate section of all members of the # contents of the appropriate section of all members of the
# archive which possess that section. Heuristic: eliminate # archive that possess that section. Heuristic: eliminate
# all those which have a first or second character that is # all those that have a first or second character that is
# a '.' (that is, objdump's representation of an unprintable # a '.' (that is, objdump's representation of an unprintable
# character.) This should work for all archives with less than # character.) This should work for all archives with less than
# 0x302f exports -- but will fail for DLLs whose name actually # 0x302f exports -- but will fail for DLLs whose name actually
# begins with a literal '.' or a single character followed by # begins with a literal '.' or a single character followed by
# a '.'. # a '.'.
# #
# Of those that remain, print the first one. # Of those that remain, print the first one.
$SED -e '/^\./d;/^.\./d;q' $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_s
ymbol_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_sy
mbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
test -n "$func_cygming_ms_implib_tmp"
}
# func_cygming_dll_for_implib_fallback ARG # func_cygming_dll_for_implib_fallback ARG
# Platform-specific function to extract the # Platform-specific function to extract the
# name of the DLL associated with the specified # name of the DLL associated with the specified
# import library ARG. # import library ARG.
# #
# This fallback implementation is for use when $DLLTOOL # This fallback implementation is for use when $DLLTOOL
# does not support the --identify-strict option. # does not support the --identify-strict option.
# Invoked by eval'ing the libtool variable # Invoked by eval'ing the libtool variable
# $sharedlib_from_linklib_cmd # $sharedlib_from_linklib_cmd
# Result is available in the variable # Result is available in the variable
# $sharedlib_from_linklib_result # $sharedlib_from_linklib_result
func_cygming_dll_for_implib_fallback () func_cygming_dll_for_implib_fallback ()
{ {
$opt_debug $debug_cmd
if func_cygming_gnu_implib_p "$1" ; then
if func_cygming_gnu_implib_p "$1"; then
# binutils import library # binutils import library
sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.i data$7' "$1"` sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.i data$7' "$1"`
elif func_cygming_ms_implib_p "$1" ; then elif func_cygming_ms_implib_p "$1"; then
# ms-generated import library # ms-generated import library
sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.i data$6' "$1"` sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.i data$6' "$1"`
else else
# unknown # unknown
sharedlib_from_linklib_result="" sharedlib_from_linklib_result=
fi fi
} }
# func_extract_an_archive dir oldlib # func_extract_an_archive dir oldlib
func_extract_an_archive () func_extract_an_archive ()
{ {
$opt_debug $debug_cmd
f_ex_an_ar_dir="$1"; shift
f_ex_an_ar_oldlib="$1" f_ex_an_ar_dir=$1; shift
if test "$lock_old_archive_extraction" = yes; then f_ex_an_ar_oldlib=$1
if test yes = "$lock_old_archive_extraction"; then
lockfile=$f_ex_an_ar_oldlib.lock lockfile=$f_ex_an_ar_oldlib.lock
until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
func_echo "Waiting for $lockfile to be removed" func_echo "Waiting for $lockfile to be removed"
sleep 2 sleep 2
done done
fi fi
func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \ func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \
'stat=$?; rm -f "$lockfile"; exit $stat' 'stat=$?; rm -f "$lockfile"; exit $stat'
if test "$lock_old_archive_extraction" = yes; then if test yes = "$lock_old_archive_extraction"; then
$opt_dry_run || rm -f "$lockfile" $opt_dry_run || rm -f "$lockfile"
fi fi
if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
: :
else else
func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_ an_ar_oldlib" func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_ an_ar_oldlib"
fi fi
} }
# func_extract_archives gentop oldlib ... # func_extract_archives gentop oldlib ...
func_extract_archives () func_extract_archives ()
{ {
$opt_debug $debug_cmd
my_gentop="$1"; shift
my_gentop=$1; shift
my_oldlibs=${1+"$@"} my_oldlibs=${1+"$@"}
my_oldobjs="" my_oldobjs=
my_xlib="" my_xlib=
my_xabs="" my_xabs=
my_xdir="" my_xdir=
for my_xlib in $my_oldlibs; do for my_xlib in $my_oldlibs; do
# Extract the objects. # Extract the objects.
case $my_xlib in case $my_xlib in
[\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;; [\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;;
*) my_xabs=`pwd`"/$my_xlib" ;; *) my_xabs=`pwd`"/$my_xlib" ;;
esac esac
func_basename "$my_xlib" func_basename "$my_xlib"
my_xlib="$func_basename_result" my_xlib=$func_basename_result
my_xlib_u=$my_xlib my_xlib_u=$my_xlib
while :; do while :; do
case " $extracted_archives " in case " $extracted_archives " in
*" $my_xlib_u "*) *" $my_xlib_u "*)
func_arith $extracted_serial + 1 func_arith $extracted_serial + 1
extracted_serial=$func_arith_result extracted_serial=$func_arith_result
my_xlib_u=lt$extracted_serial-$my_xlib ;; my_xlib_u=lt$extracted_serial-$my_xlib ;;
*) break ;; *) break ;;
esac esac
done done
extracted_archives="$extracted_archives $my_xlib_u" extracted_archives="$extracted_archives $my_xlib_u"
my_xdir="$my_gentop/$my_xlib_u" my_xdir=$my_gentop/$my_xlib_u
func_mkdir_p "$my_xdir" func_mkdir_p "$my_xdir"
case $host in case $host in
*-darwin*) *-darwin*)
func_verbose "Extracting $my_xabs" func_verbose "Extracting $my_xabs"
# Do not bother doing anything if just a dry run # Do not bother doing anything if just a dry run
$opt_dry_run || { $opt_dry_run || {
darwin_orig_dir=`pwd` darwin_orig_dir=`pwd`
cd $my_xdir || exit $? cd $my_xdir || exit $?
darwin_archive=$my_xabs darwin_archive=$my_xabs
darwin_curdir=`pwd` darwin_curdir=`pwd`
darwin_base_archive=`basename "$darwin_archive"` func_basename "$darwin_archive"
darwin_base_archive=$func_basename_result
darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Archit ectures 2>/dev/null || true` darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Archit ectures 2>/dev/null || true`
if test -n "$darwin_arches"; then if test -n "$darwin_arches"; then
darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'`
darwin_arch= darwin_arch=
func_verbose "$darwin_base_archive has multiple architectures $darwin _arches" func_verbose "$darwin_base_archive has multiple architectures $darwin _arches"
for darwin_arch in $darwin_arches ; do for darwin_arch in $darwin_arches; do
func_mkdir_p "unfat-$$/${darwin_base_archive}-${darwin_arch}" func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch"
$LIPO -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-$ $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$da
{darwin_arch}/${darwin_base_archive}" "${darwin_archive}" rwin_arch/$darwin_base_archive" "$darwin_archive"
cd "unfat-$$/${darwin_base_archive}-${darwin_arch}" cd "unfat-$$/$darwin_base_archive-$darwin_arch"
func_extract_an_archive "`pwd`" "${darwin_base_archive}" func_extract_an_archive "`pwd`" "$darwin_base_archive"
cd "$darwin_curdir" cd "$darwin_curdir"
$RM "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_a rchive}" $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archiv e"
done # $darwin_arches done # $darwin_arches
## Okay now we've a bunch of thin objects, gotta fatten them up :) ## Okay now we've a bunch of thin objects, gotta fatten them up :)
darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*. lo -print | $SED -e "$basename" | sort -u` darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*. lo -print | $SED -e "$sed_basename" | sort -u`
darwin_file= darwin_file=
darwin_files= darwin_files=
for darwin_file in $darwin_filelist; do for darwin_file in $darwin_filelist; do
darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2 SP` darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2 SP`
$LIPO -create -output "$darwin_file" $darwin_files $LIPO -create -output "$darwin_file" $darwin_files
done # $darwin_filelist done # $darwin_filelist
$RM -rf unfat-$$ $RM -rf unfat-$$
cd "$darwin_orig_dir" cd "$darwin_orig_dir"
else else
cd $darwin_orig_dir cd $darwin_orig_dir
skipping to change at line 3746 skipping to change at line 5065
fi # $darwin_arches fi # $darwin_arches
} # !$opt_dry_run } # !$opt_dry_run
;; ;;
*) *)
func_extract_an_archive "$my_xdir" "$my_xabs" func_extract_an_archive "$my_xdir" "$my_xabs"
;; ;;
esac esac
my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \ *.lo -print | sort | $NL2SP` my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \ *.lo -print | sort | $NL2SP`
done done
func_extract_archives_result="$my_oldobjs" func_extract_archives_result=$my_oldobjs
} }
# func_emit_wrapper [arg=no] # func_emit_wrapper [arg=no]
# #
# Emit a libtool wrapper script on stdout. # Emit a libtool wrapper script on stdout.
# Don't directly open a file because we may want to # Don't directly open a file because we may want to
# incorporate the script contents within a cygwin/mingw # incorporate the script contents within a cygwin/mingw
# wrapper executable. Must ONLY be called from within # wrapper executable. Must ONLY be called from within
# func_mode_link because it depends on a number of variables # func_mode_link because it depends on a number of variables
# set therein. # set therein.
# #
# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR # ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR
# variable will take. If 'yes', then the emitted script # variable will take. If 'yes', then the emitted script
# will assume that the directory in which it is stored is # will assume that the directory where it is stored is
# the $objdir directory. This is a cygwin/mingw-specific # the $objdir directory. This is a cygwin/mingw-specific
# behavior. # behavior.
func_emit_wrapper () func_emit_wrapper ()
{ {
func_emit_wrapper_arg1=${1-no} func_emit_wrapper_arg1=${1-no}
$ECHO "\ $ECHO "\
#! $SHELL #! $SHELL
# $output - temporary wrapper script for $objdir/$outputname # $output - temporary wrapper script for $objdir/$outputname
# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION # Generated by $PROGRAM (GNU $PACKAGE) $VERSION
# #
# The $output program cannot be directly executed until all the libtool # The $output program cannot be directly executed until all the libtool
# libraries that it depends on are installed. # libraries that it depends on are installed.
# #
# This wrapper script should never be moved out of the build directory. # This wrapper script should never be moved out of the build directory.
# If it is, it will not operate correctly. # If it is, it will not operate correctly.
# Sed substitution that helps us do robust quoting. It backslashifies # Sed substitution that helps us do robust quoting. It backslashifies
# metacharacters that are still active within double-quoted strings. # metacharacters that are still active within double-quoted strings.
sed_quote_subst='$sed_quote_subst' sed_quote_subst='$sed_quote_subst'
skipping to change at line 3828 skipping to change at line 5147
{ {
eval 'cat <<_LTECHO_EOF eval 'cat <<_LTECHO_EOF
\$1 \$1
_LTECHO_EOF' _LTECHO_EOF'
} }
ECHO=\"$qECHO\" ECHO=\"$qECHO\"
fi fi
# Very basic option parsing. These options are (a) specific to # Very basic option parsing. These options are (a) specific to
# the libtool wrapper, (b) are identical between the wrapper # the libtool wrapper, (b) are identical between the wrapper
# /script/ and the wrapper /executable/ which is used only on # /script/ and the wrapper /executable/ that is used only on
# windows platforms, and (c) all begin with the string "--lt-" # windows platforms, and (c) all begin with the string "--lt-"
# (application programs are unlikely to have options which match # (application programs are unlikely to have options that match
# this pattern). # this pattern).
# #
# There are only two supported options: --lt-debug and # There are only two supported options: --lt-debug and
# --lt-dump-script. There is, deliberately, no --lt-help. # --lt-dump-script. There is, deliberately, no --lt-help.
# #
# The first argument to this parsing function should be the # The first argument to this parsing function should be the
# script's $0 value, followed by "$@". # script's $0 value, followed by "$@".
lt_option_debug= lt_option_debug=
func_parse_lt_options () func_parse_lt_options ()
{ {
skipping to change at line 3863 skipping to change at line 5182
;; ;;
--lt-*) --lt-*)
\$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2 \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2
exit 1 exit 1
;; ;;
esac esac
done done
# Print the debug banner immediately: # Print the debug banner immediately:
if test -n \"\$lt_option_debug\"; then if test -n \"\$lt_option_debug\"; then
echo \"${outputname}:${output}:\${LINENO}: libtool wrapper (GNU $PACKAGE$TIM ESTAMP) $VERSION\" 1>&2 echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION \" 1>&2
fi fi
} }
# Used when --lt-debug. Prints its arguments to stdout # Used when --lt-debug. Prints its arguments to stdout
# (redirection is the responsibility of the caller) # (redirection is the responsibility of the caller)
func_lt_dump_args () func_lt_dump_args ()
{ {
lt_dump_args_N=1; lt_dump_args_N=1;
for lt_arg for lt_arg
do do
\$ECHO \"${outputname}:${output}:\${LINENO}: newargv[\$lt_dump_args_N]: \$lt _arg\" \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\"
lt_dump_args_N=\`expr \$lt_dump_args_N + 1\` lt_dump_args_N=\`expr \$lt_dump_args_N + 1\`
done done
} }
# Core function for launching the target application # Core function for launching the target application
func_exec_program_core () func_exec_program_core ()
{ {
" "
case $host in case $host in
# Backslashes separate directories on plain windows # Backslashes separate directories on plain windows
*-*-mingw | *-*-os2* | *-cegcc*) *-*-mingw | *-*-os2* | *-cegcc*)
$ECHO "\ $ECHO "\
if test -n \"\$lt_option_debug\"; then if test -n \"\$lt_option_debug\"; then
\$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir\\\\\$ program\" 1>&2 \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$progra m\" 1>&2
func_lt_dump_args \${1+\"\$@\"} 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2
fi fi
exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
" "
;; ;;
*) *)
$ECHO "\ $ECHO "\
if test -n \"\$lt_option_debug\"; then if test -n \"\$lt_option_debug\"; then
\$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir/\$pro gram\" 1>&2 \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2
func_lt_dump_args \${1+\"\$@\"} 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2
fi fi
exec \"\$progdir/\$program\" \${1+\"\$@\"} exec \"\$progdir/\$program\" \${1+\"\$@\"}
" "
;; ;;
esac esac
$ECHO "\ $ECHO "\
\$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2
exit 1 exit 1
} }
skipping to change at line 3973 skipping to change at line 5292
*[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$ %%'\` ;; *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$ %%'\` ;;
$objdir ) thisdir=. ;; $objdir ) thisdir=. ;;
esac esac
fi fi
# Try to get the absolute directory name. # Try to get the absolute directory name.
absdir=\`cd \"\$thisdir\" && pwd\` absdir=\`cd \"\$thisdir\" && pwd\`
test -n \"\$absdir\" && thisdir=\"\$absdir\" test -n \"\$absdir\" && thisdir=\"\$absdir\"
" "
if test "$fast_install" = yes; then if test yes = "$fast_install"; then
$ECHO "\ $ECHO "\
program=lt-'$outputname'$exeext program=lt-'$outputname'$exeext
progdir=\"\$thisdir/$objdir\" progdir=\"\$thisdir/$objdir\"
if test ! -f \"\$progdir/\$program\" || if test ! -f \"\$progdir/\$program\" ||
{ file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/ null | ${SED} 1q\`; \\ { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/ null | $SED 1q\`; \\
test \"X\$file\" != \"X\$progdir/\$program\"; }; then test \"X\$file\" != \"X\$progdir/\$program\"; }; then
file=\"\$\$-\$program\" file=\"\$\$-\$program\"
if test ! -d \"\$progdir\"; then if test ! -d \"\$progdir\"; then
$MKDIR \"\$progdir\" $MKDIR \"\$progdir\"
else else
$RM \"\$progdir/\$file\" $RM \"\$progdir/\$file\"
fi" fi"
$ECHO "\ $ECHO "\
# relink executable if necessary # relink executable if necessary
if test -n \"\$relink_command\"; then if test -n \"\$relink_command\"; then
if relink_command_output=\`eval \$relink_command 2>&1\`; then : if relink_command_output=\`eval \$relink_command 2>&1\`; then :
else else
$ECHO \"\$relink_command_output\" >&2 \$ECHO \"\$relink_command_output\" >&2
$RM \"\$progdir/\$file\" $RM \"\$progdir/\$file\"
exit 1 exit 1
fi fi
fi fi
$MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null ||
{ $RM \"\$progdir/\$program\"; { $RM \"\$progdir/\$program\";
$MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; }
$RM \"\$progdir/\$file\" $RM \"\$progdir/\$file\"
fi" fi"
skipping to change at line 4031 skipping to change at line 5350
# to shlibpath, because on Windows, both are PATH and uninstalled # to shlibpath, because on Windows, both are PATH and uninstalled
# libraries must come first. # libraries must come first.
if test -n "$dllsearchpath"; then if test -n "$dllsearchpath"; then
$ECHO "\ $ECHO "\
# Add the dll search path components to the executable PATH # Add the dll search path components to the executable PATH
PATH=$dllsearchpath:\$PATH PATH=$dllsearchpath:\$PATH
" "
fi fi
# Export our shlibpath_var if we have one. # Export our shlibpath_var if we have one.
if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
$ECHO "\ $ECHO "\
# Add our own library path to $shlibpath_var # Add our own library path to $shlibpath_var
$shlibpath_var=\"$temp_rpath\$$shlibpath_var\" $shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
# Some systems cannot cope with colon-terminated $shlibpath_var # Some systems cannot cope with colon-terminated $shlibpath_var
# The second colon is a workaround for a bug in BeOS R4 sed # The second colon is a workaround for a bug in BeOS R4 sed
$shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\` $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\`
export $shlibpath_var export $shlibpath_var
" "
fi fi
$ECHO "\ $ECHO "\
if test \"\$libtool_execute_magic\" != \"$magic\"; then if test \"\$libtool_execute_magic\" != \"$magic\"; then
# Run the actual program with our arguments. # Run the actual program with our arguments.
func_exec_program \${1+\"\$@\"} func_exec_program \${1+\"\$@\"}
fi fi
else else
# The program doesn't exist. # The program doesn't exist.
\$ECHO \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2 \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2
\$ECHO \"This script is just a wrapper for \$program.\" 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 exit 1
fi fi
fi\ fi\
" "
} }
# func_emit_cwrapperexe_src # func_emit_cwrapperexe_src
# emit the source code for a wrapper executable on stdout # emit the source code for a wrapper executable on stdout
# Must ONLY be called from within func_mode_link because # Must ONLY be called from within func_mode_link because
# it depends on a number of variable set therein. # it depends on a number of variable set therein.
func_emit_cwrapperexe_src () func_emit_cwrapperexe_src ()
{ {
cat <<EOF cat <<EOF
/* $cwrappersource - temporary wrapper executable for $objdir/$outputname /* $cwrappersource - temporary wrapper executable for $objdir/$outputname
Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION Generated by $PROGRAM (GNU $PACKAGE) $VERSION
The $output program cannot be directly executed until all the libtool The $output program cannot be directly executed until all the libtool
libraries that it depends on are installed. libraries that it depends on are installed.
This wrapper executable should never be moved out of the build directory. This wrapper executable should never be moved out of the build directory.
If it is, it will not operate correctly. If it is, it will not operate correctly.
*/ */
EOF EOF
cat <<"EOF" cat <<"EOF"
#ifdef _MSC_VER #ifdef _MSC_VER
skipping to change at line 4104 skipping to change at line 5423
#endif #endif
#include <malloc.h> #include <malloc.h>
#include <stdarg.h> #include <stdarg.h>
#include <assert.h> #include <assert.h>
#include <string.h> #include <string.h>
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <fcntl.h> #include <fcntl.h>
#include <sys/stat.h> #include <sys/stat.h>
#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
/* declarations of non-ANSI functions */ /* declarations of non-ANSI functions */
#if defined(__MINGW32__) #if defined __MINGW32__
# ifdef __STRICT_ANSI__ # ifdef __STRICT_ANSI__
int _putenv (const char *); int _putenv (const char *);
# endif # endif
#elif defined(__CYGWIN__) #elif defined __CYGWIN__
# ifdef __STRICT_ANSI__ # ifdef __STRICT_ANSI__
char *realpath (const char *, char *); char *realpath (const char *, char *);
int putenv (char *); int putenv (char *);
int setenv (const char *, const char *, int); int setenv (const char *, const char *, int);
# endif # endif
/* #elif defined (other platforms) ... */ /* #elif defined other_platform || defined ... */
#endif #endif
/* portability defines, excluding path handling macros */ /* portability defines, excluding path handling macros */
#if defined(_MSC_VER) #if defined _MSC_VER
# define setmode _setmode # define setmode _setmode
# define stat _stat # define stat _stat
# define chmod _chmod # define chmod _chmod
# define getcwd _getcwd # define getcwd _getcwd
# define putenv _putenv # define putenv _putenv
# define S_IXUSR _S_IEXEC # define S_IXUSR _S_IEXEC
# ifndef _INTPTR_T_DEFINED #elif defined __MINGW32__
# define _INTPTR_T_DEFINED
# define intptr_t int
# endif
#elif defined(__MINGW32__)
# define setmode _setmode # define setmode _setmode
# define stat _stat # define stat _stat
# define chmod _chmod # define chmod _chmod
# define getcwd _getcwd # define getcwd _getcwd
# define putenv _putenv # define putenv _putenv
#elif defined(__CYGWIN__) #elif defined __CYGWIN__
# define HAVE_SETENV # define HAVE_SETENV
# define FOPEN_WB "wb" # define FOPEN_WB "wb"
/* #elif defined (other platforms) ... */ /* #elif defined other platforms ... */
#endif #endif
#if defined(PATH_MAX) #if defined PATH_MAX
# define LT_PATHMAX PATH_MAX # define LT_PATHMAX PATH_MAX
#elif defined(MAXPATHLEN) #elif defined MAXPATHLEN
# define LT_PATHMAX MAXPATHLEN # define LT_PATHMAX MAXPATHLEN
#else #else
# define LT_PATHMAX 1024 # define LT_PATHMAX 1024
#endif #endif
#ifndef S_IXOTH #ifndef S_IXOTH
# define S_IXOTH 0 # define S_IXOTH 0
#endif #endif
#ifndef S_IXGRP #ifndef S_IXGRP
# define S_IXGRP 0 # define S_IXGRP 0
#endif #endif
/* path handling portability macros */ /* path handling portability macros */
#ifndef DIR_SEPARATOR #ifndef DIR_SEPARATOR
# define DIR_SEPARATOR '/' # define DIR_SEPARATOR '/'
# define PATH_SEPARATOR ':' # define PATH_SEPARATOR ':'
#endif #endif
#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \ #if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \
defined (__OS2__) defined __OS2__
# define HAVE_DOS_BASED_FILE_SYSTEM # define HAVE_DOS_BASED_FILE_SYSTEM
# define FOPEN_WB "wb" # define FOPEN_WB "wb"
# ifndef DIR_SEPARATOR_2 # ifndef DIR_SEPARATOR_2
# define DIR_SEPARATOR_2 '\\' # define DIR_SEPARATOR_2 '\\'
# endif # endif
# ifndef PATH_SEPARATOR_2 # ifndef PATH_SEPARATOR_2
# define PATH_SEPARATOR_2 ';' # define PATH_SEPARATOR_2 ';'
# endif # endif
#endif #endif
skipping to change at line 4197 skipping to change at line 5514
#ifndef FOPEN_WB #ifndef FOPEN_WB
# define FOPEN_WB "w" # define FOPEN_WB "w"
#endif #endif
#ifndef _O_BINARY #ifndef _O_BINARY
# define _O_BINARY 0 # define _O_BINARY 0
#endif #endif
#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) #define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type)))
#define XFREE(stale) do { \ #define XFREE(stale) do { \
if (stale) { free ((void *) stale); stale = 0; } \ if (stale) { free (stale); stale = 0; } \
} while (0) } while (0)
#if defined(LT_DEBUGWRAPPER) #if defined LT_DEBUGWRAPPER
static int lt_debug = 1; static int lt_debug = 1;
#else #else
static int lt_debug = 0; static int lt_debug = 0;
#endif #endif
const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */ const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */
void *xmalloc (size_t num); void *xmalloc (size_t num);
char *xstrdup (const char *string); char *xstrdup (const char *string);
const char *base_name (const char *name); const char *base_name (const char *name);
skipping to change at line 4229 skipping to change at line 5546
static const char *nonempty (const char *s); static const char *nonempty (const char *s);
void lt_setenv (const char *name, const char *value); void lt_setenv (const char *name, const char *value);
char *lt_extend_str (const char *orig_value, const char *add, int to_end); char *lt_extend_str (const char *orig_value, const char *add, int to_end);
void lt_update_exe_path (const char *name, const char *value); void lt_update_exe_path (const char *name, const char *value);
void lt_update_lib_path (const char *name, const char *value); void lt_update_lib_path (const char *name, const char *value);
char **prepare_spawn (char **argv); char **prepare_spawn (char **argv);
void lt_dump_script (FILE *f); void lt_dump_script (FILE *f);
EOF EOF
cat <<EOF cat <<EOF
volatile const char * MAGIC_EXE = "$magic_exe"; #if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 5)
# define externally_visible volatile
#else
# define externally_visible __attribute__((externally_visible)) volatile
#endif
externally_visible const char * MAGIC_EXE = "$magic_exe";
const char * LIB_PATH_VARNAME = "$shlibpath_var"; const char * LIB_PATH_VARNAME = "$shlibpath_var";
EOF EOF
if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_v ar" && test -n "$temp_rpath"; then if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_v ar" && test -n "$temp_rpath"; then
func_to_host_path "$temp_rpath" func_to_host_path "$temp_rpath"
cat <<EOF cat <<EOF
const char * LIB_PATH_VALUE = "$func_to_host_path_result"; const char * LIB_PATH_VALUE = "$func_to_host_path_result";
EOF EOF
else else
cat <<"EOF" cat <<"EOF"
const char * LIB_PATH_VALUE = ""; const char * LIB_PATH_VALUE = "";
EOF EOF
fi fi
skipping to change at line 4257 skipping to change at line 5579
const char * EXE_PATH_VARNAME = "PATH"; const char * EXE_PATH_VARNAME = "PATH";
const char * EXE_PATH_VALUE = "$func_to_host_path_result"; const char * EXE_PATH_VALUE = "$func_to_host_path_result";
EOF EOF
else else
cat <<"EOF" cat <<"EOF"
const char * EXE_PATH_VARNAME = ""; const char * EXE_PATH_VARNAME = "";
const char * EXE_PATH_VALUE = ""; const char * EXE_PATH_VALUE = "";
EOF EOF
fi fi
if test "$fast_install" = yes; then if test yes = "$fast_install"; then
cat <<EOF cat <<EOF
const char * TARGET_PROGRAM_NAME = "lt-$outputname"; /* hopefully, no .exe */ const char * TARGET_PROGRAM_NAME = "lt-$outputname"; /* hopefully, no .exe */
EOF EOF
else else
cat <<EOF cat <<EOF
const char * TARGET_PROGRAM_NAME = "$outputname"; /* hopefully, no .exe */ const char * TARGET_PROGRAM_NAME = "$outputname"; /* hopefully, no .exe */
EOF EOF
fi fi
cat <<"EOF" cat <<"EOF"
skipping to change at line 4285 skipping to change at line 5607
int int
main (int argc, char *argv[]) main (int argc, char *argv[])
{ {
char **newargz; char **newargz;
int newargc; int newargc;
char *tmp_pathspec; char *tmp_pathspec;
char *actual_cwrapper_path; char *actual_cwrapper_path;
char *actual_cwrapper_name; char *actual_cwrapper_name;
char *target_name; char *target_name;
char *lt_argv_zero; char *lt_argv_zero;
intptr_t rval = 127; int rval = 127;
int i; int i;
program_name = (char *) xstrdup (base_name (argv[0])); program_name = (char *) xstrdup (base_name (argv[0]));
newargz = XMALLOC (char *, argc + 1); newargz = XMALLOC (char *, (size_t) 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 * also, copy all non cwrapper options to newargz, except
* argz[0], which is handled differently * argz[0], which is handled differently
*/ */
newargc=0; newargc=0;
for (i = 1; i < argc; i++) for (i = 1; i < argc; i++)
{ {
if (strcmp (argv[i], dumpscript_opt) == 0) if (STREQ (argv[i], dumpscript_opt))
{ {
EOF EOF
case "$host" in case $host in
*mingw* | *cygwin* ) *mingw* | *cygwin* )
# make stdout use "unix" line endings # make stdout use "unix" line endings
echo " setmode(1,_O_BINARY);" echo " setmode(1,_O_BINARY);"
;; ;;
esac esac
cat <<"EOF" cat <<"EOF"
lt_dump_script (stdout); lt_dump_script (stdout);
return 0; return 0;
} }
if (strcmp (argv[i], debug_opt) == 0) if (STREQ (argv[i], debug_opt))
{ {
lt_debug = 1; lt_debug = 1;
continue; continue;
} }
if (strcmp (argv[i], ltwrapper_option_prefix) == 0) if (STREQ (argv[i], ltwrapper_option_prefix))
{ {
/* however, if there is an option in the LTWRAPPER_OPTION_PREFIX /* however, if there is an option in the LTWRAPPER_OPTION_PREFIX
namespace, but it is not one of the ones we know about and namespace, but it is not one of the ones we know about and
have already dealt with, above (inluding dump-script), then have already dealt with, above (inluding dump-script), then
report an error. Otherwise, targets might begin to believe report an error. Otherwise, targets might begin to believe
they are allowed to use options in the LTWRAPPER_OPTION_PREFIX they are allowed to use options in the LTWRAPPER_OPTION_PREFIX
namespace. The first time any user complains about this, we'll namespace. The first time any user complains about this, we'll
need to make LTWRAPPER_OPTION_PREFIX a configure-time option need to make LTWRAPPER_OPTION_PREFIX a configure-time option
or a configure.ac-settable value. or a configure.ac-settable value.
*/ */
skipping to change at line 4341 skipping to change at line 5663
ltwrapper_option_prefix, argv[i]); ltwrapper_option_prefix, argv[i]);
} }
/* otherwise ... */ /* otherwise ... */
newargz[++newargc] = xstrdup (argv[i]); newargz[++newargc] = xstrdup (argv[i]);
} }
newargz[++newargc] = NULL; newargz[++newargc] = NULL;
EOF EOF
cat <<EOF cat <<EOF
/* The GNU banner must be the first non-error debug message */ /* The GNU banner must be the first non-error debug message */
lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\n"); lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE) $VERSION\n ");
EOF EOF
cat <<"EOF" cat <<"EOF"
lt_debugprintf (__FILE__, __LINE__, "(main) argv[0]: %s\n", argv[0]); lt_debugprintf (__FILE__, __LINE__, "(main) argv[0]: %s\n", argv[0]);
lt_debugprintf (__FILE__, __LINE__, "(main) program_name: %s\n", program_name) ; lt_debugprintf (__FILE__, __LINE__, "(main) program_name: %s\n", program_name) ;
tmp_pathspec = find_executable (argv[0]); tmp_pathspec = find_executable (argv[0]);
if (tmp_pathspec == NULL) if (tmp_pathspec == NULL)
lt_fatal (__FILE__, __LINE__, "couldn't find %s", argv[0]); lt_fatal (__FILE__, __LINE__, "couldn't find %s", argv[0]);
lt_debugprintf (__FILE__, __LINE__, lt_debugprintf (__FILE__, __LINE__,
"(main) found exe (before symlink chase) at: %s\n", "(main) found exe (before symlink chase) at: %s\n",
skipping to change at line 4452 skipping to change at line 5774
i, nonnull (newargz[i])); i, nonnull (newargz[i]));
} }
EOF EOF
case $host_os in case $host_os in
mingw*) mingw*)
cat <<"EOF" cat <<"EOF"
/* execv doesn't actually work on mingw as expected on unix */ /* execv doesn't actually work on mingw as expected on unix */
newargz = prepare_spawn (newargz); newargz = prepare_spawn (newargz);
rval = _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz); rval = (int) _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
if (rval == -1) if (rval == -1)
{ {
/* failed to start process */ /* failed to start process */
lt_debugprintf (__FILE__, __LINE__, lt_debugprintf (__FILE__, __LINE__,
"(main) failed to launch target \"%s\": %s\n", "(main) failed to launch target \"%s\": %s\n",
lt_argv_zero, nonnull (strerror (errno))); lt_argv_zero, nonnull (strerror (errno)));
return 127; return 127;
} }
return rval; return rval;
EOF EOF
skipping to change at line 4497 skipping to change at line 5819
{ {
return string ? strcpy ((char *) xmalloc (strlen (string) + 1), return string ? strcpy ((char *) xmalloc (strlen (string) + 1),
string) : NULL; string) : NULL;
} }
const char * const char *
base_name (const char *name) base_name (const char *name)
{ {
const char *base; const char *base;
#if defined (HAVE_DOS_BASED_FILE_SYSTEM) #if defined HAVE_DOS_BASED_FILE_SYSTEM
/* Skip over the disk name in MSDOS pathnames. */ /* Skip over the disk name in MSDOS pathnames. */
if (isalpha ((unsigned char) name[0]) && name[1] == ':') if (isalpha ((unsigned char) name[0]) && name[1] == ':')
name += 2; name += 2;
#endif #endif
for (base = name; *name; name++) for (base = name; *name; name++)
if (IS_DIR_SEPARATOR (*name)) if (IS_DIR_SEPARATOR (*name))
base = name + 1; base = name + 1;
return base; return base;
} }
skipping to change at line 4556 skipping to change at line 5878
Does not chase symlinks, even on platforms that support them. Does not chase symlinks, even on platforms that support them.
*/ */
char * char *
find_executable (const char *wrapper) find_executable (const char *wrapper)
{ {
int has_slash = 0; int has_slash = 0;
const char *p; const char *p;
const char *p_next; const char *p_next;
/* static buffer for getcwd */ /* static buffer for getcwd */
char tmp[LT_PATHMAX + 1]; char tmp[LT_PATHMAX + 1];
int tmp_len; size_t tmp_len;
char *concat_name; char *concat_name;
lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n", lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n",
nonempty (wrapper)); nonempty (wrapper));
if ((wrapper == NULL) || (*wrapper == '\0')) if ((wrapper == NULL) || (*wrapper == '\0'))
return NULL; return NULL;
/* Absolute path? */ /* Absolute path? */
#if defined (HAVE_DOS_BASED_FILE_SYSTEM) #if defined HAVE_DOS_BASED_FILE_SYSTEM
if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':')
{ {
concat_name = xstrdup (wrapper); concat_name = xstrdup (wrapper);
if (check_executable (concat_name)) if (check_executable (concat_name))
return concat_name; return concat_name;
XFREE (concat_name); XFREE (concat_name);
} }
else else
{ {
#endif #endif
if (IS_DIR_SEPARATOR (wrapper[0])) if (IS_DIR_SEPARATOR (wrapper[0]))
{ {
concat_name = xstrdup (wrapper); concat_name = xstrdup (wrapper);
if (check_executable (concat_name)) if (check_executable (concat_name))
return concat_name; return concat_name;
XFREE (concat_name); XFREE (concat_name);
} }
#if defined (HAVE_DOS_BASED_FILE_SYSTEM) #if defined HAVE_DOS_BASED_FILE_SYSTEM
} }
#endif #endif
for (p = wrapper; *p; p++) for (p = wrapper; *p; p++)
if (*p == '/') if (*p == '/')
{ {
has_slash = 1; has_slash = 1;
break; break;
} }
if (!has_slash) if (!has_slash)
skipping to change at line 4607 skipping to change at line 5929
const char *path = getenv ("PATH"); const char *path = getenv ("PATH");
if (path != NULL) if (path != NULL)
{ {
for (p = path; *p; p = p_next) for (p = path; *p; p = p_next)
{ {
const char *q; const char *q;
size_t p_len; size_t p_len;
for (q = p; *q; q++) for (q = p; *q; q++)
if (IS_PATH_SEPARATOR (*q)) if (IS_PATH_SEPARATOR (*q))
break; break;
p_len = q - p; p_len = (size_t) (q - p);
p_next = (*q == '\0' ? q : q + 1); p_next = (*q == '\0' ? q : q + 1);
if (p_len == 0) if (p_len == 0)
{ {
/* empty path: current directory */ /* empty path: current directory */
if (getcwd (tmp, LT_PATHMAX) == NULL) if (getcwd (tmp, LT_PATHMAX) == NULL)
lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", lt_fatal (__FILE__, __LINE__, "getcwd failed: %s",
nonnull (strerror (errno))); nonnull (strerror (errno)));
tmp_len = strlen (tmp); tmp_len = strlen (tmp);
concat_name = concat_name =
XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1);
skipping to change at line 4726 skipping to change at line 6048
assert (str != NULL); assert (str != NULL);
assert (pat != NULL); assert (pat != NULL);
len = strlen (str); len = strlen (str);
patlen = strlen (pat); patlen = strlen (pat);
if (patlen <= len) if (patlen <= len)
{ {
str += len - patlen; str += len - patlen;
if (strcmp (str, pat) == 0) if (STREQ (str, pat))
*str = '\0'; *str = '\0';
} }
return str; return str;
} }
void void
lt_debugprintf (const char *file, int line, const char *fmt, ...) lt_debugprintf (const char *file, int line, const char *fmt, ...)
{ {
va_list args; va_list args;
if (lt_debug) if (lt_debug)
skipping to change at line 4791 skipping to change at line 6113
{ {
lt_debugprintf (__FILE__, __LINE__, lt_debugprintf (__FILE__, __LINE__,
"(lt_setenv) setting '%s' to '%s'\n", "(lt_setenv) setting '%s' to '%s'\n",
nonnull (name), nonnull (value)); nonnull (name), nonnull (value));
{ {
#ifdef HAVE_SETENV #ifdef HAVE_SETENV
/* always make a copy, for consistency with !HAVE_SETENV */ /* always make a copy, for consistency with !HAVE_SETENV */
char *str = xstrdup (value); char *str = xstrdup (value);
setenv (name, str, 1); setenv (name, str, 1);
#else #else
int len = strlen (name) + 1 + strlen (value) + 1; size_t len = strlen (name) + 1 + strlen (value) + 1;
char *str = XMALLOC (char, len); char *str = XMALLOC (char, len);
sprintf (str, "%s=%s", name, value); sprintf (str, "%s=%s", name, value);
if (putenv (str) != EXIT_SUCCESS) if (putenv (str) != EXIT_SUCCESS)
{ {
XFREE (str); XFREE (str);
} }
#endif #endif
} }
} }
char * char *
lt_extend_str (const char *orig_value, const char *add, int to_end) lt_extend_str (const char *orig_value, const char *add, int to_end)
{ {
char *new_value; char *new_value;
if (orig_value && *orig_value) if (orig_value && *orig_value)
{ {
int orig_value_len = strlen (orig_value); size_t orig_value_len = strlen (orig_value);
int add_len = strlen (add); size_t add_len = strlen (add);
new_value = XMALLOC (char, add_len + orig_value_len + 1); new_value = XMALLOC (char, add_len + orig_value_len + 1);
if (to_end) if (to_end)
{ {
strcpy (new_value, orig_value); strcpy (new_value, orig_value);
strcpy (new_value + orig_value_len, add); strcpy (new_value + orig_value_len, add);
} }
else else
{ {
strcpy (new_value, add); strcpy (new_value, add);
strcpy (new_value + add_len, orig_value); strcpy (new_value + add_len, orig_value);
skipping to change at line 4840 skipping to change at line 6162
lt_update_exe_path (const char *name, const char *value) lt_update_exe_path (const char *name, const char *value)
{ {
lt_debugprintf (__FILE__, __LINE__, lt_debugprintf (__FILE__, __LINE__,
"(lt_update_exe_path) modifying '%s' by prepending '%s'\n", "(lt_update_exe_path) modifying '%s' by prepending '%s'\n",
nonnull (name), nonnull (value)); nonnull (name), nonnull (value));
if (name && *name && value && *value) if (name && *name && value && *value)
{ {
char *new_value = lt_extend_str (getenv (name), value, 0); char *new_value = lt_extend_str (getenv (name), value, 0);
/* some systems can't cope with a ':'-terminated path #' */ /* some systems can't cope with a ':'-terminated path #' */
int len = strlen (new_value); size_t len = strlen (new_value);
while (((len = strlen (new_value)) > 0) && IS_PATH_SEPARATOR (new_value[le while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1]))
n-1]))
{ {
new_value[len-1] = '\0'; new_value[--len] = '\0';
} }
lt_setenv (name, new_value); lt_setenv (name, new_value);
XFREE (new_value); XFREE (new_value);
} }
} }
void void
lt_update_lib_path (const char *name, const char *value) lt_update_lib_path (const char *name, const char *value)
{ {
lt_debugprintf (__FILE__, __LINE__, lt_debugprintf (__FILE__, __LINE__,
skipping to change at line 5010 skipping to change at line 6332
cat <<"EOF" cat <<"EOF"
} }
EOF EOF
} }
# end: func_emit_cwrapperexe_src # end: func_emit_cwrapperexe_src
# func_win32_import_lib_p ARG # func_win32_import_lib_p ARG
# True if ARG is an import lib, as indicated by $file_magic_cmd # True if ARG is an import lib, as indicated by $file_magic_cmd
func_win32_import_lib_p () func_win32_import_lib_p ()
{ {
$opt_debug $debug_cmd
case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in
*import*) : ;; *import*) : ;;
*) false ;; *) false ;;
esac esac
} }
# func_suncc_cstd_abi
# !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!!
# Several compiler flags select an ABI that is incompatible with the
# Cstd library. Avoid specifying it if any are in CXXFLAGS.
func_suncc_cstd_abi ()
{
$debug_cmd
case " $compile_command " in
*" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=
stlport4 "*)
suncc_use_cstd_abi=no
;;
*)
suncc_use_cstd_abi=yes
;;
esac
}
# func_mode_link arg... # func_mode_link arg...
func_mode_link () func_mode_link ()
{ {
$opt_debug $debug_cmd
case $host in case $host in
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
# It is impossible to link a dll without this setting, and # It is impossible to link a dll without this setting, and
# we shouldn't force the makefile maintainer to figure out # we shouldn't force the makefile maintainer to figure out
# which system we are compiling for in order to pass an extra # what system we are compiling for in order to pass an extra
# flag for every libtool invocation. # flag for every libtool invocation.
# allow_undefined=no # allow_undefined=no
# FIXME: Unfortunately, there are problems with the above when trying # FIXME: Unfortunately, there are problems with the above when trying
# to make a dll which has undefined symbols, in which case not # to make a dll that has undefined symbols, in which case not
# even a static library is built. For now, we need to specify # even a static library is built. For now, we need to specify
# -no-undefined on the libtool link line when we can be certain # -no-undefined on the libtool link line when we can be certain
# that all symbols are satisfied, otherwise we get a static library. # that all symbols are satisfied, otherwise we get a static library.
allow_undefined=yes allow_undefined=yes
;; ;;
*) *)
allow_undefined=yes allow_undefined=yes
;; ;;
esac esac
libtool_args=$nonopt libtool_args=$nonopt
skipping to change at line 5074 skipping to change at line 6416
dlself=no dlself=no
export_dynamic=no export_dynamic=no
export_symbols= export_symbols=
export_symbols_regex= export_symbols_regex=
generated= generated=
libobjs= libobjs=
ltlibs= ltlibs=
module=no module=no
no_install=no no_install=no
objs= objs=
os2dllname=
non_pic_objects= non_pic_objects=
precious_files_regex= precious_files_regex=
prefer_static_libs=no prefer_static_libs=no
preload=no preload=false
prev= prev=
prevarg= prevarg=
release= release=
rpath= rpath=
xrpath= xrpath=
perm_rpath= perm_rpath=
temp_rpath= temp_rpath=
thread_safe=no thread_safe=no
vinfo= vinfo=
vinfo_number=no vinfo_number=no
weak_libs= weak_libs=
single_module="${wl}-single_module" single_module=$wl-single_module
func_infer_tag $base_compile func_infer_tag $base_compile
# We need to know -static, to get the right output filenames. # We need to know -static, to get the right output filenames.
for arg for arg
do do
case $arg in case $arg in
-shared) -shared)
test "$build_libtool_libs" != yes && \ test yes != "$build_libtool_libs" \
func_fatal_configuration "can not build a shared library" && func_fatal_configuration "cannot build a shared library"
build_old_libs=no build_old_libs=no
break break
;; ;;
-all-static | -static | -static-libtool-libs) -all-static | -static | -static-libtool-libs)
case $arg in case $arg in
-all-static) -all-static)
if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; the n if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; the n
func_warning "complete static linking is impossible in this configura tion" func_warning "complete static linking is impossible in this configura tion"
fi fi
if test -n "$link_static_flag"; then if test -n "$link_static_flag"; then
dlopen_self=$dlopen_self_static dlopen_self=$dlopen_self_static
fi fi
prefer_static_libs=yes prefer_static_libs=yes
;; ;;
-static) -static)
if test -z "$pic_flag" && test -n "$link_static_flag"; then if test -z "$pic_flag" && test -n "$link_static_flag"; then
dlopen_self=$dlopen_self_static dlopen_self=$dlopen_self_static
skipping to change at line 5138 skipping to change at line 6481
break break
;; ;;
esac esac
done done
# See if our shared archives depend on static archives. # See if our shared archives depend on static archives.
test -n "$old_archive_from_new_cmds" && build_old_libs=yes test -n "$old_archive_from_new_cmds" && build_old_libs=yes
# Go through the arguments, transforming them on the way. # Go through the arguments, transforming them on the way.
while test "$#" -gt 0; do while test "$#" -gt 0; do
arg="$1" arg=$1
shift shift
func_quote_for_eval "$arg" func_quote_for_eval "$arg"
qarg=$func_quote_for_eval_unquoted_result qarg=$func_quote_for_eval_unquoted_result
func_append libtool_args " $func_quote_for_eval_result" func_append libtool_args " $func_quote_for_eval_result"
# If the previous option needs an argument, assign it. # If the previous option needs an argument, assign it.
if test -n "$prev"; then if test -n "$prev"; then
case $prev in case $prev in
output) output)
func_append compile_command " @OUTPUT@" func_append compile_command " @OUTPUT@"
func_append finalize_command " @OUTPUT@" func_append finalize_command " @OUTPUT@"
;; ;;
esac esac
case $prev in case $prev in
bindir) bindir)
bindir="$arg" bindir=$arg
prev= prev=
continue continue
;; ;;
dlfiles|dlprefiles) dlfiles|dlprefiles)
if test "$preload" = no; then $preload || {
# Add the symbol object into the linking commands. # Add the symbol object into the linking commands.
func_append compile_command " @SYMFILE@" func_append compile_command " @SYMFILE@"
func_append finalize_command " @SYMFILE@" func_append finalize_command " @SYMFILE@"
preload=yes preload=:
fi }
case $arg in case $arg in
*.la | *.lo) ;; # We handle these cases below. *.la | *.lo) ;; # We handle these cases below.
force) force)
if test "$dlself" = no; then if test no = "$dlself"; then
dlself=needless dlself=needless
export_dynamic=yes export_dynamic=yes
fi fi
prev= prev=
continue continue
;; ;;
self) self)
if test "$prev" = dlprefiles; then if test dlprefiles = "$prev"; then
dlself=yes dlself=yes
elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then
dlself=yes dlself=yes
else else
dlself=needless dlself=needless
export_dynamic=yes export_dynamic=yes
fi fi
prev= prev=
continue continue
;; ;;
*) *)
if test "$prev" = dlfiles; then if test dlfiles = "$prev"; then
func_append dlfiles " $arg" func_append dlfiles " $arg"
else else
func_append dlprefiles " $arg" func_append dlprefiles " $arg"
fi fi
prev= prev=
continue continue
;; ;;
esac esac
;; ;;
expsyms) expsyms)
export_symbols="$arg" export_symbols=$arg
test -f "$arg" \ test -f "$arg" \
|| func_fatal_error "symbol file \`$arg' does not exist" || func_fatal_error "symbol file '$arg' does not exist"
prev= prev=
continue continue
;; ;;
expsyms_regex) expsyms_regex)
export_symbols_regex="$arg" export_symbols_regex=$arg
prev= prev=
continue continue
;; ;;
framework) framework)
case $host in case $host in
*-*-darwin*) *-*-darwin*)
case "$deplibs " in case "$deplibs " in
*" $qarg.ltframework "*) ;; *" $qarg.ltframework "*) ;;
*) func_append deplibs " $qarg.ltframework" # this is fixed later *) func_append deplibs " $qarg.ltframework" # this is fixed later
;; ;;
esac esac
;; ;;
esac esac
prev= prev=
continue continue
;; ;;
inst_prefix) inst_prefix)
inst_prefix_dir="$arg" inst_prefix_dir=$arg
prev=
continue
;;
mllvm)
# Clang does not use LLVM to link, so we can simply discard any
# '-mllvm $arg' options when doing the link step.
prev= prev=
continue continue
;; ;;
objectlist) objectlist)
if test -f "$arg"; then if test -f "$arg"; then
save_arg=$arg save_arg=$arg
moreargs= moreargs=
for fil in `cat "$save_arg"` for fil in `cat "$save_arg"`
do do
# func_append moreargs " $fil" # func_append moreargs " $fil"
skipping to change at line 5249 skipping to change at line 6598
# Check to see that this really is a libtool object. # Check to see that this really is a libtool object.
if func_lalib_unsafe_p "$arg"; then if func_lalib_unsafe_p "$arg"; then
pic_object= pic_object=
non_pic_object= non_pic_object=
# Read the .lo file # Read the .lo file
func_source "$arg" func_source "$arg"
if test -z "$pic_object" || if test -z "$pic_object" ||
test -z "$non_pic_object" || test -z "$non_pic_object" ||
test "$pic_object" = none && test none = "$pic_object" &&
test "$non_pic_object" = none; then test none = "$non_pic_object"; then
func_fatal_error "cannot find name of object for \`$arg'" func_fatal_error "cannot find name of object for '$arg'"
fi fi
# Extract subdirectory from the argument. # Extract subdirectory from the argument.
func_dirname "$arg" "/" "" func_dirname "$arg" "/" ""
xdir="$func_dirname_result" xdir=$func_dirname_result
if test "$pic_object" != none; then if test none != "$pic_object"; then
# Prepend the subdirectory the object is found in. # Prepend the subdirectory the object is found in.
pic_object="$xdir$pic_object" pic_object=$xdir$pic_object
if test "$prev" = dlfiles; then if test dlfiles = "$prev"; then
if test "$build_libtool_libs" = yes && test "$dlopen_support" if test yes = "$build_libtool_libs" && test yes = "$dlopen_su
= yes; then pport"; then
func_append dlfiles " $pic_object" func_append dlfiles " $pic_object"
prev= prev=
continue continue
else else
# If libtool objects are unsupported, then we need to prelo ad. # If libtool objects are unsupported, then we need to prelo ad.
prev=dlprefiles prev=dlprefiles
fi fi
fi fi
# CHECK ME: I think I busted this. -Ossama # CHECK ME: I think I busted this. -Ossama
if test "$prev" = dlprefiles; then if test dlprefiles = "$prev"; then
# Preload the old-style object. # Preload the old-style object.
func_append dlprefiles " $pic_object" func_append dlprefiles " $pic_object"
prev= prev=
fi fi
# A PIC object. # A PIC object.
func_append libobjs " $pic_object" func_append libobjs " $pic_object"
arg="$pic_object" arg=$pic_object
fi fi
# Non-PIC object. # Non-PIC object.
if test "$non_pic_object" != none; then if test none != "$non_pic_object"; then
# Prepend the subdirectory the object is found in. # Prepend the subdirectory the object is found in.
non_pic_object="$xdir$non_pic_object" non_pic_object=$xdir$non_pic_object
# A standard non-PIC object # A standard non-PIC object
func_append non_pic_objects " $non_pic_object" func_append non_pic_objects " $non_pic_object"
if test -z "$pic_object" || test "$pic_object" = none ; then if test -z "$pic_object" || test none = "$pic_object"; then
arg="$non_pic_object" arg=$non_pic_object
fi fi
else else
# If the PIC object exists, use it instead. # If the PIC object exists, use it instead.
# $xdir was prepended to $pic_object above. # $xdir was prepended to $pic_object above.
non_pic_object="$pic_object" non_pic_object=$pic_object
func_append non_pic_objects " $non_pic_object" func_append non_pic_objects " $non_pic_object"
fi fi
else else
# Only an error if not doing a dry-run. # Only an error if not doing a dry-run.
if $opt_dry_run; then if $opt_dry_run; then
# Extract subdirectory from the argument. # Extract subdirectory from the argument.
func_dirname "$arg" "/" "" func_dirname "$arg" "/" ""
xdir="$func_dirname_result" xdir=$func_dirname_result
func_lo2o "$arg" func_lo2o "$arg"
pic_object=$xdir$objdir/$func_lo2o_result pic_object=$xdir$objdir/$func_lo2o_result
non_pic_object=$xdir$func_lo2o_result non_pic_object=$xdir$func_lo2o_result
func_append libobjs " $pic_object" func_append libobjs " $pic_object"
func_append non_pic_objects " $non_pic_object" func_append non_pic_objects " $non_pic_object"
else else
func_fatal_error "\`$arg' is not a valid libtool object" func_fatal_error "'$arg' is not a valid libtool object"
fi fi
fi fi
done done
else else
func_fatal_error "link input file \`$arg' does not exist" func_fatal_error "link input file '$arg' does not exist"
fi fi
arg=$save_arg arg=$save_arg
prev= prev=
continue continue
;; ;;
os2dllname)
os2dllname=$arg
prev=
continue
;;
precious_regex) precious_regex)
precious_files_regex="$arg" precious_files_regex=$arg
prev= prev=
continue continue
;; ;;
release) release)
release="-$arg" release=-$arg
prev= prev=
continue continue
;; ;;
rpath | xrpath) rpath | xrpath)
# We need an absolute path. # We need an absolute path.
case $arg in case $arg in
[\\/]* | [A-Za-z]:[\\/]*) ;; [\\/]* | [A-Za-z]:[\\/]*) ;;
*) *)
func_fatal_error "only absolute run-paths are allowed" func_fatal_error "only absolute run-paths are allowed"
;; ;;
esac esac
if test "$prev" = rpath; then if test rpath = "$prev"; then
case "$rpath " in case "$rpath " in
*" $arg "*) ;; *" $arg "*) ;;
*) func_append rpath " $arg" ;; *) func_append rpath " $arg" ;;
esac esac
else else
case "$xrpath " in case "$xrpath " in
*" $arg "*) ;; *" $arg "*) ;;
*) func_append xrpath " $arg" ;; *) func_append xrpath " $arg" ;;
esac esac
fi fi
prev= prev=
continue continue
;; ;;
shrext) shrext)
shrext_cmds="$arg" shrext_cmds=$arg
prev= prev=
continue continue
;; ;;
weak) weak)
func_append weak_libs " $arg" func_append weak_libs " $arg"
prev= prev=
continue continue
;; ;;
xcclinker) xcclinker)
func_append linker_flags " $qarg" func_append linker_flags " $qarg"
skipping to change at line 5398 skipping to change at line 6752
continue continue
;; ;;
*) *)
eval "$prev=\"\$arg\"" eval "$prev=\"\$arg\""
prev= prev=
continue continue
;; ;;
esac esac
fi # test -n "$prev" fi # test -n "$prev"
prevarg="$arg" prevarg=$arg
case $arg in case $arg in
-all-static) -all-static)
if test -n "$link_static_flag"; then if test -n "$link_static_flag"; then
# See comment for -static flag below, for more details. # See comment for -static flag below, for more details.
func_append compile_command " $link_static_flag" func_append compile_command " $link_static_flag"
func_append finalize_command " $link_static_flag" func_append finalize_command " $link_static_flag"
fi fi
continue continue
;; ;;
-allow-undefined) -allow-undefined)
# FIXME: remove this flag sometime in the future. # FIXME: remove this flag sometime in the future.
func_fatal_error "\`-allow-undefined' must not be used because it is the default" func_fatal_error "'-allow-undefined' must not be used because it is the d efault"
;; ;;
-avoid-version) -avoid-version)
avoid_version=yes avoid_version=yes
continue continue
;; ;;
-bindir) -bindir)
prev=bindir prev=bindir
continue continue
skipping to change at line 5444 skipping to change at line 6798
-export-dynamic) -export-dynamic)
export_dynamic=yes export_dynamic=yes
continue continue
;; ;;
-export-symbols | -export-symbols-regex) -export-symbols | -export-symbols-regex)
if test -n "$export_symbols" || test -n "$export_symbols_regex"; then if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
func_fatal_error "more than one -exported-symbols argument is not allow ed" func_fatal_error "more than one -exported-symbols argument is not allow ed"
fi fi
if test "X$arg" = "X-export-symbols"; then if test X-export-symbols = "X$arg"; then
prev=expsyms prev=expsyms
else else
prev=expsyms_regex prev=expsyms_regex
fi fi
continue continue
;; ;;
-framework) -framework)
prev=framework prev=framework
continue continue
skipping to change at line 5478 skipping to change at line 6832
func_append finalize_command " $arg" func_append finalize_command " $arg"
;; ;;
esac esac
continue continue
;; ;;
-L*) -L*)
func_stripname "-L" '' "$arg" func_stripname "-L" '' "$arg"
if test -z "$func_stripname_result"; then if test -z "$func_stripname_result"; then
if test "$#" -gt 0; then if test "$#" -gt 0; then
func_fatal_error "require no space between \`-L' and \`$1'" func_fatal_error "require no space between '-L' and '$1'"
else else
func_fatal_error "need path for \`-L' option" func_fatal_error "need path for '-L' option"
fi fi
fi fi
func_resolve_sysroot "$func_stripname_result" func_resolve_sysroot "$func_stripname_result"
dir=$func_resolve_sysroot_result dir=$func_resolve_sysroot_result
# We need an absolute path. # We need an absolute path.
case $dir in case $dir in
[\\/]* | [A-Za-z]:[\\/]*) ;; [\\/]* | [A-Za-z]:[\\/]*) ;;
*) *)
absdir=`cd "$dir" && pwd` absdir=`cd "$dir" && pwd`
test -z "$absdir" && \ test -z "$absdir" && \
func_fatal_error "cannot determine absolute directory name of \`$dir' func_fatal_error "cannot determine absolute directory name of '$dir'"
" dir=$absdir
dir="$absdir"
;; ;;
esac esac
case "$deplibs " in case "$deplibs " in
*" -L$dir "* | *" $arg "*) *" -L$dir "* | *" $arg "*)
# Will only happen for absolute or sysroot arguments # Will only happen for absolute or sysroot arguments
;; ;;
*) *)
# Preserve sysroot, but never include relative directories # Preserve sysroot, but never include relative directories
case $dir in case $dir in
[\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;; [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;;
skipping to change at line 5527 skipping to change at line 6881
*":$testbindir:"*) ;; *":$testbindir:"*) ;;
::) dllsearchpath=$testbindir;; ::) dllsearchpath=$testbindir;;
*) func_append dllsearchpath ":$testbindir";; *) func_append dllsearchpath ":$testbindir";;
esac esac
;; ;;
esac esac
continue continue
;; ;;
-l*) -l*)
if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then if test X-lc = "X$arg" || test X-lm = "X$arg"; then
case $host in case $host in
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku *) *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku *)
# These systems don't actually have a C or math library (as such) # These systems don't actually have a C or math library (as such)
continue continue
;; ;;
*-*-os2*) *-*-os2*)
# These systems don't actually have a C library (as such) # These systems don't actually have a C library (as such)
test "X$arg" = "X-lc" && continue test X-lc = "X$arg" && continue
;; ;;
*-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*)
# Do not include libc due to us having libc/libc_r. # Do not include libc due to us having libc/libc_r.
test "X$arg" = "X-lc" && continue test X-lc = "X$arg" && continue
;; ;;
*-*-rhapsody* | *-*-darwin1.[012]) *-*-rhapsody* | *-*-darwin1.[012])
# Rhapsody C and math libraries are in the System framework # Rhapsody C and math libraries are in the System framework
func_append deplibs " System.ltframework" func_append deplibs " System.ltframework"
continue continue
;; ;;
*-*-sco3.2v5* | *-*-sco5v6*) *-*-sco3.2v5* | *-*-sco5v6*)
# Causes problems with __ctype # Causes problems with __ctype
test "X$arg" = "X-lc" && continue test X-lc = "X$arg" && continue
;; ;;
*-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*)
# Compiler inserts libc in the correct place for threads to work # Compiler inserts libc in the correct place for threads to work
test "X$arg" = "X-lc" && continue test X-lc = "X$arg" && continue
;; ;;
esac esac
elif test "X$arg" = "X-lc_r"; then elif test X-lc_r = "X$arg"; then
case $host in case $host in
*-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*)
# Do not include libc_r directly, use -pthread flag. # Do not include libc_r directly, use -pthread flag.
continue continue
;; ;;
esac esac
fi fi
func_append deplibs " $arg" func_append deplibs " $arg"
continue continue
;; ;;
-mllvm)
prev=mllvm
continue
;;
-module) -module)
module=yes module=yes
continue continue
;; ;;
# Tru64 UNIX uses -model [arg] to determine the layout of C++ # Tru64 UNIX uses -model [arg] to determine the layout of C++
# classes, name mangling, and exception handling. # classes, name mangling, and exception handling.
# Darwin uses the -arch flag to determine output architecture. # Darwin uses the -arch flag to determine output architecture.
-model|-arch|-isysroot|--sysroot) -model|-arch|-isysroot|--sysroot)
func_append compiler_flags " $arg" func_append compiler_flags " $arg"
skipping to change at line 5596 skipping to change at line 6955
func_append compile_command " $arg" func_append compile_command " $arg"
func_append finalize_command " $arg" func_append finalize_command " $arg"
case "$new_inherited_linker_flags " in case "$new_inherited_linker_flags " in
*" $arg "*) ;; *" $arg "*) ;;
* ) func_append new_inherited_linker_flags " $arg" ;; * ) func_append new_inherited_linker_flags " $arg" ;;
esac esac
continue continue
;; ;;
-multi_module) -multi_module)
single_module="${wl}-multi_module" single_module=$wl-multi_module
continue continue
;; ;;
-no-fast-install) -no-fast-install)
fast_install=no fast_install=no
continue continue
;; ;;
-no-install) -no-install)
case $host in case $host in
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*)
# The PATH hackery in wrapper scripts is required on Windows # The PATH hackery in wrapper scripts is required on Windows
# and Darwin in order for the loader to find any dlls it needs. # and Darwin in order for the loader to find any dlls it needs.
func_warning "\`-no-install' is ignored for $host" func_warning "'-no-install' is ignored for $host"
func_warning "assuming \`-no-fast-install' instead" func_warning "assuming '-no-fast-install' instead"
fast_install=no fast_install=no
;; ;;
*) no_install=yes ;; *) no_install=yes ;;
esac esac
continue continue
;; ;;
-no-undefined) -no-undefined)
allow_undefined=no allow_undefined=no
continue continue
;; ;;
-objectlist) -objectlist)
prev=objectlist prev=objectlist
continue continue
;; ;;
-os2dllname)
prev=os2dllname
continue
;;
-o) prev=output ;; -o) prev=output ;;
-precious-files-regex) -precious-files-regex)
prev=precious_regex prev=precious_regex
continue continue
;; ;;
-release) -release)
prev=release prev=release
continue continue
skipping to change at line 5716 skipping to change at line 7080
-weak) -weak)
prev=weak prev=weak
continue continue
;; ;;
-Wc,*) -Wc,*)
func_stripname '-Wc,' '' "$arg" func_stripname '-Wc,' '' "$arg"
args=$func_stripname_result args=$func_stripname_result
arg= arg=
save_ifs="$IFS"; IFS=',' save_ifs=$IFS; IFS=,
for flag in $args; do for flag in $args; do
IFS="$save_ifs" IFS=$save_ifs
func_quote_for_eval "$flag" func_quote_for_eval "$flag"
func_append arg " $func_quote_for_eval_result" func_append arg " $func_quote_for_eval_result"
func_append compiler_flags " $func_quote_for_eval_result" func_append compiler_flags " $func_quote_for_eval_result"
done done
IFS="$save_ifs" IFS=$save_ifs
func_stripname ' ' '' "$arg" func_stripname ' ' '' "$arg"
arg=$func_stripname_result arg=$func_stripname_result
;; ;;
-Wl,*) -Wl,*)
func_stripname '-Wl,' '' "$arg" func_stripname '-Wl,' '' "$arg"
args=$func_stripname_result args=$func_stripname_result
arg= arg=
save_ifs="$IFS"; IFS=',' save_ifs=$IFS; IFS=,
for flag in $args; do for flag in $args; do
IFS="$save_ifs" IFS=$save_ifs
func_quote_for_eval "$flag" func_quote_for_eval "$flag"
func_append arg " $wl$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 compiler_flags " $wl$func_quote_for_eval_result"
func_append linker_flags " $func_quote_for_eval_result" func_append linker_flags " $func_quote_for_eval_result"
done done
IFS="$save_ifs" IFS=$save_ifs
func_stripname ' ' '' "$arg" func_stripname ' ' '' "$arg"
arg=$func_stripname_result arg=$func_stripname_result
;; ;;
-Xcompiler) -Xcompiler)
prev=xcompiler prev=xcompiler
continue continue
;; ;;
-Xlinker) -Xlinker)
skipping to change at line 5763 skipping to change at line 7127
;; ;;
-XCClinker) -XCClinker)
prev=xcclinker prev=xcclinker
continue continue
;; ;;
# -msg_* for osf cc # -msg_* for osf cc
-msg_*) -msg_*)
func_quote_for_eval "$arg" func_quote_for_eval "$arg"
arg="$func_quote_for_eval_result" arg=$func_quote_for_eval_result
;; ;;
# Flags to be passed through unchanged, with rationale: # Flags to be passed through unchanged, with rationale:
# -64, -mips[0-9] enable 64-bit mode for the SGI compiler # -64, -mips[0-9] enable 64-bit mode for the SGI compiler
# -r[0-9][0-9]* specify processor 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 # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler
# +DA*, +DD* enable 64-bit mode for the HP compiler # +DA*, +DD* enable 64-bit mode for the HP compiler
# -q* compiler args for the IBM compiler # -q* compiler args for the IBM compiler
# -m*, -t[45]*, -txscale* architecture-specific flags for GCC # -m*, -t[45]*, -txscale* architecture-specific flags for GCC
# -F/path path to uninstalled frameworks, gcc on darwin # -F/path path to uninstalled frameworks, gcc on darwin
# -p, -pg, --coverage, -fprofile-* profiling flags for GCC # -p, -pg, --coverage, -fprofile-* profiling flags for GCC
# -fstack-protector* stack protector flags for GCC
# @file GCC response files # @file GCC response files
# -tp=* Portland pgcc target processor selection # -tp=* Portland pgcc target processor selection
# --sysroot=* for sysroot support # --sysroot=* for sysroot support
# -O*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimizati
on
# -specs=* GCC specs files
# -stdlib=* select c++ std lib with clang
# -fsanitize=* Clang/GCC memory and address sanitizer
-64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
-t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
-O*|-flto*|-fwhopr*|-fuse-linker-plugin) -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*|
\
-specs=*|-fsanitize=*)
func_quote_for_eval "$arg" func_quote_for_eval "$arg"
arg="$func_quote_for_eval_result" arg=$func_quote_for_eval_result
func_append compile_command " $arg" func_append compile_command " $arg"
func_append finalize_command " $arg" func_append finalize_command " $arg"
func_append compiler_flags " $arg" func_append compiler_flags " $arg"
continue continue
;; ;;
-Z*)
if test os2 = "`expr $host : '.*\(os2\)'`"; then
# OS/2 uses -Zxxx to specify OS/2-specific options
compiler_flags="$compiler_flags $arg"
func_append compile_command " $arg"
func_append finalize_command " $arg"
case $arg in
-Zlinker | -Zstack)
prev=xcompiler
;;
esac
continue
else
# Otherwise treat like 'Some other compiler flag' below
func_quote_for_eval "$arg"
arg=$func_quote_for_eval_result
fi
;;
# Some other compiler flag. # Some other compiler flag.
-* | +*) -* | +*)
func_quote_for_eval "$arg" func_quote_for_eval "$arg"
arg="$func_quote_for_eval_result" arg=$func_quote_for_eval_result
;; ;;
*.$objext) *.$objext)
# A standard object. # A standard object.
func_append objs " $arg" func_append objs " $arg"
;; ;;
*.lo) *.lo)
# A libtool-controlled object. # A libtool-controlled object.
# Check to see that this really is a libtool object. # Check to see that this really is a libtool object.
if func_lalib_unsafe_p "$arg"; then if func_lalib_unsafe_p "$arg"; then
pic_object= pic_object=
non_pic_object= non_pic_object=
# Read the .lo file # Read the .lo file
func_source "$arg" func_source "$arg"
if test -z "$pic_object" || if test -z "$pic_object" ||
test -z "$non_pic_object" || test -z "$non_pic_object" ||
test "$pic_object" = none && test none = "$pic_object" &&
test "$non_pic_object" = none; then test none = "$non_pic_object"; then
func_fatal_error "cannot find name of object for \`$arg'" func_fatal_error "cannot find name of object for '$arg'"
fi fi
# Extract subdirectory from the argument. # Extract subdirectory from the argument.
func_dirname "$arg" "/" "" func_dirname "$arg" "/" ""
xdir="$func_dirname_result" xdir=$func_dirname_result
if test "$pic_object" != none; then test none = "$pic_object" || {
# Prepend the subdirectory the object is found in. # Prepend the subdirectory the object is found in.
pic_object="$xdir$pic_object" pic_object=$xdir$pic_object
if test "$prev" = dlfiles; then if test dlfiles = "$prev"; then
if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"
; then ; then
func_append dlfiles " $pic_object" func_append dlfiles " $pic_object"
prev= prev=
continue continue
else else
# If libtool objects are unsupported, then we need to preload. # If libtool objects are unsupported, then we need to preload.
prev=dlprefiles prev=dlprefiles
fi fi
fi fi
# CHECK ME: I think I busted this. -Ossama # CHECK ME: I think I busted this. -Ossama
if test "$prev" = dlprefiles; then if test dlprefiles = "$prev"; then
# Preload the old-style object. # Preload the old-style object.
func_append dlprefiles " $pic_object" func_append dlprefiles " $pic_object"
prev= prev=
fi fi
# A PIC object. # A PIC object.
func_append libobjs " $pic_object" func_append libobjs " $pic_object"
arg="$pic_object" arg=$pic_object
fi }
# Non-PIC object. # Non-PIC object.
if test "$non_pic_object" != none; then if test none != "$non_pic_object"; then
# Prepend the subdirectory the object is found in. # Prepend the subdirectory the object is found in.
non_pic_object="$xdir$non_pic_object" non_pic_object=$xdir$non_pic_object
# A standard non-PIC object # A standard non-PIC object
func_append non_pic_objects " $non_pic_object" func_append non_pic_objects " $non_pic_object"
if test -z "$pic_object" || test "$pic_object" = none ; then if test -z "$pic_object" || test none = "$pic_object"; then
arg="$non_pic_object" arg=$non_pic_object
fi fi
else else
# If the PIC object exists, use it instead. # If the PIC object exists, use it instead.
# $xdir was prepended to $pic_object above. # $xdir was prepended to $pic_object above.
non_pic_object="$pic_object" non_pic_object=$pic_object
func_append non_pic_objects " $non_pic_object" func_append non_pic_objects " $non_pic_object"
fi fi
else else
# Only an error if not doing a dry-run. # Only an error if not doing a dry-run.
if $opt_dry_run; then if $opt_dry_run; then
# Extract subdirectory from the argument. # Extract subdirectory from the argument.
func_dirname "$arg" "/" "" func_dirname "$arg" "/" ""
xdir="$func_dirname_result" xdir=$func_dirname_result
func_lo2o "$arg" func_lo2o "$arg"
pic_object=$xdir$objdir/$func_lo2o_result pic_object=$xdir$objdir/$func_lo2o_result
non_pic_object=$xdir$func_lo2o_result non_pic_object=$xdir$func_lo2o_result
func_append libobjs " $pic_object" func_append libobjs " $pic_object"
func_append non_pic_objects " $non_pic_object" func_append non_pic_objects " $non_pic_object"
else else
func_fatal_error "\`$arg' is not a valid libtool object" func_fatal_error "'$arg' is not a valid libtool object"
fi fi
fi fi
;; ;;
*.$libext) *.$libext)
# An archive. # An archive.
func_append deplibs " $arg" func_append deplibs " $arg"
func_append old_deplibs " $arg" func_append old_deplibs " $arg"
continue continue
;; ;;
*.la) *.la)
# A libtool-controlled library. # A libtool-controlled library.
func_resolve_sysroot "$arg" func_resolve_sysroot "$arg"
if test "$prev" = dlfiles; then if test dlfiles = "$prev"; then
# This library was specified with -dlopen. # This library was specified with -dlopen.
func_append dlfiles " $func_resolve_sysroot_result" func_append dlfiles " $func_resolve_sysroot_result"
prev= prev=
elif test "$prev" = dlprefiles; then elif test dlprefiles = "$prev"; then
# The library was specified with -dlpreopen. # The library was specified with -dlpreopen.
func_append dlprefiles " $func_resolve_sysroot_result" func_append dlprefiles " $func_resolve_sysroot_result"
prev= prev=
else else
func_append deplibs " $func_resolve_sysroot_result" func_append deplibs " $func_resolve_sysroot_result"
fi fi
continue continue
;; ;;
# Some other compiler argument. # Some other compiler argument.
*) *)
# Unknown arguments in both finalize_command and compile_command need # Unknown arguments in both finalize_command and compile_command need
# to be aesthetically quoted because they are evaled later. # to be aesthetically quoted because they are evaled later.
func_quote_for_eval "$arg" func_quote_for_eval "$arg"
arg="$func_quote_for_eval_result" arg=$func_quote_for_eval_result
;; ;;
esac # arg esac # arg
# Now actually substitute the argument into the commands. # Now actually substitute the argument into the commands.
if test -n "$arg"; then if test -n "$arg"; then
func_append compile_command " $arg" func_append compile_command " $arg"
func_append finalize_command " $arg" func_append finalize_command " $arg"
fi fi
done # argument parsing loop done # argument parsing loop
test -n "$prev" && \ test -n "$prev" && \
func_fatal_help "the \`$prevarg' option requires an argument" func_fatal_help "the '$prevarg' option requires an argument"
if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then
eval arg=\"$export_dynamic_flag_spec\" eval arg=\"$export_dynamic_flag_spec\"
func_append compile_command " $arg" func_append compile_command " $arg"
func_append finalize_command " $arg" func_append finalize_command " $arg"
fi fi
oldlibs= oldlibs=
# calculate the name of the file, without its directory # calculate the name of the file, without its directory
func_basename "$output" func_basename "$output"
outputname="$func_basename_result" outputname=$func_basename_result
libobjs_save="$libobjs" libobjs_save=$libobjs
if test -n "$shlibpath_var"; then if test -n "$shlibpath_var"; then
# get the directories listed in $shlibpath_var # get the directories listed in $shlibpath_var
eval shlib_search_path=\`\$ECHO \"\${$shlibpath_var}\" \| \$SED \'s/:/ /g\ '\` eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\ `
else else
shlib_search_path= shlib_search_path=
fi fi
eval sys_lib_search_path=\"$sys_lib_search_path_spec\" eval sys_lib_search_path=\"$sys_lib_search_path_spec\"
eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\"
# Definition is injected by LT_CONFIG during libtool generation.
func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH"
func_dirname "$output" "/" "" func_dirname "$output" "/" ""
output_objdir="$func_dirname_result$objdir" output_objdir=$func_dirname_result$objdir
func_to_tool_file "$output_objdir/" func_to_tool_file "$output_objdir/"
tool_output_objdir=$func_to_tool_file_result tool_output_objdir=$func_to_tool_file_result
# Create the object directory. # Create the object directory.
func_mkdir_p "$output_objdir" func_mkdir_p "$output_objdir"
# Determine the type of output # Determine the type of output
case $output in case $output in
"") "")
func_fatal_help "you must specify an output file" func_fatal_help "you must specify an output file"
;; ;;
skipping to change at line 5973 skipping to change at line 7364
*.la) linkmode=lib ;; *.la) linkmode=lib ;;
*) linkmode=prog ;; # Anything else should be a program. *) linkmode=prog ;; # Anything else should be a program.
esac esac
specialdeplibs= specialdeplibs=
libs= libs=
# Find all interdependent deplibs by searching for libraries # Find all interdependent deplibs by searching for libraries
# that are linked more than once (e.g. -la -lb -la) # that are linked more than once (e.g. -la -lb -la)
for deplib in $deplibs; do for deplib in $deplibs; do
if $opt_preserve_dup_deps ; then if $opt_preserve_dup_deps; then
case "$libs " in case "$libs " in
*" $deplib "*) func_append specialdeplibs " $deplib" ;; *" $deplib "*) func_append specialdeplibs " $deplib" ;;
esac esac
fi fi
func_append libs " $deplib" func_append libs " $deplib"
done done
if test "$linkmode" = lib; then if test lib = "$linkmode"; then
libs="$predeps $libs $compiler_lib_search_path $postdeps" libs="$predeps $libs $compiler_lib_search_path $postdeps"
# Compute libraries that are listed more than once in $predeps # Compute libraries that are listed more than once in $predeps
# $postdeps and mark them as special (i.e., whose duplicates are # $postdeps and mark them as special (i.e., whose duplicates are
# not to be eliminated). # not to be eliminated).
pre_post_deps= pre_post_deps=
if $opt_duplicate_compiler_generated_deps; then if $opt_duplicate_compiler_generated_deps; then
for pre_post_dep in $predeps $postdeps; do for pre_post_dep in $predeps $postdeps; do
case "$pre_post_deps " in case "$pre_post_deps " in
*" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;; *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;;
skipping to change at line 6013 skipping to change at line 7404
notinst_deplibs= # not-installed libtool libraries notinst_deplibs= # not-installed libtool libraries
notinst_path= # paths that contain not-installed libtool libraries notinst_path= # paths that contain not-installed libtool libraries
case $linkmode in case $linkmode in
lib) lib)
passes="conv dlpreopen link" passes="conv dlpreopen link"
for file in $dlfiles $dlprefiles; do for file in $dlfiles $dlprefiles; do
case $file in case $file in
*.la) ;; *.la) ;;
*) *)
func_fatal_help "libraries can \`-dlopen' only libtool libraries: $fi le" func_fatal_help "libraries can '-dlopen' only libtool libraries: $fil e"
;; ;;
esac esac
done done
;; ;;
prog) prog)
compile_deplibs= compile_deplibs=
finalize_deplibs= finalize_deplibs=
alldeplibs=no alldeplibs=false
newdlfiles= newdlfiles=
newdlprefiles= newdlprefiles=
passes="conv scan dlopen dlpreopen link" passes="conv scan dlopen dlpreopen link"
;; ;;
*) passes="conv" *) passes="conv"
;; ;;
esac esac
for pass in $passes; do for pass in $passes; do
# The preopen pass in lib mode reverses $deplibs; put it back here # The preopen pass in lib mode reverses $deplibs; put it back here
# so that -L comes before libs that need it for instance... # so that -L comes before libs that need it for instance...
if test "$linkmode,$pass" = "lib,link"; then if test lib,link = "$linkmode,$pass"; then
## FIXME: Find the place where the list is rebuilt in the wrong ## FIXME: Find the place where the list is rebuilt in the wrong
## order, and fix it there properly ## order, and fix it there properly
tmp_deplibs= tmp_deplibs=
for deplib in $deplibs; do for deplib in $deplibs; do
tmp_deplibs="$deplib $tmp_deplibs" tmp_deplibs="$deplib $tmp_deplibs"
done done
deplibs="$tmp_deplibs" deplibs=$tmp_deplibs
fi fi
if test "$linkmode,$pass" = "lib,link" || if test lib,link = "$linkmode,$pass" ||
test "$linkmode,$pass" = "prog,scan"; then test prog,scan = "$linkmode,$pass"; then
libs="$deplibs" libs=$deplibs
deplibs= deplibs=
fi fi
if test "$linkmode" = prog; then if test prog = "$linkmode"; then
case $pass in case $pass in
dlopen) libs="$dlfiles" ;; dlopen) libs=$dlfiles ;;
dlpreopen) libs="$dlprefiles" ;; dlpreopen) libs=$dlprefiles ;;
link) link)
libs="$deplibs %DEPLIBS%" libs="$deplibs %DEPLIBS%"
test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs" test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs"
;; ;;
esac esac
fi fi
if test "$linkmode,$pass" = "lib,dlpreopen"; then if test lib,dlpreopen = "$linkmode,$pass"; then
# Collect and forward deplibs of preopened libtool libs # Collect and forward deplibs of preopened libtool libs
for lib in $dlprefiles; do for lib in $dlprefiles; do
# Ignore non-libtool-libs # Ignore non-libtool-libs
dependency_libs= dependency_libs=
func_resolve_sysroot "$lib" func_resolve_sysroot "$lib"
case $lib in case $lib in
*.la) func_source "$func_resolve_sysroot_result" ;; *.la) func_source "$func_resolve_sysroot_result" ;;
esac esac
# Collect preopened libtool deplibs, except any this library # Collect preopened libtool deplibs, except any this library
# has declared as weak libs # has declared as weak libs
for deplib in $dependency_libs; do for deplib in $dependency_libs; do
func_basename "$deplib" func_basename "$deplib"
deplib_base=$func_basename_result deplib_base=$func_basename_result
case " $weak_libs " in case " $weak_libs " in
*" $deplib_base "*) ;; *" $deplib_base "*) ;;
*) func_append deplibs " $deplib" ;; *) func_append deplibs " $deplib" ;;
esac esac
done done
done done
libs="$dlprefiles" libs=$dlprefiles
fi fi
if test "$pass" = dlopen; then if test dlopen = "$pass"; then
# Collect dlpreopened libraries # Collect dlpreopened libraries
save_deplibs="$deplibs" save_deplibs=$deplibs
deplibs= deplibs=
fi fi
for deplib in $libs; do for deplib in $libs; do
lib= lib=
found=no found=false
case $deplib in case $deplib in
-mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \
|-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*)
if test "$linkmode,$pass" = "prog,link"; then if test prog,link = "$linkmode,$pass"; then
compile_deplibs="$deplib $compile_deplibs" compile_deplibs="$deplib $compile_deplibs"
finalize_deplibs="$deplib $finalize_deplibs" finalize_deplibs="$deplib $finalize_deplibs"
else else
func_append compiler_flags " $deplib" func_append compiler_flags " $deplib"
if test "$linkmode" = lib ; then if test lib = "$linkmode"; then
case "$new_inherited_linker_flags " in case "$new_inherited_linker_flags " in
*" $deplib "*) ;; *" $deplib "*) ;;
* ) func_append new_inherited_linker_flags " $deplib" ;; * ) func_append new_inherited_linker_flags " $deplib" ;;
esac esac
fi fi
fi fi
continue continue
;; ;;
-l*) -l*)
if test "$linkmode" != lib && test "$linkmode" != prog; then if test lib != "$linkmode" && test prog != "$linkmode"; then
func_warning "\`-l' is ignored for archives/objects" func_warning "'-l' is ignored for archives/objects"
continue continue
fi fi
func_stripname '-l' '' "$deplib" func_stripname '-l' '' "$deplib"
name=$func_stripname_result name=$func_stripname_result
if test "$linkmode" = lib; then if test lib = "$linkmode"; then
searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search _dirs $sys_lib_search_path $shlib_search_path" searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search _dirs $sys_lib_search_path $shlib_search_path"
else else
searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path"
fi fi
for searchdir in $searchdirs; do for searchdir in $searchdirs; do
for search_ext in .la $std_shrext .so .a; do for search_ext in .la $std_shrext .so .a; do
# Search the libtool library # Search the libtool library
lib="$searchdir/lib${name}${search_ext}" lib=$searchdir/lib$name$search_ext
if test -f "$lib"; then if test -f "$lib"; then
if test "$search_ext" = ".la"; then if test .la = "$search_ext"; then
found=yes found=:
else else
found=no found=false
fi fi
break 2 break 2
fi fi
done done
done done
if test "$found" != yes; then if $found; then
# deplib doesn't seem to be a libtool library # deplib is a libtool library
if test "$linkmode,$pass" = "prog,link"; then
compile_deplibs="$deplib $compile_deplibs"
finalize_deplibs="$deplib $finalize_deplibs"
else
deplibs="$deplib $deplibs"
test "$linkmode" = lib && newdependency_libs="$deplib $newdependenc
y_libs"
fi
continue
else # deplib is a libtool library
# If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib,
# We need to do some special things here, and not later. # We need to do some special things here, and not later.
if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then if test yes = "$allow_libtool_libs_with_static_runtimes"; then
case " $predeps $postdeps " in case " $predeps $postdeps " in
*" $deplib "*) *" $deplib "*)
if func_lalib_p "$lib"; then if func_lalib_p "$lib"; then
library_names= library_names=
old_library= old_library=
func_source "$lib" func_source "$lib"
for l in $old_library $library_names; do for l in $old_library $library_names; do
ll="$l" ll=$l
done done
if test "X$ll" = "X$old_library" ; then # only static version a if test "X$ll" = "X$old_library"; then # only static version