debian/0000755000000000000000000000000012067077540007176 5ustar debian/compat0000644000000000000000000000000212067065013010364 0ustar 9 debian/patches/0000755000000000000000000000000012067076566010634 5ustar debian/patches/03-uptodate-ltmain.diff0000644000000000000000000151770412067064404015020 0ustar # Fixes lintian warning: We want an up to date ltmain.sh. @DPATCH@ --- swh-plugins-0.4.15+1.orig/ltmain.sh 2009-07-29 13:33:20.000000000 +0200 +++ swh-plugins-0.4.15+1/ltmain.sh 2009-07-29 13:37:17.000000000 +0200 @@ -1,8203 +1,6012 @@ -# Generated from ltmain.m4sh. - -# ltmain.sh (GNU libtool) 2.2.6 -# Written by Gordon Matzigkeit , 1996 - -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, 2007 2008 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. - -# GNU Libtool is free software; you can redistribute it and/or modify +# ltmain.sh - Provide generalized library-building support services. +# NOTE: Changing this file will not affect anything until you rerun configure. +# +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004 +# Free Software Foundation, Inc. +# Originally by Gordon Matzigkeit , 1996 +# +# 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 2 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. -# -# GNU Libtool is distributed in the hope that it will be useful, but +# 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 GNU Libtool; see the file COPYING. If not, a copy -# can be downloaded from http://www.gnu.org/licenses/gpl.html, -# or obtained by writing to the Free Software Foundation, Inc., -# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - -# Usage: $progname [OPTION]... [MODE-ARG]... -# -# Provide generalized library-building support services. +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. # -# --config show all configuration variables -# --debug enable verbose shell tracing -# -n, --dry-run display commands without modifying any files -# --features display basic configuration information and exit -# --mode=MODE use operation mode MODE -# --preserve-dup-deps don't remove duplicate dependency libraries -# --quiet, --silent don't print informational messages -# --tag=TAG use configuration variables from tag TAG -# -v, --verbose print informational messages (default) -# --version print version information -# -h, --help print short or long help message -# -# 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. -# Try `$progname --help --mode=MODE' for a more detailed description of MODE. -# -# When reporting a bug, please describe a test case to reproduce it and -# include the following information: -# -# host-triplet: $host -# shell: $SHELL -# compiler: $LTCC -# compiler flags: $LTCFLAGS -# linker: $LD (gnu? $with_gnu_ld) -# $progname: (GNU libtool) 2.2.6 Debian-2.2.6a-4 -# automake: $automake_version -# autoconf: $autoconf_version -# -# Report bugs to . - -PROGRAM=ltmain.sh -PACKAGE=libtool -VERSION="2.2.6 Debian-2.2.6a-4" -TIMESTAMP="" -package_revision=1.3012 - -# Be Bourne compatible -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac -fi -BIN_SH=xpg4; export BIN_SH # for Tru64 -DUALCASE=1; export DUALCASE # for MKS sh - -# NLS nuisances: We save the old values to restore during execute mode. -# Only set LANG and LC_ALL to C if already set. -# These must not be set unconditionally because not all systems understand -# e.g. LANG=C (notably SCO). -lt_user_locale= -lt_safe_locale= -for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES -do - eval "if test \"\${$lt_var+set}\" = set; then - save_$lt_var=\$$lt_var - $lt_var=C - export $lt_var - lt_user_locale=\"$lt_var=\\\$save_\$lt_var; \$lt_user_locale\" - lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\" - fi" -done - -$lt_unset CDPATH - +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. +basename="s,^.*/,,g" +# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh +# is ksh but when the shell is invoked as "sh" and the current value of +# the _XPG environment variable is not equal to 1 (one), the special +# positional parameter $0, within a function call, is the name of the +# function. +progpath="$0" +# RH: define SED for historic ltconfig's generated by Libtool 1.3 +[ -z "$SED" ] && SED=sed -: ${CP="cp -f"} -: ${ECHO="echo"} -: ${EGREP="/bin/grep -E"} -: ${FGREP="/bin/grep -F"} -: ${GREP="/bin/grep"} -: ${LN_S="ln -s"} -: ${MAKE="make"} -: ${MKDIR="mkdir"} -: ${MV="mv -f"} -: ${RM="rm -f"} -: ${SED="/bin/sed"} -: ${SHELL="${CONFIG_SHELL-/bin/sh}"} -: ${Xsed="$SED -e 1s/^X//"} +# The name of this program: +progname=`echo "$progpath" | $SED $basename` +modename="$progname" # 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 - -# Make sure IFS has a sensible default -lt_nl=' -' -IFS=" $lt_nl" - -dirname="s,/[^/]*$,," -basename="s,^.*/,," - -# 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" -# 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 "X${1}" | $Xsed -e "$dirname"` - if test "X$func_dirname_result" = "X${1}"; then - func_dirname_result="${3}" - else - func_dirname_result="$func_dirname_result${2}" - fi - func_basename_result=`$ECHO "X${1}" | $Xsed -e "$basename"` -} +PROGRAM=ltmain.sh +PACKAGE=libtool +VERSION=1.5.6 +TIMESTAMP=" (1.1220.2.95 2004/04/11 05:50:42)" -# Generated shell functions inserted here. -# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh -# is ksh but when the shell is invoked as "sh" and the current value of -# the _XPG environment variable is not equal to 1 (one), the special -# positional parameter $0, within a function call, is the name of the -# function. -progpath="$0" +# Check that we have a working $echo. +if test "X$1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X$1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`($echo '\t') 2>/dev/null`" = 'X\t'; then + # Yippee, $echo works! + : +else + # Restart under the correct shell, and then maybe $echo will work. + exec $SHELL "$progpath" --no-reexec ${1+"$@"} +fi -# The name of this program: -# In the unlikely event $progname began with a '-', it would play havoc with -# func_echo (imagine progname=-n), so we prepend ./ in that case: -func_dirname_and_basename "$progpath" -progname=$func_basename_result -case $progname in - -*) progname=./$progname ;; -esac +if test "X$1" = X--fallback-echo; then + # used as fallback echo + shift + cat <&2 -} +# Make sure IFS has a sensible default +: ${IFS=" +"} -# func_warning arg... -# Echo program name prefixed warning message to standard error. -func_warning () -{ - $opt_warning && $ECHO "$progname${mode+: }$mode: warning: "${1+"$@"} 1>&2 +if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then + $echo "$modename: not configured to build any kind of library" 1>&2 + $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2 + exit $EXIT_FAILURE +fi - # bash bug again: - : -} +# Global variables. +mode=$default_mode +nonopt= +prev= +prevopt= +run= +show="$echo" +show_help= +execute_dlfiles= +lo2o="s/\\.lo\$/.${objext}/" +o2lo="s/\\.${objext}\$/.lo/" -# func_fatal_error arg... -# Echo program name prefixed message to standard error, and exit. -func_fatal_error () -{ - func_error ${1+"$@"} - exit $EXIT_FAILURE -} +##################################### +# Shell function definitions: +# This seems to be the best place for them -# func_fatal_help arg... -# Echo program name prefixed message to standard error, followed by -# a help hint, and exit. -func_fatal_help () -{ - func_error ${1+"$@"} - func_fatal_error "$help" +# func_win32_libid arg +# return the library type of file 'arg' +# +# Need a lot of goo to handle *both* DLLs and import libs +# Has to be a shell function in order to 'eat' the argument +# that is supplied when $file_magic_command is called. +func_win32_libid () { + win32_libid_type="unknown" + win32_fileres=`file -L $1 2>/dev/null` + case $win32_fileres in + *ar\ archive\ import\ library*) # definitely import + win32_libid_type="x86 archive import" + ;; + *ar\ archive*) # could be an import, or static + if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | \ + $EGREP -e 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then + win32_nmres=`eval $NM -f posix -A $1 | \ + sed -n -e '1,100{/ I /{x;/import/!{s/^/import/;h;p;};x;};}'` + if test "X$win32_nmres" = "Ximport" ; then + win32_libid_type="x86 archive import" + else + win32_libid_type="x86 archive static" + fi + fi + ;; + *DLL*) + win32_libid_type="x86 DLL" + ;; + *executable*) # but shell scripts are "executable" too... + case $win32_fileres in + *MS\ Windows\ PE\ Intel*) + win32_libid_type="x86 DLL" + ;; + esac + ;; + esac + $echo $win32_libid_type } -help="Try \`$progname --help' for more information." ## default -# func_grep expression filename -# Check whether EXPRESSION matches any line of FILENAME, without output. -func_grep () -{ - $GREP "$1" "$2" >/dev/null 2>&1 +# func_infer_tag arg +# Infer tagged configuration to use if any are available and +# if one wasn't chosen via the "--tag" command line option. +# Only attempt this if the compiler in the base compile +# command doesn't match the default compiler. +# arg is usually of the form 'gcc ...' +func_infer_tag () { + if test -n "$available_tags" && test -z "$tagname"; then + CC_quoted= + for arg in $CC; do + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + CC_quoted="$CC_quoted $arg" + done + case $@ in + # Blanks in the command may have been stripped by the calling shell, + # but not from the CC environment variable when configure was run. + " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) ;; + # Blanks at the start of $base_compile will cause this to fail + # if we don't check for them as well. + *) + for z in $available_tags; do + if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then + # Evaluate the configuration. + eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" + CC_quoted= + for arg in $CC; do + # Double-quote args containing other shell metacharacters. + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + CC_quoted="$CC_quoted $arg" + done + case "$@ " in + " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) + # The compiler in the base compile command matches + # the one in the tagged configuration. + # Assume this is the tagged configuration we want. + tagname=$z + break + ;; + esac + fi + done + # If $tagname still isn't set, then no tagged configuration + # was found and let the user know that the "--tag" command + # line option must be used. + if test -z "$tagname"; then + $echo "$modename: unable to infer tagged configuration" + $echo "$modename: specify a tag with \`--tag'" 1>&2 + exit $EXIT_FAILURE +# else +# $echo "$modename: using $tagname tagged configuration" + fi + ;; + esac + fi } +# End of Shell function definitions +##################################### +# Darwin sucks +eval std_shrext=\"$shrext_cmds\" -# func_mkdir_p directory-path -# Make sure the entire path to DIRECTORY-PATH is available. -func_mkdir_p () -{ - my_directory_path="$1" - my_dir_list= +# Parse our command line options once, thoroughly. +while test "$#" -gt 0 +do + arg="$1" + shift - if test -n "$my_directory_path" && test "$opt_dry_run" != ":"; then + case $arg in + -*=*) optarg=`$echo "X$arg" | $Xsed -e 's/[-_a-zA-Z0-9]*=//'` ;; + *) optarg= ;; + esac - # Protect directory names starting with `-' - case $my_directory_path in - -*) my_directory_path="./$my_directory_path" ;; + # If the previous option needs an argument, assign it. + if test -n "$prev"; then + case $prev in + execute_dlfiles) + execute_dlfiles="$execute_dlfiles $arg" + ;; + tag) + tagname="$arg" + preserve_args="${preserve_args}=$arg" + + # Check whether tagname contains only valid characters + case $tagname in + *[!-_A-Za-z0-9,/]*) + $echo "$progname: invalid tag name: $tagname" 1>&2 + exit $EXIT_FAILURE + ;; esac - # While some portion of DIR does not yet exist... - while test ! -d "$my_directory_path"; do - # ...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" + case $tagname in + CC) + # Don't test for the "default" C tag, as we know, it's there, but + # not specially marked. + ;; + *) + if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "$progpath" > /dev/null; then + taglist="$taglist $tagname" + # Evaluate the configuration. + eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$tagname'$/,/^# ### END LIBTOOL TAG CONFIG: '$tagname'$/p' < $progpath`" + else + $echo "$progname: ignoring unknown tag $tagname" 1>&2 + fi + ;; + esac + ;; + *) + eval "$prev=\$arg" + ;; + esac - # If the last portion added has no slash in it, the list is done - case $my_directory_path in */*) ;; *) break ;; esac + prev= + prevopt= + continue + fi - # ...otherwise throw away the child directory and loop - my_directory_path=`$ECHO "X$my_directory_path" | $Xsed -e "$dirname"` - done - my_dir_list=`$ECHO "X$my_dir_list" | $Xsed -e 's,:*$,,'` + # Have we seen a non-optional argument yet? + case $arg in + --help) + show_help=yes + ;; - save_mkdir_p_IFS="$IFS"; IFS=':' - for my_dir in $my_dir_list; do - IFS="$save_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 "$my_dir" 2>/dev/null || : - done - IFS="$save_mkdir_p_IFS" + --version) + $echo "$PROGRAM (GNU $PACKAGE) $VERSION$TIMESTAMP" + $echo + $echo "Copyright (C) 2003 Free Software Foundation, Inc." + $echo "This is free software; see the source for copying conditions. There is NO" + $echo "warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + exit $EXIT_SUCCESS + ;; - # Bail out if we (or some other process) failed to create a directory. - test -d "$my_directory_path" || \ - func_fatal_error "Failed to create \`$1'" - fi -} + --config) + ${SED} -e '1,/^# ### BEGIN LIBTOOL CONFIG/d' -e '/^# ### END LIBTOOL CONFIG/,$d' $progpath + # Now print the configurations for the tags. + for tagname in $taglist; do + ${SED} -n -e "/^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$/,/^# ### END LIBTOOL TAG CONFIG: $tagname$/p" < "$progpath" + done + exit $EXIT_SUCCESS + ;; + --debug) + $echo "$progname: enabling shell trace mode" + set -x + preserve_args="$preserve_args $arg" + ;; -# func_mktempdir [string] -# Make a temporary directory that won't clash with other running -# libtool processes, and avoids race conditions if possible. If -# given, STRING is the basename for that directory. -func_mktempdir () -{ - my_template="${TMPDIR-/tmp}/${1-$progname}" + --dry-run | -n) + run=: + ;; - if test "$opt_dry_run" = ":"; then - # Return a directory name, but don't create it in dry-run mode - my_tmpdir="${my_template}-$$" + --features) + $echo "host: $host" + if test "$build_libtool_libs" = yes; then + $echo "enable shared libraries" else - - # If mktemp works, use that first and foremost - my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null` - - if test ! -d "$my_tmpdir"; then - # Failing that, at least try and use $RANDOM to avoid a race - my_tmpdir="${my_template}-${RANDOM-0}$$" - - save_mktempdir_umask=`umask` - umask 0077 - $MKDIR "$my_tmpdir" - umask $save_mktempdir_umask - fi - - # If we're not in dry-run mode, bomb out on failure - test -d "$my_tmpdir" || \ - func_fatal_error "cannot create temporary directory \`$my_tmpdir'" + $echo "disable shared libraries" + fi + if test "$build_old_libs" = yes; then + $echo "enable static libraries" + else + $echo "disable static libraries" fi + exit $EXIT_SUCCESS + ;; - $ECHO "X$my_tmpdir" | $Xsed -} + --finish) mode="finish" ;; + --mode) prevopt="--mode" prev=mode ;; + --mode=*) mode="$optarg" ;; -# func_quote_for_eval arg -# Aesthetically quote ARG to be evaled later. -# This function returns two values: FUNC_QUOTE_FOR_EVAL_RESULT -# is double-quoted, suitable for a subsequent eval, whereas -# FUNC_QUOTE_FOR_EVAL_UNQUOTED_RESULT has merely all characters -# which are still active within double quotes backslashified. -func_quote_for_eval () -{ - case $1 in - *[\\\`\"\$]*) - func_quote_for_eval_unquoted_result=`$ECHO "X$1" | $Xsed -e "$sed_quote_subst"` ;; - *) - func_quote_for_eval_unquoted_result="$1" ;; - esac + --preserve-dup-deps) duplicate_deps="yes" ;; - case $func_quote_for_eval_unquoted_result in - # Double-quote args containing shell metacharacters to delay - # word splitting, command substitution and and variable - # expansion for a subsequent eval. - # 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 -} + --quiet | --silent) + show=: + preserve_args="$preserve_args $arg" + ;; + --tag) prevopt="--tag" prev=tag ;; + --tag=*) + set tag "$optarg" ${1+"$@"} + shift + prev=tag + preserve_args="$preserve_args --tag" + ;; -# 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 () -{ - case $1 in - *[\\\`\"]*) - my_arg=`$ECHO "X$1" | $Xsed \ - -e "$double_quote_subst" -e "$sed_double_backslash"` ;; - *) - my_arg="$1" ;; - esac + -dlopen) + prevopt="-dlopen" + prev=execute_dlfiles + ;; - 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 + -*) + $echo "$modename: unrecognized option \`$arg'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; - func_quote_for_expand_result="$my_arg" -} + *) + nonopt="$arg" + break + ;; + esac +done +if test -n "$prevopt"; then + $echo "$modename: option \`$prevopt' requires an argument" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE +fi -# func_show_eval cmd [fail_exp] -# 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 -# is given, then evaluate it. -func_show_eval () -{ - my_cmd="$1" - 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 - eval "$my_cmd" - my_status=$? - if test "$my_status" -eq 0; then :; else - eval "(exit $my_status); $my_fail_exp" - fi - fi -} +# 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= +if test -z "$show_help"; then -# func_show_eval_locale cmd [fail_exp] -# 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 -# is given, then evaluate it. Use the saved locale for evaluation. -func_show_eval_locale () -{ - my_cmd="$1" - my_fail_exp="${2-:}" + # Infer the operation mode. + if test -z "$mode"; then + $echo "*** Warning: inferring the mode of operation is deprecated." 1>&2 + $echo "*** Future versions of Libtool will require -mode=MODE be specified." 1>&2 + case $nonopt in + *cc | cc* | *++ | gcc* | *-gcc* | g++* | xlc*) + mode=link + for arg + do + case $arg in + -c) + mode=compile + break + ;; + esac + done + ;; + *db | *dbx | *strace | *truss) + mode=execute + ;; + *install*|cp|mv) + mode=install + ;; + *rm) + mode=uninstall + ;; + *) + # If we have no mode, but dlfiles were specified, then do execute mode. + test -n "$execute_dlfiles" && mode=execute - ${opt_silent-false} || { - func_quote_for_expand "$my_cmd" - eval "func_echo $func_quote_for_expand_result" - } - - if ${opt_dry_run-false}; then :; else - eval "$lt_user_locale - $my_cmd" - my_status=$? - eval "$lt_safe_locale" - if test "$my_status" -eq 0; then :; else - eval "(exit $my_status); $my_fail_exp" + # Just use the default operation mode. + if test -z "$mode"; then + if test -n "$nonopt"; then + $echo "$modename: warning: cannot infer operation mode from \`$nonopt'" 1>&2 + else + $echo "$modename: warning: cannot infer operation mode without MODE-ARGS" 1>&2 + fi fi - fi -} + ;; + esac + fi + # Only execute mode is allowed to have -dlopen flags. + if test -n "$execute_dlfiles" && test "$mode" != execute; then + $echo "$modename: unrecognized option \`-dlopen'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + # Change the help message to a mode-specific one. + generic_help="$help" + help="Try \`$modename --help --mode=$mode' for more information." + # These modes are in order of execution frequency so that they run quickly. + case $mode in + # libtool compile mode + compile) + modename="$modename: compile" + # Get the compilation command and the source file. + base_compile= + srcfile="$nonopt" # always keep a non-empty value in "srcfile" + suppress_opt=yes + suppress_output= + arg_mode=normal + libobj= + later= + for arg + do + case "$arg_mode" in + arg ) + # do not "continue". Instead, add this to base_compile + lastarg="$arg" + arg_mode=normal + ;; -# func_version -# Echo version message to standard output and exit. -func_version () -{ - $SED -n '/^# '$PROGRAM' (GNU /,/# warranty; / { - s/^# // - s/^# *$// - s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/ - p - }' < "$progpath" - exit $? -} + target ) + libobj="$arg" + arg_mode=normal + continue + ;; -# func_usage -# Echo short help message to standard output and exit. -func_usage () -{ - $SED -n '/^# Usage:/,/# -h/ { - s/^# // - s/^# *$// - s/\$progname/'$progname'/ - p - }' < "$progpath" - $ECHO - $ECHO "run \`$progname --help | more' for full usage" - exit $? -} + normal ) + # Accept any command-line options. + case $arg in + -o) + if test -n "$libobj" ; then + $echo "$modename: you cannot specify \`-o' more than once" 1>&2 + exit $EXIT_FAILURE + fi + arg_mode=target + continue + ;; -# func_help -# Echo long help message to standard output and exit. -func_help () -{ - $SED -n '/^# Usage:/,/# Report bugs to/ { - s/^# // - s/^# *$// - s*\$progname*'$progname'* - s*\$host*'"$host"'* - s*\$SHELL*'"$SHELL"'* - s*\$LTCC*'"$LTCC"'* - s*\$LTCFLAGS*'"$LTCFLAGS"'* - s*\$LD*'"$LD"'* - s/\$with_gnu_ld/'"$with_gnu_ld"'/ - s/\$automake_version/'"`(automake --version) 2>/dev/null |$SED 1q`"'/ - s/\$autoconf_version/'"`(autoconf --version) 2>/dev/null |$SED 1q`"'/ - p - }' < "$progpath" - exit $? -} + -static | -prefer-pic | -prefer-non-pic) + later="$later $arg" + continue + ;; -# func_missing_arg argname -# Echo program name prefixed message to standard error and set global -# exit_cmd. -func_missing_arg () -{ - func_error "missing argument for $1" - exit_cmd=exit -} + -no-suppress) + suppress_opt=no + continue + ;; -exit_cmd=: + -Xcompiler) + arg_mode=arg # the next one goes into the "base_compile" arg list + continue # The current "srcfile" will either be retained or + ;; # replaced later. I would guess that would be a bug. + -Wc,*) + args=`$echo "X$arg" | $Xsed -e "s/^-Wc,//"` + lastarg= + save_ifs="$IFS"; IFS=',' + for arg in $args; do + IFS="$save_ifs" + # Double-quote args containing other shell metacharacters. + # Many Bourne shells cannot handle close brackets correctly + # in scan sets, so we specify it separately. + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + lastarg="$lastarg $arg" + done + IFS="$save_ifs" + lastarg=`$echo "X$lastarg" | $Xsed -e "s/^ //"` + # Add the arguments to base_compile. + base_compile="$base_compile $lastarg" + continue + ;; + * ) + # Accept the current argument as the source file. + # The previous "srcfile" becomes the current argument. + # + lastarg="$srcfile" + srcfile="$arg" + ;; + esac # case $arg + ;; + esac # case $arg_mode -# Check that we have a working $ECHO. -if test "X$1" = X--no-reexec; then - # Discard the --no-reexec flag, and continue. - shift -elif test "X$1" = X--fallback-echo; then - # Avoid inline document here, it may be left over - : -elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t'; then - # Yippee, $ECHO works! - : -else - # Restart under the correct shell, and then maybe $ECHO will work. - exec $SHELL "$progpath" --no-reexec ${1+"$@"} -fi + # Aesthetically quote the previous argument. + lastarg=`$echo "X$lastarg" | $Xsed -e "$sed_quote_subst"` -if test "X$1" = X--fallback-echo; then - # used as fallback echo - shift - cat <\?\'\ \ ]*|*]*|"") + lastarg="\"$lastarg\"" + ;; + esac -magic="%%%MAGIC variable%%%" -magic_exe="%%%MAGIC EXE variable%%%" + base_compile="$base_compile $lastarg" + done # for arg -# Global variables. -# $mode is unset -nonopt= -execute_dlfiles= -preserve_args= -lo2o="s/\\.lo\$/.${objext}/" -o2lo="s/\\.${objext}\$/.lo/" -extracted_archives= -extracted_serial=0 + case $arg_mode in + arg) + $echo "$modename: you must specify an argument for -Xcompile" + exit $EXIT_FAILURE + ;; + target) + $echo "$modename: you must specify a target with \`-o'" 1>&2 + exit $EXIT_FAILURE + ;; + *) + # Get the name of the library object. + [ -z "$libobj" ] && libobj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%'` + ;; + esac -opt_dry_run=false -opt_duplicate_deps=false -opt_silent=false -opt_debug=: + # Recognize several different file suffixes. + # If the user specifies -o file.o, it is replaced with file.lo + xform='[cCFSifmso]' + case $libobj in + *.ada) xform=ada ;; + *.adb) xform=adb ;; + *.ads) xform=ads ;; + *.asm) xform=asm ;; + *.c++) xform=c++ ;; + *.cc) xform=cc ;; + *.ii) xform=ii ;; + *.class) xform=class ;; + *.cpp) xform=cpp ;; + *.cxx) xform=cxx ;; + *.f90) xform=f90 ;; + *.for) xform=for ;; + *.java) xform=java ;; + esac -# 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= + libobj=`$echo "X$libobj" | $Xsed -e "s/\.$xform$/.lo/"` -# func_fatal_configuration arg... -# Echo program name prefixed message to standard error, followed by -# a configuration failure hint, and exit. -func_fatal_configuration () -{ - func_error ${1+"$@"} - func_error "See the $PACKAGE documentation for more information." - func_fatal_error "Fatal configuration error." -} + case $libobj in + *.lo) obj=`$echo "X$libobj" | $Xsed -e "$lo2o"` ;; + *) + $echo "$modename: cannot determine name of library object from \`$libobj'" 1>&2 + exit $EXIT_FAILURE + ;; + esac + func_infer_tag $base_compile -# func_config -# Display the configuration for all the tags in this script. -func_config () -{ - re_begincf='^# ### BEGIN LIBTOOL' - re_endcf='^# ### END LIBTOOL' + for arg in $later; do + case $arg in + -static) + build_old_libs=yes + continue + ;; - # Default configuration. - $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" + -prefer-pic) + pic_mode=yes + continue + ;; - # Now print the configurations for the tags. - for tagname in $taglist; do - $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath" + -prefer-non-pic) + pic_mode=no + continue + ;; + esac done - exit $? -} - -# func_features -# Display the features supported by this script. -func_features () -{ - $ECHO "host: $host" - if test "$build_libtool_libs" = yes; then - $ECHO "enable shared libraries" + objname=`$echo "X$obj" | $Xsed -e 's%^.*/%%'` + xdir=`$echo "X$obj" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$obj"; then + xdir= else - $ECHO "disable shared libraries" + xdir=$xdir/ + fi + lobj=${xdir}$objdir/$objname + + if test -z "$base_compile"; then + $echo "$modename: you must specify a compilation command" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE fi + + # Delete any leftover library objects. if test "$build_old_libs" = yes; then - $ECHO "enable static libraries" + removelist="$obj $lobj $libobj ${libobj}T" else - $ECHO "disable static libraries" + removelist="$lobj $libobj ${libobj}T" fi - exit $? -} - -# func_enable_tag tagname -# 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 -# variable here. -func_enable_tag () -{ - # Global variable: - tagname="$1" + $run $rm $removelist + trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15 - re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" - re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" - sed_extractcf="/$re_begincf/,/$re_endcf/p" - - # Validate tagname. - case $tagname in - *[!-_A-Za-z0-9,/]*) - func_fatal_error "invalid tag name: $tagname" + # On Cygwin there's no "real" PIC flag so we must build both object types + case $host_os in + cygwin* | mingw* | pw32* | os2*) + pic_mode=default ;; - esac + esac + if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then + # non-PIC code in shared libraries is not supported + pic_mode=default + fi - # Don't test for the "default" C tag, as we know it's - # there but not specially marked. - case $tagname in - CC) ;; - *) - if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then - taglist="$taglist $tagname" + # Calculate the filename of the output object if compiler does + # not support -o with -c + if test "$compiler_c_o" = no; then + output_obj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext} + lockfile="$output_obj.lock" + removelist="$removelist $output_obj $lockfile" + trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15 + else + output_obj= + need_locks=no + lockfile= + fi - # Evaluate the configuration. Be careful to quote the path - # and the sed script, to avoid splitting on whitespace, but - # also don't use non-portable quotes within backquotes within - # quotes we have to do it in 2 steps: - extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` - eval "$extractedcf" - else - func_error "ignoring unknown tag $tagname" - fi - ;; - esac -} + # Lock this critical section if it is needed + # We use this script file to make the link, it avoids creating a new file + if test "$need_locks" = yes; then + until $run ln "$progpath" "$lockfile" 2>/dev/null; do + $show "Waiting for $lockfile to be removed" + sleep 2 + done + elif test "$need_locks" = warn; then + if test -f "$lockfile"; then + $echo "\ +*** ERROR, $lockfile exists and contains: +`cat $lockfile 2>/dev/null` -# Parse options once, thoroughly. This comes as soon as possible in -# the script to make things like `libtool --version' happen quickly. -{ +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." - # Shorthand for --mode=foo, only valid as the first argument - case $1 in - clean|clea|cle|cl) - shift; set dummy --mode clean ${1+"$@"}; shift - ;; - compile|compil|compi|comp|com|co|c) - shift; set dummy --mode compile ${1+"$@"}; shift - ;; - execute|execut|execu|exec|exe|ex|e) - shift; set dummy --mode execute ${1+"$@"}; shift - ;; - finish|finis|fini|fin|fi|f) - shift; set dummy --mode finish ${1+"$@"}; shift - ;; - install|instal|insta|inst|ins|in|i) - shift; set dummy --mode install ${1+"$@"}; shift - ;; - link|lin|li|l) - shift; set dummy --mode link ${1+"$@"}; shift - ;; - uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) - shift; set dummy --mode uninstall ${1+"$@"}; shift - ;; - esac + $run $rm $removelist + exit $EXIT_FAILURE + fi + $echo $srcfile > "$lockfile" + fi - # Parse non-mode specific arguments: - while test "$#" -gt 0; do - opt="$1" - shift + if test -n "$fix_srcfile_path"; then + eval srcfile=\"$fix_srcfile_path\" + fi - case $opt in - --config) func_config ;; + $run $rm "$libobj" "${libobj}T" - --debug) preserve_args="$preserve_args $opt" - func_echo "enabling shell trace mode" - opt_debug='set -x' - $opt_debug - ;; + # Create a libtool object file (analogous to a ".la" file), + # but don't create it if we're doing a dry run. + test -z "$run" && cat > ${libobj}T </dev/null`" != "X$srcfile"; then + $echo "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` - -\?|-h) func_usage ;; - --help) opt_help=: ;; - --version) func_version ;; +but it should contain: +$srcfile - -*) func_fatal_help "unrecognized option \`$opt'" ;; +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." - *) nonopt="$opt" - break - ;; - esac - done + $run $rm $removelist + exit $EXIT_FAILURE + fi + # 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 + $show "$mv $output_obj $lobj" + if $run $mv $output_obj $lobj; then : + else + error=$? + $run $rm $removelist + exit $error + fi + fi - case $host in - *cygwin* | *mingw* | *pw32* | *cegcc*) - # don't eliminate duplications in $postdeps and $predeps - opt_duplicate_compiler_generated_deps=: - ;; - *) - opt_duplicate_compiler_generated_deps=$opt_duplicate_deps - ;; - esac + # Append the name of the PIC object to the libtool object file. + test -z "$run" && cat >> ${libobj}T <&2 <<_LT_EOF -$progname: Version mismatch error. This is $PACKAGE $VERSION, but the -$progname: definition of this LT_INIT comes from an older release. -$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION -$progname: and run autoconf again. -_LT_EOF - else - cat >&2 <<_LT_EOF -$progname: Version mismatch error. This is $PACKAGE $VERSION, but the -$progname: definition of this LT_INIT comes from $PACKAGE $macro_version. -$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION -$progname: and run autoconf again. -_LT_EOF + # Allow error messages only from the first compilation. + if test "$suppress_opt" = yes; then + suppress_output=' >/dev/null 2>&1' fi else - cat >&2 <<_LT_EOF -$progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, -$progname: but the definition of this LT_INIT comes from revision $macro_revision. -$progname: You should recreate aclocal.m4 with macros from revision $package_revision -$progname: of $PACKAGE $VERSION and run autoconf again. -_LT_EOF - fi - - exit $EXIT_MISMATCH - fi -} + # No PIC object so indicate it doesn't exist in the libtool + # object file. + test -z "$run" && cat >> ${libobj}T </dev/null`" != "X$srcfile"; then + $echo "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` - # Darwin sucks - eval std_shrext=\"$shrext_cmds\" +but it should contain: +$srcfile +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." - # Only execute mode is allowed to have -dlopen flags. - if test -n "$execute_dlfiles" && test "$mode" != execute; then - func_error "unrecognized option \`-dlopen'" - $ECHO "$help" 1>&2 - exit $EXIT_FAILURE - fi + $run $rm $removelist + exit $EXIT_FAILURE + fi - # Change the help message to a mode-specific one. - generic_help="$help" - help="Try \`$progname --help --mode=$mode' for more information." -} + # Just move the object if needed + if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then + $show "$mv $output_obj $obj" + if $run $mv $output_obj $obj; then : + else + error=$? + $run $rm $removelist + exit $error + fi + fi + # Append the name of the non-PIC object the libtool object file. + # Only append if the libtool object file exists. + test -z "$run" && cat >> ${libobj}T </dev/null \ - | $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 -} +EOF + else + # Append the name of the non-PIC object the libtool object file. + # Only append if the libtool object file exists. + test -z "$run" && cat >> ${libobj}T </dev/null 2>&1 -} + $run $mv "${libobj}T" "${libobj}" -# func_ltwrapper_scriptname file -# Assumes file is an ltwrapper_executable -# uses $file to determine the appropriate filename for a -# temporary ltwrapper_script. -func_ltwrapper_scriptname () -{ - func_ltwrapper_scriptname_result="" - if func_ltwrapper_executable_p "$1"; then - func_dirname_and_basename "$1" "" "." - func_stripname '' '.exe' "$func_basename_result" - func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper" + # Unlock the critical section if it was locked + if test "$need_locks" != no; then + $run $rm "$lockfile" fi -} -# func_ltwrapper_p file -# True iff FILE is a libtool wrapper script or wrapper executable -# This function is only a basic sanity check; it will hardly flush out -# determined imposters. -func_ltwrapper_p () -{ - func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" -} + exit $EXIT_SUCCESS + ;; + # libtool link mode + link | relink) + modename="$modename: link" + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*) + # It is impossible to link a dll without this setting, and + # we shouldn't force the makefile maintainer to figure out + # which system we are compiling for in order to pass an extra + # flag for every libtool invocation. + # allow_undefined=no -# func_execute_cmds commands fail_cmd -# Execute tilde-delimited COMMANDS. -# If FAIL_CMD is given, eval that upon failure. -# FAIL_CMD may read-access the current command in variable CMD! -func_execute_cmds () -{ - $opt_debug - save_ifs=$IFS; IFS='~' - for cmd in $1; do - IFS=$save_ifs - eval cmd=\"$cmd\" - func_show_eval "$cmd" "${2-:}" - done - IFS=$save_ifs -} + # FIXME: Unfortunately, there are problems with the above when trying + # to make a dll which has undefined symbols, in which case not + # even a static library is built. For now, we need to specify + # -no-undefined on the libtool link line when we can be certain + # that all symbols are satisfied, otherwise we get a static library. + allow_undefined=yes + ;; + *) + allow_undefined=yes + ;; + esac + libtool_args="$nonopt" + base_compile="$nonopt $@" + compile_command="$nonopt" + finalize_command="$nonopt" + compile_rpath= + finalize_rpath= + compile_shlibpath= + finalize_shlibpath= + convenience= + old_convenience= + deplibs= + old_deplibs= + compiler_flags= + linker_flags= + dllsearchpath= + lib_search_path=`pwd` + inst_prefix_dir= -# func_source file -# Source FILE, adding directory component if necessary. -# 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 -# behavior happens only for exec(3), not for open(2)! Also, sourcing -# `FILE.' does not work on cygwin managed mounts. -func_source () -{ - $opt_debug - case $1 in - */* | *\\*) . "$1" ;; - *) . "./$1" ;; - esac -} + avoid_version=no + dlfiles= + dlprefiles= + dlself=no + export_dynamic=no + export_symbols= + export_symbols_regex= + generated= + libobjs= + ltlibs= + module=no + no_install=no + objs= + non_pic_objects= + precious_files_regex= + prefer_static_libs=no + preload=no + prev= + prevarg= + release= + rpath= + xrpath= + perm_rpath= + temp_rpath= + thread_safe=no + vinfo= + vinfo_number=no + func_infer_tag $base_compile -# func_infer_tag arg -# Infer tagged configuration to use if any are available and -# if one wasn't chosen via the "--tag" command line option. -# Only attempt this if the compiler in the base compile -# command doesn't match the default compiler. -# arg is usually of the form 'gcc ...' -func_infer_tag () -{ - $opt_debug - if test -n "$available_tags" && test -z "$tagname"; then - CC_quoted= - for arg in $CC; do - func_quote_for_eval "$arg" - CC_quoted="$CC_quoted $func_quote_for_eval_result" - done - case $@ in - # Blanks in the command may have been stripped by the calling shell, - # but not from the CC environment variable when configure was run. - " $CC "* | "$CC "* | " `$ECHO $CC` "* | "`$ECHO $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$ECHO $CC_quoted` "* | "`$ECHO $CC_quoted` "*) ;; - # Blanks at the start of $base_compile will cause this to fail - # if we don't check for them as well. - *) - for z in $available_tags; do - if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then - # Evaluate the configuration. - eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" - CC_quoted= - for arg in $CC; do - # Double-quote args containing other shell metacharacters. - func_quote_for_eval "$arg" - CC_quoted="$CC_quoted $func_quote_for_eval_result" - done - case "$@ " in - " $CC "* | "$CC "* | " `$ECHO $CC` "* | "`$ECHO $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$ECHO $CC_quoted` "* | "`$ECHO $CC_quoted` "*) - # The compiler in the base compile command matches - # the one in the tagged configuration. - # Assume this is the tagged configuration we want. - tagname=$z - break - ;; - esac + # We need to know -static, to get the right output filenames. + for arg + do + case $arg in + -all-static | -static) + if test "X$arg" = "X-all-static"; then + if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then + $echo "$modename: warning: complete static linking is impossible in this configuration" 1>&2 + fi + if test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + else + if test -z "$pic_flag" && test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static fi - done - # If $tagname still isn't set, then no tagged configuration - # was found and let the user know that the "--tag" command - # line option must be used. - if test -z "$tagname"; then - func_echo "unable to infer tagged configuration" - func_fatal_error "specify a tag with \`--tag'" -# else -# func_verbose "using $tagname tagged configuration" fi + build_libtool_libs=no + build_old_libs=yes + prefer_static_libs=yes + break ;; esac - fi -} + done + # See if our shared archives depend on static archives. + test -n "$old_archive_from_new_cmds" && build_old_libs=yes + # Go through the arguments, transforming them on the way. + while test "$#" -gt 0; do + arg="$1" + shift + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + qarg=\"`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`\" ### testsuite: skip nested quoting test + ;; + *) qarg=$arg ;; + esac + libtool_args="$libtool_args $qarg" -# func_write_libtool_object output_name pic_name nonpic_name -# Create a libtool object file (analogous to a ".la" file), -# but don't create it if we're doing a dry run. -func_write_libtool_object () -{ - write_libobj=${1} - if test "$build_libtool_libs" = yes; then - write_lobj=\'${2}\' - else - write_lobj=none - fi + # If the previous option needs an argument, assign it. + if test -n "$prev"; then + case $prev in + output) + compile_command="$compile_command @OUTPUT@" + finalize_command="$finalize_command @OUTPUT@" + ;; + esac - if test "$build_old_libs" = yes; then - write_oldobj=\'${3}\' - else - write_oldobj=none - fi + case $prev in + dlfiles|dlprefiles) + if test "$preload" = no; then + # Add the symbol object into the linking commands. + compile_command="$compile_command @SYMFILE@" + finalize_command="$finalize_command @SYMFILE@" + preload=yes + fi + case $arg in + *.la | *.lo) ;; # We handle these cases below. + force) + if test "$dlself" = no; then + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + self) + if test "$prev" = dlprefiles; then + dlself=yes + elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then + dlself=yes + else + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + *) + if test "$prev" = dlfiles; then + dlfiles="$dlfiles $arg" + else + dlprefiles="$dlprefiles $arg" + fi + prev= + continue + ;; + esac + ;; + expsyms) + export_symbols="$arg" + if test ! -f "$arg"; then + $echo "$modename: symbol file \`$arg' does not exist" + exit $EXIT_FAILURE + fi + prev= + continue + ;; + expsyms_regex) + export_symbols_regex="$arg" + prev= + continue + ;; + inst_prefix) + inst_prefix_dir="$arg" + prev= + continue + ;; + precious_regex) + precious_files_regex="$arg" + prev= + continue + ;; + release) + release="-$arg" + prev= + continue + ;; + objectlist) + if test -f "$arg"; then + save_arg=$arg + moreargs= + for fil in `cat $save_arg` + do +# moreargs="$moreargs $fil" + arg=$fil + # A libtool-controlled object. - $opt_dry_run || { - cat >${write_libobj}T </dev/null 2>&1; then + pic_object= + non_pic_object= -# Name of the PIC object. -pic_object=$write_lobj + # Read the .lo file + # If there is no directory component, then add one. + case $arg in + */* | *\\*) . $arg ;; + *) . ./$arg ;; + esac -# Name of the non-PIC object -non_pic_object=$write_oldobj + if test -z "$pic_object" || \ + test -z "$non_pic_object" || + test "$pic_object" = none && \ + test "$non_pic_object" = none; then + $echo "$modename: cannot find name of object for \`$arg'" 1>&2 + exit $EXIT_FAILURE + fi -EOF - $MV "${write_libobj}T" "${write_libobj}" - } -} + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi -# func_mode_compile arg... -func_mode_compile () -{ - $opt_debug - # Get the compilation command and the source file. - base_compile= - srcfile="$nonopt" # always keep a non-empty value in "srcfile" - suppress_opt=yes - suppress_output= - arg_mode=normal - libobj= - later= - pie_flag= + if test "$pic_object" != none; then + # Prepend the subdirectory the object is found in. + pic_object="$xdir$pic_object" - for arg - do - case $arg_mode in - arg ) - # do not "continue". Instead, add this to base_compile - lastarg="$arg" - arg_mode=normal - ;; + if test "$prev" = dlfiles; then + if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then + dlfiles="$dlfiles $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi - target ) - libobj="$arg" - arg_mode=normal - continue - ;; + # CHECK ME: I think I busted this. -Ossama + if test "$prev" = dlprefiles; then + # Preload the old-style object. + dlprefiles="$dlprefiles $pic_object" + prev= + fi - normal ) - # Accept any command-line options. - case $arg in - -o) - test -n "$libobj" && \ - func_fatal_error "you cannot specify \`-o' more than once" - arg_mode=target + # A PIC object. + libobjs="$libobjs $pic_object" + arg="$pic_object" + fi + + # Non-PIC object. + if test "$non_pic_object" != none; then + # Prepend the subdirectory the object is found in. + non_pic_object="$xdir$non_pic_object" + + # A standard non-PIC object + non_pic_objects="$non_pic_objects $non_pic_object" + if test -z "$pic_object" || test "$pic_object" = none ; then + arg="$non_pic_object" + fi + fi + else + # Only an error if not doing a dry-run. + if test -z "$run"; then + $echo "$modename: \`$arg' is not a valid libtool object" 1>&2 + exit $EXIT_FAILURE + else + # Dry-run case. + + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi + + pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"` + non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"` + libobjs="$libobjs $pic_object" + non_pic_objects="$non_pic_objects $non_pic_object" + fi + fi + done + else + $echo "$modename: link input file \`$save_arg' does not exist" + exit $EXIT_FAILURE + fi + arg=$save_arg + prev= continue ;; - - -pie | -fpie | -fPIE) - pie_flag="$pie_flag $arg" + rpath | xrpath) + # We need an absolute path. + case $arg in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + $echo "$modename: only absolute run-paths are allowed" 1>&2 + exit $EXIT_FAILURE + ;; + esac + if test "$prev" = rpath; then + case "$rpath " in + *" $arg "*) ;; + *) rpath="$rpath $arg" ;; + esac + else + case "$xrpath " in + *" $arg "*) ;; + *) xrpath="$xrpath $arg" ;; + esac + fi + prev= continue ;; - - -shared | -static | -prefer-pic | -prefer-non-pic) - later="$later $arg" + xcompiler) + compiler_flags="$compiler_flags $qarg" + prev= + compile_command="$compile_command $qarg" + finalize_command="$finalize_command $qarg" continue ;; - - -no-suppress) - suppress_opt=no + xlinker) + linker_flags="$linker_flags $qarg" + compiler_flags="$compiler_flags $wl$qarg" + prev= + compile_command="$compile_command $wl$qarg" + finalize_command="$finalize_command $wl$qarg" continue ;; - - -Xcompiler) - arg_mode=arg # the next one goes into the "base_compile" arg list - continue # The current "srcfile" will either be retained or - ;; # replaced later. I would guess that would be a bug. - - -Wc,*) - func_stripname '-Wc,' '' "$arg" - args=$func_stripname_result - lastarg= - save_ifs="$IFS"; IFS=',' - for arg in $args; do - IFS="$save_ifs" - func_quote_for_eval "$arg" - lastarg="$lastarg $func_quote_for_eval_result" - done - IFS="$save_ifs" - func_stripname ' ' '' "$lastarg" - lastarg=$func_stripname_result - - # Add the arguments to base_compile. - base_compile="$base_compile $lastarg" + xcclinker) + linker_flags="$linker_flags $qarg" + compiler_flags="$compiler_flags $qarg" + prev= + compile_command="$compile_command $qarg" + finalize_command="$finalize_command $qarg" + continue + ;; + shrext) + shrext_cmds="$arg" + prev= continue ;; - *) - # Accept the current argument as the source file. - # The previous "srcfile" becomes the current argument. - # - lastarg="$srcfile" - srcfile="$arg" + eval "$prev=\"\$arg\"" + prev= + continue ;; - esac # case $arg - ;; - esac # case $arg_mode + esac + fi # test -n "$prev" - # Aesthetically quote the previous argument. - func_quote_for_eval "$lastarg" - base_compile="$base_compile $func_quote_for_eval_result" - done # for arg + prevarg="$arg" - case $arg_mode in - arg) - func_fatal_error "you must specify an argument for -Xcompile" - ;; - target) - func_fatal_error "you must specify a target with \`-o'" - ;; - *) - # Get the name of the library object. - test -z "$libobj" && { - func_basename "$srcfile" - libobj="$func_basename_result" - } - ;; - esac + case $arg in + -all-static) + if test -n "$link_static_flag"; then + compile_command="$compile_command $link_static_flag" + finalize_command="$finalize_command $link_static_flag" + fi + continue + ;; - # Recognize several different file suffixes. - # If the user specifies -o file.o, it is replaced with file.lo - case $libobj in - *.[cCFSifmso] | \ - *.ada | *.adb | *.ads | *.asm | \ - *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ - *.[fF][09]? | *.for | *.java | *.obj | *.sx) - func_xform "$libobj" - libobj=$func_xform_result - ;; - esac - - case $libobj in - *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; - *) - func_fatal_error "cannot determine name of library object from \`$libobj'" - ;; - esac + -allow-undefined) + # FIXME: remove this flag sometime in the future. + $echo "$modename: \`-allow-undefined' is deprecated because it is the default" 1>&2 + continue + ;; - func_infer_tag $base_compile + -avoid-version) + avoid_version=yes + continue + ;; - for arg in $later; do - case $arg in - -shared) - test "$build_libtool_libs" != yes && \ - func_fatal_configuration "can not build a shared library" - build_old_libs=no + -dlopen) + prev=dlfiles continue ;; - -static) - build_libtool_libs=no - build_old_libs=yes + -dlpreopen) + prev=dlprefiles continue ;; - -prefer-pic) - pic_mode=yes + -export-dynamic) + export_dynamic=yes continue ;; - -prefer-non-pic) - pic_mode=no + -export-symbols | -export-symbols-regex) + if test -n "$export_symbols" || test -n "$export_symbols_regex"; then + $echo "$modename: more than one -exported-symbols argument is not allowed" + exit $EXIT_FAILURE + fi + if test "X$arg" = "X-export-symbols"; then + prev=expsyms + else + prev=expsyms_regex + fi continue ;; - esac - done - func_quote_for_eval "$libobj" - test "X$libobj" != "X$func_quote_for_eval_result" \ - && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ - && func_warning "libobj name \`$libobj' may not contain shell special characters." - func_dirname_and_basename "$obj" "/" "" - objname="$func_basename_result" - xdir="$func_dirname_result" - lobj=${xdir}$objdir/$objname + -inst-prefix-dir) + prev=inst_prefix + continue + ;; - test -z "$base_compile" && \ - func_fatal_help "you must specify a compilation command" + # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* + # so, if we see these flags be careful not to treat them like -L + -L[A-Z][A-Z]*:*) + case $with_gcc/$host in + no/*-*-irix* | /*-*-irix*) + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + ;; + esac + continue + ;; - # Delete any leftover library objects. - if test "$build_old_libs" = yes; then - removelist="$obj $lobj $libobj ${libobj}T" - else - removelist="$lobj $libobj ${libobj}T" - fi + -L*) + dir=`$echo "X$arg" | $Xsed -e 's/^-L//'` + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + absdir=`cd "$dir" && pwd` + if test -z "$absdir"; then + $echo "$modename: cannot determine absolute directory name of \`$dir'" 1>&2 + exit $EXIT_FAILURE + fi + dir="$absdir" + ;; + esac + case "$deplibs " in + *" -L$dir "*) ;; + *) + deplibs="$deplibs -L$dir" + lib_search_path="$lib_search_path $dir" + ;; + esac + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*) + case :$dllsearchpath: in + *":$dir:"*) ;; + *) dllsearchpath="$dllsearchpath:$dir";; + esac + ;; + esac + continue + ;; - # On Cygwin there's no "real" PIC flag so we must build both object types - case $host_os in - cygwin* | mingw* | pw32* | os2* | cegcc*) - pic_mode=default - ;; - esac - if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then - # non-PIC code in shared libraries is not supported - pic_mode=default - fi + -l*) + if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then + case $host in + *-*-cygwin* | *-*-pw32* | *-*-beos*) + # These systems don't actually have a C or math library (as such) + continue + ;; + *-*-mingw* | *-*-os2*) + # These systems don't actually have a C library (as such) + test "X$arg" = "X-lc" && continue + ;; + *-*-openbsd* | *-*-freebsd*) + # Do not include libc due to us having libc/libc_r. + test "X$arg" = "X-lc" && continue + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C and math libraries are in the System framework + deplibs="$deplibs -framework System" + continue + esac + elif test "X$arg" = "X-lc_r"; then + case $host in + *-*-openbsd* | *-*-freebsd*) + # Do not include libc_r directly, use -pthread flag. + continue + ;; + esac + fi + deplibs="$deplibs $arg" + continue + ;; - # Calculate the filename of the output object if compiler does - # not support -o with -c - if test "$compiler_c_o" = no; then - output_obj=`$ECHO "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext} - lockfile="$output_obj.lock" - else - output_obj= - need_locks=no - lockfile= - fi + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe) + deplibs="$deplibs $arg" + continue + ;; - # Lock this critical section if it is needed - # We use this script file to make the link, it avoids creating a new file - if test "$need_locks" = yes; then - until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do - func_echo "Waiting for $lockfile to be removed" - sleep 2 - done - elif test "$need_locks" = warn; then - if test -f "$lockfile"; then - $ECHO "\ -*** ERROR, $lockfile exists and contains: -`cat $lockfile 2>/dev/null` + -module) + module=yes + continue + ;; -This indicates that another process is trying to use the same -temporary object file, and libtool could not work around it because -your compiler does not support \`-c' and \`-o' together. If you -repeat this compilation, it may succeed, by chance, but you had better -avoid parallel builds (make -j) in this platform, or get a better -compiler." + # gcc -m* arguments should be passed to the linker via $compiler_flags + # in order to pass architecture information to the linker + # (e.g. 32 vs 64-bit). This may also be accomplished via -Wl,-mfoo + # but this is not reliable with gcc because gcc may use -mfoo to + # select a different linker, different libraries, etc, while + # -Wl,-mfoo simply passes -mfoo to the linker. + -m*) + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + if test "$with_gcc" = "yes" ; then + compiler_flags="$compiler_flags $arg" + fi + continue + ;; - $opt_dry_run || $RM $removelist - exit $EXIT_FAILURE - fi - removelist="$removelist $output_obj" - $ECHO "$srcfile" > "$lockfile" - fi + -shrext) + prev=shrext + continue + ;; - $opt_dry_run || $RM $removelist - removelist="$removelist $lockfile" - trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 + -no-fast-install) + fast_install=no + continue + ;; - if test -n "$fix_srcfile_path"; then - eval srcfile=\"$fix_srcfile_path\" - fi - func_quote_for_eval "$srcfile" - qsrcfile=$func_quote_for_eval_result + -no-install) + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*) + # The PATH hackery in wrapper scripts is required on Windows + # in order for the loader to find any dlls it needs. + $echo "$modename: warning: \`-no-install' is ignored for $host" 1>&2 + $echo "$modename: warning: assuming \`-no-fast-install' instead" 1>&2 + fast_install=no + ;; + *) no_install=yes ;; + esac + continue + ;; - # Only build a PIC object if we are building libtool libraries. - if test "$build_libtool_libs" = yes; then - # Without this assignment, base_compile gets emptied. - fbsd_hideous_sh_bug=$base_compile + -no-undefined) + allow_undefined=no + continue + ;; - if test "$pic_mode" != no; then - command="$base_compile $qsrcfile $pic_flag" - else - # Don't build PIC code - command="$base_compile $qsrcfile" - fi + -objectlist) + prev=objectlist + continue + ;; - func_mkdir_p "$xdir$objdir" + -o) prev=output ;; - if test -z "$output_obj"; then - # Place PIC objects in $objdir - command="$command -o $lobj" - fi + -precious-files-regex) + prev=precious_regex + continue + ;; - func_show_eval_locale "$command" \ - 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' + -release) + prev=release + continue + ;; - if test "$need_locks" = warn && - test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then - $ECHO "\ -*** ERROR, $lockfile contains: -`cat $lockfile 2>/dev/null` + -rpath) + prev=rpath + continue + ;; -but it should contain: -$srcfile + -R) + prev=xrpath + continue + ;; -This indicates that another process is trying to use the same -temporary object file, and libtool could not work around it because -your compiler does not support \`-c' and \`-o' together. If you -repeat this compilation, it may succeed, by chance, but you had better -avoid parallel builds (make -j) in this platform, or get a better -compiler." + -R*) + dir=`$echo "X$arg" | $Xsed -e 's/^-R//'` + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + $echo "$modename: only absolute run-paths are allowed" 1>&2 + exit $EXIT_FAILURE + ;; + esac + case "$xrpath " in + *" $dir "*) ;; + *) xrpath="$xrpath $dir" ;; + esac + continue + ;; - $opt_dry_run || $RM $removelist - exit $EXIT_FAILURE - fi + -static) + # The effects of -static are defined in a previous loop. + # We used to do the same as -all-static on platforms that + # didn't have a PIC flag, but the assumption that the effects + # would be equivalent was wrong. It would break on at least + # Digital Unix and AIX. + continue + ;; - # 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 - func_show_eval '$MV "$output_obj" "$lobj"' \ - 'error=$?; $opt_dry_run || $RM $removelist; exit $error' - fi - - # Allow error messages only from the first compilation. - if test "$suppress_opt" = yes; then - suppress_output=' >/dev/null 2>&1' - fi - fi - - # Only build a position-dependent object if we build old libraries. - if test "$build_old_libs" = yes; then - if test "$pic_mode" != yes; then - # Don't build PIC code - command="$base_compile $qsrcfile$pie_flag" - else - command="$base_compile $qsrcfile $pic_flag" - fi - if test "$compiler_c_o" = yes; then - command="$command -o $obj" - fi + -thread-safe) + thread_safe=yes + continue + ;; - # Suppress compiler output if we already did a PIC compilation. - command="$command$suppress_output" - func_show_eval_locale "$command" \ - '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' + -version-info) + prev=vinfo + continue + ;; + -version-number) + prev=vinfo + vinfo_number=yes + continue + ;; - if test "$need_locks" = warn && - test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then - $ECHO "\ -*** ERROR, $lockfile contains: -`cat $lockfile 2>/dev/null` + -Wc,*) + args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wc,//'` + arg= + save_ifs="$IFS"; IFS=',' + for flag in $args; do + IFS="$save_ifs" + case $flag in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + flag="\"$flag\"" + ;; + esac + arg="$arg $wl$flag" + compiler_flags="$compiler_flags $flag" + done + IFS="$save_ifs" + arg=`$echo "X$arg" | $Xsed -e "s/^ //"` + ;; -but it should contain: -$srcfile + -Wl,*) + args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wl,//'` + arg= + save_ifs="$IFS"; IFS=',' + for flag in $args; do + IFS="$save_ifs" + case $flag in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + flag="\"$flag\"" + ;; + esac + arg="$arg $wl$flag" + compiler_flags="$compiler_flags $wl$flag" + linker_flags="$linker_flags $flag" + done + IFS="$save_ifs" + arg=`$echo "X$arg" | $Xsed -e "s/^ //"` + ;; -This indicates that another process is trying to use the same -temporary object file, and libtool could not work around it because -your compiler does not support \`-c' and \`-o' together. If you -repeat this compilation, it may succeed, by chance, but you had better -avoid parallel builds (make -j) in this platform, or get a better -compiler." + -Xcompiler) + prev=xcompiler + continue + ;; - $opt_dry_run || $RM $removelist - exit $EXIT_FAILURE - fi + -Xlinker) + prev=xlinker + continue + ;; - # Just move the object if needed - if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then - func_show_eval '$MV "$output_obj" "$obj"' \ - 'error=$?; $opt_dry_run || $RM $removelist; exit $error' - fi - fi + -XCClinker) + prev=xcclinker + continue + ;; - $opt_dry_run || { - func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" + # Some other compiler flag. + -* | +*) + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + ;; - # Unlock the critical section if it was locked - if test "$need_locks" != no; then - removelist=$lockfile - $RM "$lockfile" - fi - } + *.$objext) + # A standard object. + objs="$objs $arg" + ;; - exit $EXIT_SUCCESS -} + *.lo) + # A libtool-controlled object. -$opt_help || { -test "$mode" = compile && func_mode_compile ${1+"$@"} -} + # Check to see that this really is a libtool object. + if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + pic_object= + non_pic_object= -func_mode_help () -{ - # We need to display help for each of the modes. - case $mode in - "") - # Generic help is extracted from the usage comments - # at the start of this file. - func_help - ;; + # Read the .lo file + # If there is no directory component, then add one. + case $arg in + */* | *\\*) . $arg ;; + *) . ./$arg ;; + esac - clean) - $ECHO \ -"Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... + if test -z "$pic_object" || \ + test -z "$non_pic_object" || + test "$pic_object" = none && \ + test "$non_pic_object" = none; then + $echo "$modename: cannot find name of object for \`$arg'" 1>&2 + exit $EXIT_FAILURE + fi -Remove files from the build directory. + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi -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 -to RM. + if test "$pic_object" != none; then + # Prepend the subdirectory the object is found in. + pic_object="$xdir$pic_object" -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." - ;; + if test "$prev" = dlfiles; then + if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then + dlfiles="$dlfiles $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi - compile) - $ECHO \ -"Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE + # CHECK ME: I think I busted this. -Ossama + if test "$prev" = dlprefiles; then + # Preload the old-style object. + dlprefiles="$dlprefiles $pic_object" + prev= + fi -Compile a source file into a libtool library object. + # A PIC object. + libobjs="$libobjs $pic_object" + arg="$pic_object" + fi -This mode accepts the following additional options: + # Non-PIC object. + if test "$non_pic_object" != none; then + # Prepend the subdirectory the object is found in. + non_pic_object="$xdir$non_pic_object" - -o OUTPUT-FILE set the output file name to OUTPUT-FILE - -no-suppress do not suppress compiler output for multiple passes - -prefer-pic try to building PIC objects only - -prefer-non-pic try to building non-PIC objects only - -shared do not build a \`.o' file suitable for static linking - -static only build a \`.o' file suitable for static linking + # A standard non-PIC object + non_pic_objects="$non_pic_objects $non_pic_object" + if test -z "$pic_object" || test "$pic_object" = none ; then + arg="$non_pic_object" + fi + fi + else + # Only an error if not doing a dry-run. + if test -z "$run"; then + $echo "$modename: \`$arg' is not a valid libtool object" 1>&2 + exit $EXIT_FAILURE + else + # Dry-run case. -COMPILE-COMMAND is a command to be used in creating a \`standard' object file -from the given SOURCEFILE. + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi -The output file name is determined by removing the directory component from -SOURCEFILE, then substituting the C source code suffix \`.c' with the -library object suffix, \`.lo'." - ;; + pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"` + non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"` + libobjs="$libobjs $pic_object" + non_pic_objects="$non_pic_objects $non_pic_object" + fi + fi + ;; - execute) - $ECHO \ -"Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... + *.$libext) + # An archive. + deplibs="$deplibs $arg" + old_deplibs="$old_deplibs $arg" + continue + ;; -Automatically set library path, then run a program. + *.la) + # A libtool-controlled library. -This mode accepts the following additional options: + if test "$prev" = dlfiles; then + # This library was specified with -dlopen. + dlfiles="$dlfiles $arg" + prev= + elif test "$prev" = dlprefiles; then + # The library was specified with -dlpreopen. + dlprefiles="$dlprefiles $arg" + prev= + else + deplibs="$deplibs $arg" + fi + continue + ;; - -dlopen FILE add the directory containing FILE to the library path + # Some other compiler argument. + *) + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + ;; + esac # arg -This mode sets the library path environment variable according to \`-dlopen' -flags. + # Now actually substitute the argument into the commands. + if test -n "$arg"; then + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + fi + done # argument parsing loop -If any of the ARGS are libtool executable wrappers, then they are translated -into their corresponding uninstalled binary, and any of their required library -directories are added to the library path. + if test -n "$prev"; then + $echo "$modename: the \`$prevarg' option requires an argument" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi -Then, COMMAND is executed, with ARGS as arguments." - ;; + if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then + eval arg=\"$export_dynamic_flag_spec\" + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + fi - finish) - $ECHO \ -"Usage: $progname [OPTION]... --mode=finish [LIBDIR]... + oldlibs= + # calculate the name of the file, without its directory + outputname=`$echo "X$output" | $Xsed -e 's%^.*/%%'` + libobjs_save="$libobjs" -Complete the installation of libtool libraries. + if test -n "$shlibpath_var"; then + # get the directories listed in $shlibpath_var + eval shlib_search_path=\`\$echo \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\` + else + shlib_search_path= + fi + eval sys_lib_search_path=\"$sys_lib_search_path_spec\" + eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" -Each LIBDIR is a directory that contains libtool libraries. + output_objdir=`$echo "X$output" | $Xsed -e 's%/[^/]*$%%'` + if test "X$output_objdir" = "X$output"; then + output_objdir="$objdir" + else + output_objdir="$output_objdir/$objdir" + fi + # Create the object directory. + if test ! -d "$output_objdir"; then + $show "$mkdir $output_objdir" + $run $mkdir $output_objdir + status=$? + if test "$status" -ne 0 && test ! -d "$output_objdir"; then + exit $status + fi + fi -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." - ;; + # Determine the type of output + case $output in + "") + $echo "$modename: you must specify an output file" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; + *.$libext) linkmode=oldlib ;; + *.lo | *.$objext) linkmode=obj ;; + *.la) linkmode=lib ;; + *) linkmode=prog ;; # Anything else should be a program. + esac - install) - $ECHO \ -"Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... + case $host in + *cygwin* | *mingw* | *pw32*) + # don't eliminate duplications in $postdeps and $predeps + duplicate_compiler_generated_deps=yes + ;; + *) + duplicate_compiler_generated_deps=$duplicate_deps + ;; + esac + specialdeplibs= -Install executables or libraries. - -INSTALL-COMMAND is the installation command. The first component should be -either the \`install' or \`cp' program. - -The following components of INSTALL-COMMAND are treated specially: - - -inst-prefix PREFIX-DIR Use PREFIX-DIR as a staging area for installation - -The rest of the components are interpreted as arguments to that command (only -BSD-compatible install options are recognized)." - ;; - - link) - $ECHO \ -"Usage: $progname [OPTION]... --mode=link LINK-COMMAND... - -Link object files or libraries together to form another library, or to -create an executable program. - -LINK-COMMAND is a command using the C compiler that you would use to create -a program from several object files. - -The following components of LINK-COMMAND are treated specially: - - -all-static do not do any dynamic linking at all - -avoid-version do not add a version suffix if possible - -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime - -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols - -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) - -export-symbols SYMFILE - try to export only the symbols listed in SYMFILE - -export-symbols-regex REGEX - try to export only the symbols matching REGEX - -LLIBDIR search LIBDIR for required installed libraries - -lNAME OUTPUT-FILE requires the installed library libNAME - -module build a library that can dlopened - -no-fast-install disable the fast-install mode - -no-install link a not-installable executable - -no-undefined declare that a library does not refer to external symbols - -o OUTPUT-FILE create OUTPUT-FILE from the specified objects - -objectlist FILE Use a list of object files found in FILE to specify objects - -precious-files-regex REGEX - don't remove output files matching REGEX - -release RELEASE specify package release information - -rpath LIBDIR the created library will eventually be installed in LIBDIR - -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries - -shared only do dynamic linking of libtool libraries - -shrext SUFFIX override the standard shared library file extension - -static do not do any dynamic linking of uninstalled libtool libraries - -static-libtool-libs - do not do any dynamic linking of libtool libraries - -version-info CURRENT[:REVISION[:AGE]] - specify library version info [each variable defaults to 0] - -weak LIBNAME declare that the target provides the LIBNAME interface - -All other options (arguments beginning with \`-') are ignored. - -Every other argument is treated as a filename. Files ending in \`.la' are -treated as uninstalled libtool libraries, other files are standard or library -object files. - -If the OUTPUT-FILE ends in \`.la', then a libtool library is created, -only library objects (\`.lo' files) may be specified, and \`-rpath' is -required, except when creating a convenience library. - -If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created -using \`ar' and \`ranlib', or on Windows using \`lib'. - -If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file -is created, otherwise an executable program is created." - ;; - - uninstall) - $ECHO \ -"Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... - -Remove libraries from an installation directory. - -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 -to RM. - -If FILE is a libtool library, all the files associated with it are deleted. -Otherwise, only FILE itself is deleted using RM." - ;; - - *) - func_fatal_help "invalid operation mode \`$mode'" - ;; - esac - - $ECHO - $ECHO "Try \`$progname --help' for more information about other modes." - - exit $? -} - - # Now that we've collected a possible --mode arg, show help if necessary - $opt_help && func_mode_help - - -# func_mode_execute arg... -func_mode_execute () -{ - $opt_debug - # The first argument is the command name. - cmd="$nonopt" - test -z "$cmd" && \ - func_fatal_help "you must specify a COMMAND" - - # Handle -dlopen flags immediately. - for file in $execute_dlfiles; do - test -f "$file" \ - || func_fatal_help "\`$file' is not a file" - - dir= - case $file in - *.la) - # Check to see that this really is a libtool archive. - func_lalib_unsafe_p "$file" \ - || func_fatal_help "\`$lib' is not a valid libtool archive" - - # Read the libtool library. - dlname= - library_names= - func_source "$file" - - # Skip this library if it cannot be dlopened. - if test -z "$dlname"; then - # Warn if it was a shared library. - test -n "$library_names" && \ - func_warning "\`$file' was not linked with \`-export-dynamic'" - continue - fi - - func_dirname "$file" "" "." - dir="$func_dirname_result" - - if test -f "$dir/$objdir/$dlname"; then - dir="$dir/$objdir" - else - if test ! -f "$dir/$dlname"; then - func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" - fi - fi - ;; - - *.lo) - # Just add the directory containing the .lo file. - func_dirname "$file" "" "." - dir="$func_dirname_result" - ;; - - *) - func_warning "\`-dlopen' is ignored for non-libtool libraries and objects" - continue - ;; - esac - - # Get the absolute pathname. - absdir=`cd "$dir" && pwd` - test -n "$absdir" && dir="$absdir" - - # Now add the directory to shlibpath_var. - if eval "test -z \"\$$shlibpath_var\""; then - eval "$shlibpath_var=\"\$dir\"" - else - eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" + libs= + # Find all interdependent deplibs by searching for libraries + # that are linked more than once (e.g. -la -lb -la) + for deplib in $deplibs; do + if test "X$duplicate_deps" = "Xyes" ; then + case "$libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac fi + libs="$libs $deplib" done - # This variable tells wrapper scripts just to set shlibpath_var - # rather than running their programs. - libtool_execute_magic="$magic" - - # Check if any of the arguments is a wrapper script. - args= - for file - do - case $file in - -*) ;; - *) - # Do a test to see if this is really a libtool program. - if func_ltwrapper_script_p "$file"; then - func_source "$file" - # Transform arg to wrapped name. - file="$progdir/$program" - elif func_ltwrapper_executable_p "$file"; then - func_ltwrapper_scriptname "$file" - func_source "$func_ltwrapper_scriptname_result" - # Transform arg to wrapped name. - file="$progdir/$program" - fi - ;; - esac - # Quote arguments (to preserve shell metacharacters). - func_quote_for_eval "$file" - args="$args $func_quote_for_eval_result" - done - - if test "X$opt_dry_run" = Xfalse; then - if test -n "$shlibpath_var"; then - # Export the shlibpath_var. - eval "export $shlibpath_var" - fi - - # Restore saved environment variables - for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES - do - eval "if test \"\${save_$lt_var+set}\" = set; then - $lt_var=\$save_$lt_var; export $lt_var - else - $lt_unset $lt_var - fi" - done + if test "$linkmode" = lib; then + libs="$predeps $libs $compiler_lib_search_path $postdeps" - # Now prepare to actually exec the command. - 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" + # Compute libraries that are listed more than once in $predeps + # $postdeps and mark them as special (i.e., whose duplicates are + # not to be eliminated). + pre_post_deps= + if test "X$duplicate_compiler_generated_deps" = "Xyes" ; then + for pre_post_dep in $predeps $postdeps; do + case "$pre_post_deps " in + *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;; + esac + pre_post_deps="$pre_post_deps $pre_post_dep" + done fi - $ECHO "$cmd$args" - exit $EXIT_SUCCESS - fi -} - -test "$mode" = execute && func_mode_execute ${1+"$@"} - - -# func_mode_finish arg... -func_mode_finish () -{ - $opt_debug - libdirs="$nonopt" - admincmds= - - if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then - for dir - do - libdirs="$libdirs $dir" - done - - for libdir in $libdirs; do - if test -n "$finish_cmds"; then - # Do each command in the finish commands. - func_execute_cmds "$finish_cmds" 'admincmds="$admincmds -'"$cmd"'"' - fi - if test -n "$finish_eval"; then - # Do the single finish_eval. - eval cmds=\"$finish_eval\" - $opt_dry_run || eval "$cmds" || admincmds="$admincmds - $cmds" - fi - done - fi - - # Exit here if they wanted silent mode. - $opt_silent && exit $EXIT_SUCCESS - - $ECHO "X----------------------------------------------------------------------" | $Xsed - $ECHO "Libraries have been installed in:" - for libdir in $libdirs; do - $ECHO " $libdir" - done - $ECHO - $ECHO "If you ever happen to want to link against installed libraries" - $ECHO "in a given directory, LIBDIR, you must either use libtool, and" - $ECHO "specify the full pathname of the library, or use the \`-LLIBDIR'" - $ECHO "flag during linking and do at least one of the following:" - if test -n "$shlibpath_var"; then - $ECHO " - add LIBDIR to the \`$shlibpath_var' environment variable" - $ECHO " during execution" - fi - if test -n "$runpath_var"; then - $ECHO " - add LIBDIR to the \`$runpath_var' environment variable" - $ECHO " during linking" - fi - if test -n "$hardcode_libdir_flag_spec"; then - libdir=LIBDIR - eval flag=\"$hardcode_libdir_flag_spec\" - - $ECHO " - use the \`$flag' linker flag" - fi - if test -n "$admincmds"; then - $ECHO " - have your system administrator run these commands:$admincmds" - fi - if test -f /etc/ld.so.conf; then - $ECHO " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'" + pre_post_deps= fi - $ECHO - $ECHO "See any operating system documentation about shared libraries for" - case $host in - solaris2.[6789]|solaris2.1[0-9]) - $ECHO "more information, such as the ld(1), crle(1) and ld.so(8) manual" - $ECHO "pages." + deplibs= + newdependency_libs= + newlib_search_path= + need_relink=no # whether we're linking any uninstalled libtool libraries + notinst_deplibs= # not-installed libtool libraries + notinst_path= # paths that contain not-installed libtool libraries + case $linkmode in + lib) + passes="conv link" + for file in $dlfiles $dlprefiles; do + case $file in + *.la) ;; + *) + $echo "$modename: libraries can \`-dlopen' only libtool libraries: $file" 1>&2 + exit $EXIT_FAILURE + ;; + esac + done + ;; + prog) + compile_deplibs= + finalize_deplibs= + alldeplibs=no + newdlfiles= + newdlprefiles= + passes="conv scan dlopen dlpreopen link" + ;; + *) passes="conv" ;; - *) - $ECHO "more information, such as the ld(1) and ld.so(8) manual pages." - ;; esac - $ECHO "X----------------------------------------------------------------------" | $Xsed - exit $EXIT_SUCCESS -} - -test "$mode" = finish && func_mode_finish ${1+"$@"} - - -# func_mode_install arg... -func_mode_install () -{ - $opt_debug - # There may be an optional sh(1) argument at the beginning of - # install_prog (especially on Windows NT). - if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh || - # Allow the use of GNU shtool's install command. - $ECHO "X$nonopt" | $GREP shtool >/dev/null; then - # Aesthetically quote it. - func_quote_for_eval "$nonopt" - install_prog="$func_quote_for_eval_result " - arg=$1 - shift - else - install_prog= - arg=$nonopt - fi - - # The real first argument should be the name of the installation program. - # Aesthetically quote it. - func_quote_for_eval "$arg" - install_prog="$install_prog$func_quote_for_eval_result" - - # We need to accept at least all the BSD install flags. - dest= - files= - opts= - prev= - install_type= - isdir=no - stripme= - for arg - do - if test -n "$dest"; then - files="$files $dest" - dest=$arg - continue + for pass in $passes; do + if test "$linkmode,$pass" = "lib,link" || + test "$linkmode,$pass" = "prog,scan"; then + libs="$deplibs" + deplibs= fi - - case $arg in - -d) isdir=yes ;; - -f) - case " $install_prog " in - *[\\\ /]cp\ *) ;; - *) prev=$arg ;; + if test "$linkmode" = prog; then + case $pass in + dlopen) libs="$dlfiles" ;; + dlpreopen) libs="$dlprefiles" ;; + link) libs="$deplibs %DEPLIBS% $dependency_libs" ;; esac - ;; - -g | -m | -o) - prev=$arg - ;; - -s) - stripme=" -s" - continue - ;; - -*) - ;; - *) - # If the previous option needed an argument, then skip it. - if test -n "$prev"; then - prev= - else - dest=$arg + fi + if test "$pass" = dlopen; then + # Collect dlpreopened libraries + save_deplibs="$deplibs" + deplibs= + fi + for deplib in $libs; do + lib= + found=no + case $deplib in + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe) + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + fi + continue + ;; + -l*) + if test "$linkmode" != lib && test "$linkmode" != prog; then + $echo "$modename: warning: \`-l' is ignored for archives/objects" 1>&2 + continue + fi + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + continue + fi + name=`$echo "X$deplib" | $Xsed -e 's/^-l//'` + for searchdir in $newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path; do + for search_ext in .la $std_shrext .so .a; do + # Search the libtool library + lib="$searchdir/lib${name}${search_ext}" + if test -f "$lib"; then + if test "$search_ext" = ".la"; then + found=yes + else + found=no + fi + break 2 + fi + done + done + if test "$found" != yes; then + # deplib doesn't seem to be a libtool library + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" + fi + continue + else # deplib is a libtool library + # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, + # We need to do some special things here, and not later. + if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then + case " $predeps $postdeps " in + *" $deplib "*) + if (${SED} -e '2q' $lib | + grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + library_names= + old_library= + case $lib in + */* | *\\*) . $lib ;; + *) . ./$lib ;; + esac + for l in $old_library $library_names; do + ll="$l" + done + if test "X$ll" = "X$old_library" ; then # only static version available + found=no + ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'` + test "X$ladir" = "X$lib" && ladir="." + lib=$ladir/$old_library + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" + fi + continue + fi + fi + ;; + *) ;; + esac + fi + fi + ;; # -l + -L*) + case $linkmode in + lib) + deplibs="$deplib $deplibs" + test "$pass" = conv && continue + newdependency_libs="$deplib $newdependency_libs" + newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'` + ;; + prog) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + continue + fi + if test "$pass" = scan; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'` + ;; + *) + $echo "$modename: warning: \`-L' is ignored for archives/objects" 1>&2 + ;; + esac # linkmode + continue + ;; # -L + -R*) + if test "$pass" = link; then + dir=`$echo "X$deplib" | $Xsed -e 's/^-R//'` + # Make sure the xrpath contains only unique directories. + case "$xrpath " in + *" $dir "*) ;; + *) xrpath="$xrpath $dir" ;; + esac + fi + deplibs="$deplib $deplibs" + continue + ;; + *.la) lib="$deplib" ;; + *.$libext) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + continue + fi + case $linkmode in + lib) + if test "$deplibs_check_method" != pass_all; then + $echo + $echo "*** Warning: Trying to link with static lib archive $deplib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have" + $echo "*** because the file extensions .$libext of this argument makes me believe" + $echo "*** that it is just a static archive that I should not used here." + else + $echo + $echo "*** Warning: Linking the shared library $output against the" + $echo "*** static library $deplib is not portable!" + deplibs="$deplib $deplibs" + fi + continue + ;; + prog) + if test "$pass" != link; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + continue + ;; + esac # linkmode + ;; # *.$libext + *.lo | *.$objext) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + elif test "$linkmode" = prog; then + if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then + # If there is no dlopen support or we're linking statically, + # we need to preload. + newdlprefiles="$newdlprefiles $deplib" + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + newdlfiles="$newdlfiles $deplib" + fi + fi continue + ;; + %DEPLIBS%) + alldeplibs=yes + continue + ;; + esac # case $deplib + if test "$found" = yes || test -f "$lib"; then : + else + $echo "$modename: cannot find the library \`$lib'" 1>&2 + exit $EXIT_FAILURE fi - ;; - esac - - # Aesthetically quote the argument. - func_quote_for_eval "$arg" - install_prog="$install_prog $func_quote_for_eval_result" - done - test -z "$install_prog" && \ - func_fatal_help "you must specify an install program" + # Check to see that this really is a libtool archive. + if (${SED} -e '2q' $lib | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then : + else + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE + fi - test -n "$prev" && \ - func_fatal_help "the \`$prev' option requires an argument" + ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'` + test "X$ladir" = "X$lib" && ladir="." - if test -z "$files"; then - if test -z "$dest"; then - func_fatal_help "no file or destination specified" - else - func_fatal_help "you must specify a destination" - fi - fi + dlname= + dlopen= + dlpreopen= + libdir= + library_names= + old_library= + # If the library was installed with an old release of libtool, + # it will not redefine variables installed, or shouldnotlink + installed=yes + shouldnotlink=no - # Strip any trailing slash from the destination. - func_stripname '' '/' "$dest" - dest=$func_stripname_result + # Read the .la file + case $lib in + */* | *\\*) . $lib ;; + *) . ./$lib ;; + esac - # Check to see that the destination is a directory. - test -d "$dest" && isdir=yes - if test "$isdir" = yes; then - destdir="$dest" - destname= - else - func_dirname_and_basename "$dest" "" "." - destdir="$func_dirname_result" - destname="$func_basename_result" + if test "$linkmode,$pass" = "lib,link" || + test "$linkmode,$pass" = "prog,scan" || + { test "$linkmode" != prog && test "$linkmode" != lib; }; then + test -n "$dlopen" && dlfiles="$dlfiles $dlopen" + test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen" + fi - # Not a directory, so check to see that there is only one file specified. - set dummy $files; shift - test "$#" -gt 1 && \ - func_fatal_help "\`$dest' is not a directory" - fi - case $destdir in - [\\/]* | [A-Za-z]:[\\/]*) ;; - *) - for file in $files; do - case $file in - *.lo) ;; - *) - func_fatal_help "\`$destdir' must be an absolute directory name" - ;; - esac - done - ;; - esac - - # This variable tells wrapper scripts just to set variables rather - # than running their programs. - libtool_install_magic="$magic" - - staticlibs= - future_libdirs= - current_libdirs= - for file in $files; do - - # Do each installation. - case $file in - *.$libext) - # Do the static libraries later. - staticlibs="$staticlibs $file" - ;; - - *.la) - # Check to see that this really is a libtool archive. - func_lalib_unsafe_p "$file" \ - || func_fatal_help "\`$file' is not a valid libtool archive" + if test "$pass" = conv; then + # Only check for convenience libraries + deplibs="$lib $deplibs" + if test -z "$libdir"; then + if test -z "$old_library"; then + $echo "$modename: cannot find name of link library for \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + # It is a libtool convenience library, so add in its objects. + convenience="$convenience $ladir/$objdir/$old_library" + old_convenience="$old_convenience $ladir/$objdir/$old_library" + tmp_libs= + for deplib in $dependency_libs; do + deplibs="$deplib $deplibs" + if test "X$duplicate_deps" = "Xyes" ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done + elif test "$linkmode" != prog && test "$linkmode" != lib; then + $echo "$modename: \`$lib' is not a convenience library" 1>&2 + exit $EXIT_FAILURE + fi + continue + fi # $pass = conv - library_names= - old_library= - relink_command= - func_source "$file" - # Add the libdir to current_libdirs if it is the destination. - if test "X$destdir" = "X$libdir"; then - case "$current_libdirs " in - *" $libdir "*) ;; - *) current_libdirs="$current_libdirs $libdir" ;; - esac - else - # Note the libdir as a future libdir. - case "$future_libdirs " in - *" $libdir "*) ;; - *) future_libdirs="$future_libdirs $libdir" ;; - esac + # Get the name of the library we link against. + linklib= + for l in $old_library $library_names; do + linklib="$l" + done + if test -z "$linklib"; then + $echo "$modename: cannot find name of link library for \`$lib'" 1>&2 + exit $EXIT_FAILURE fi - func_dirname "$file" "/" "" - dir="$func_dirname_result" - dir="$dir$objdir" + # This library was specified with -dlopen. + if test "$pass" = dlopen; then + if test -z "$libdir"; then + $echo "$modename: cannot -dlopen a convenience library: \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + if test -z "$dlname" || + test "$dlopen_support" != yes || + test "$build_libtool_libs" = no; then + # If there is no dlname, no dlopen support or we're linking + # statically, we need to preload. We also need to preload any + # dependent libraries so libltdl's deplib preloader doesn't + # bomb out in the load deplibs phase. + dlprefiles="$dlprefiles $lib $dependency_libs" + else + newdlfiles="$newdlfiles $lib" + fi + continue + fi # $pass = dlopen - if test -n "$relink_command"; then - # Determine the prefix the user has applied to our future dir. - inst_prefix_dir=`$ECHO "X$destdir" | $Xsed -e "s%$libdir\$%%"` + # We need an absolute path. + case $ladir in + [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;; + *) + abs_ladir=`cd "$ladir" && pwd` + if test -z "$abs_ladir"; then + $echo "$modename: warning: cannot determine absolute directory name of \`$ladir'" 1>&2 + $echo "$modename: passing it literally to the linker, although it might fail" 1>&2 + abs_ladir="$ladir" + fi + ;; + esac + laname=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` - # Don't allow the user to place us outside of our expected - # location b/c this prevents finding dependent libraries that - # are installed to the same prefix. - # At present, this check doesn't affect windows .dll's that - # are installed into $libdir/../bin (currently, that works fine) - # but it's something to keep an eye on. - test "$inst_prefix_dir" = "$destdir" && \ - func_fatal_error "error: cannot install \`$file' to a directory not ending in $libdir" + # Find the relevant object directory and library name. + if test "X$installed" = Xyes; then + if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then + $echo "$modename: warning: library \`$lib' was moved." 1>&2 + dir="$ladir" + absdir="$abs_ladir" + libdir="$abs_ladir" + else + dir="$libdir" + absdir="$libdir" + fi + else + dir="$ladir/$objdir" + absdir="$abs_ladir/$objdir" + # Remove this search path later + notinst_path="$notinst_path $abs_ladir" + fi # $installed = yes + name=`$echo "X$laname" | $Xsed -e 's/\.la$//' -e 's/^lib//'` - if test -n "$inst_prefix_dir"; then - # Stick the inst_prefix_dir data into the link command. - relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` + # This library was specified with -dlpreopen. + if test "$pass" = dlpreopen; then + if test -z "$libdir"; then + $echo "$modename: cannot -dlpreopen a convenience library: \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + # Prefer using a static library (so that no silly _DYNAMIC symbols + # are required to link). + if test -n "$old_library"; then + newdlprefiles="$newdlprefiles $dir/$old_library" + # Otherwise, use the dlname, so that lt_dlopen finds it. + elif test -n "$dlname"; then + newdlprefiles="$newdlprefiles $dir/$dlname" else - relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%%"` + newdlprefiles="$newdlprefiles $dir/$linklib" fi + fi # $pass = dlpreopen - func_warning "relinking \`$file'" - func_show_eval "$relink_command" \ - 'func_fatal_error "error: relink \`$file'\'' with the above command before installing it"' + if test -z "$libdir"; then + # Link the convenience library + if test "$linkmode" = lib; then + deplibs="$dir/$old_library $deplibs" + elif test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$dir/$old_library $compile_deplibs" + finalize_deplibs="$dir/$old_library $finalize_deplibs" + else + deplibs="$lib $deplibs" # used for prog,scan pass + fi + continue fi - # See the names of the shared library. - set dummy $library_names; shift - if test -n "$1"; then - realname="$1" - shift - - srcname="$realname" - test -n "$relink_command" && srcname="$realname"T - # Install the shared library and build the symlinks. - func_show_eval "$install_prog $dir/$srcname $destdir/$realname" \ - 'exit $?' - tstripme="$stripme" - case $host_os in - cygwin* | mingw* | pw32* | cegcc*) - case $realname in - *.dll.a) - tstripme="" - ;; - esac - ;; - esac - if test -n "$tstripme" && test -n "$striplib"; then - func_show_eval "$striplib $destdir/$realname" 'exit $?' - fi + if test "$linkmode" = prog && test "$pass" != link; then + newlib_search_path="$newlib_search_path $ladir" + deplibs="$lib $deplibs" - if test "$#" -gt 0; then - # Delete the old symlinks, and create new ones. - # Try `ln -sf' first, because the `ln' binary might depend on - # the symlink we replace! Solaris /bin/ln does not understand -f, - # so we also need to try rm && ln -s. - for linkname - do - test "$linkname" != "$realname" \ - && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" - done + linkalldeplibs=no + if test "$link_all_deplibs" != no || test -z "$library_names" || + test "$build_libtool_libs" = no; then + linkalldeplibs=yes fi - # Do each command in the postinstall commands. - lib="$destdir/$realname" - func_execute_cmds "$postinstall_cmds" 'exit $?' - fi - - # Install the pseudo-library for information purposes. - func_basename "$file" - name="$func_basename_result" - instname="$dir/$name"i - func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' + tmp_libs= + for deplib in $dependency_libs; do + case $deplib in + -L*) newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`;; ### testsuite: skip nested quoting test + esac + # Need to link against all dependency_libs? + if test "$linkalldeplibs" = yes; then + deplibs="$deplib $deplibs" + else + # Need to hardcode shared library paths + # or/and link against static libraries + newdependency_libs="$deplib $newdependency_libs" + fi + if test "X$duplicate_deps" = "Xyes" ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done # for deplib + continue + fi # $linkmode = prog... - # Maybe install the static library, too. - test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library" - ;; + if test "$linkmode,$pass" = "prog,link"; then + if test -n "$library_names" && + { test "$prefer_static_libs" = no || test -z "$old_library"; }; then + # We need to hardcode the library path + if test -n "$shlibpath_var"; then + # Make sure the rpath contains only unique directories. + case "$temp_rpath " in + *" $dir "*) ;; + *" $absdir "*) ;; + *) temp_rpath="$temp_rpath $dir" ;; + esac + fi - *.lo) - # Install (i.e. copy) a libtool object. + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) compile_rpath="$compile_rpath $absdir" + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" + esac + ;; + esac + fi # $linkmode,$pass = prog,link... - # Figure out destination file name, if it wasn't already specified. - if test -n "$destname"; then - destfile="$destdir/$destname" - else - func_basename "$file" - destfile="$func_basename_result" - destfile="$destdir/$destfile" + if test "$alldeplibs" = yes && + { test "$deplibs_check_method" = pass_all || + { test "$build_libtool_libs" = yes && + test -n "$library_names"; }; }; then + # We only need to search for static libraries + continue + fi fi - # Deduce the name of the destination old-style object file. - case $destfile in - *.lo) - func_lo2o "$destfile" - staticdest=$func_lo2o_result - ;; - *.$objext) - staticdest="$destfile" - destfile= - ;; - *) - func_fatal_help "cannot copy a libtool object to \`$destfile'" - ;; - esac + link_static=no # Whether the deplib will be linked statically + if test -n "$library_names" && + { test "$prefer_static_libs" = no || test -z "$old_library"; }; then + if test "$installed" = no; then + notinst_deplibs="$notinst_deplibs $lib" + need_relink=yes + fi + # This is a shared library - # Install the libtool object if requested. - test -n "$destfile" && \ - func_show_eval "$install_prog $file $destfile" 'exit $?' + # Warn about portability, can't link against -module's on + # some systems (darwin) + if test "$shouldnotlink" = yes && test "$pass" = link ; then + $echo + if test "$linkmode" = prog; then + $echo "*** Warning: Linking the executable $output against the loadable module" + else + $echo "*** Warning: Linking the shared library $output against the loadable module" + fi + $echo "*** $linklib is not portable!" + fi + if test "$linkmode" = lib && + test "$hardcode_into_libs" = yes; then + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) compile_rpath="$compile_rpath $absdir" + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" + esac + ;; + esac + fi - # Install the old object if enabled. - if test "$build_old_libs" = yes; then - # Deduce the name of the old-style object file. - func_lo2o "$file" - staticobj=$func_lo2o_result - func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' - fi - exit $EXIT_SUCCESS - ;; + if test -n "$old_archive_from_expsyms_cmds"; then + # figure out the soname + set dummy $library_names + realname="$2" + shift; shift + libname=`eval \\$echo \"$libname_spec\"` + # use dlname if we got it. it's perfectly good, no? + if test -n "$dlname"; then + soname="$dlname" + elif test -n "$soname_spec"; then + # bleh windows + case $host in + *cygwin* | mingw*) + major=`expr $current - $age` + versuffix="-$major" + ;; + esac + eval soname=\"$soname_spec\" + else + soname="$realname" + fi - *) - # Figure out destination file name, if it wasn't already specified. - if test -n "$destname"; then - destfile="$destdir/$destname" - else - func_basename "$file" - destfile="$func_basename_result" - destfile="$destdir/$destfile" - fi + # Make a new name for the extract_expsyms_cmds to use + soroot="$soname" + soname=`$echo $soroot | ${SED} -e 's/^.*\///'` + newlib="libimp-`$echo $soname | ${SED} 's/^lib//;s/\.dll$//'`.a" - # If the file is missing, and there is a .exe on the end, strip it - # because it is most likely a libtool script we actually want to - # install - stripped_ext="" - case $file in - *.exe) - if test ! -f "$file"; then - func_stripname '' '.exe' "$file" - file=$func_stripname_result - stripped_ext=".exe" + # If the library has no export list, then create one now + if test -f "$output_objdir/$soname-def"; then : + else + $show "extracting exported symbol list from \`$soname'" + save_ifs="$IFS"; IFS='~' + cmds=$extract_expsyms_cmds + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" fi - ;; - esac - # Do a test to see if this is really a libtool program. - case $host in - *cygwin* | *mingw*) - if func_ltwrapper_executable_p "$file"; then - func_ltwrapper_scriptname "$file" - wrapper=$func_ltwrapper_scriptname_result - else - func_stripname '' '.exe' "$file" - wrapper=$func_stripname_result + # Create $newlib + if test -f "$output_objdir/$newlib"; then :; else + $show "generating import library for \`$soname'" + save_ifs="$IFS"; IFS='~' + cmds=$old_archive_from_expsyms_cmds + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" fi - ;; - *) - wrapper=$file - ;; - esac - if func_ltwrapper_script_p "$wrapper"; then - notinst_deplibs= - relink_command= + # make sure the library variables are pointing to the new library + dir=$output_objdir + linklib=$newlib + fi # test -n "$old_archive_from_expsyms_cmds" - func_source "$wrapper" + if test "$linkmode" = prog || test "$mode" != relink; then + add_shlibpath= + add_dir= + add= + lib_linked=yes + case $hardcode_action in + immediate | unsupported) + if test "$hardcode_direct" = no; then + add="$dir/$linklib" + case $host in + *-*-sco3.2v5* ) add_dir="-L$dir" ;; + *-*-darwin* ) + # if the lib is a module then we can not link against + # it, someone is ignoring the new warnings I added + if /usr/bin/file -L $add 2> /dev/null | $EGREP "bundle" >/dev/null ; then + $echo "** Warning, lib $linklib is a module, not a shared library" + if test -z "$old_library" ; then + $echo + $echo "** And there doesn't seem to be a static archive available" + $echo "** The link will probably fail, sorry" + else + add="$dir/$old_library" + fi + fi + esac + elif test "$hardcode_minus_L" = no; then + case $host in + *-*-sunos*) add_shlibpath="$dir" ;; + esac + add_dir="-L$dir" + add="-l$name" + elif test "$hardcode_shlibpath_var" = no; then + add_shlibpath="$dir" + add="-l$name" + else + lib_linked=no + fi + ;; + relink) + if test "$hardcode_direct" = yes; then + add="$dir/$linklib" + elif test "$hardcode_minus_L" = yes; then + add_dir="-L$dir" + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case "$libdir" in + [\\/]*) + add_dir="$add_dir -L$inst_prefix_dir$libdir" + ;; + esac + fi + add="-l$name" + elif test "$hardcode_shlibpath_var" = yes; then + add_shlibpath="$dir" + add="-l$name" + else + lib_linked=no + fi + ;; + *) lib_linked=no ;; + esac - # Check the variables that should have been set. - test -z "$generated_by_libtool_version" && \ - func_fatal_error "invalid libtool wrapper script \`$wrapper'" + if test "$lib_linked" != yes; then + $echo "$modename: configuration error: unsupported hardcode properties" + exit $EXIT_FAILURE + fi - finalize=yes - for lib in $notinst_deplibs; do - # Check to see that each library is installed. - libdir= - if test -f "$lib"; then - func_source "$lib" + if test -n "$add_shlibpath"; then + case :$compile_shlibpath: in + *":$add_shlibpath:"*) ;; + *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;; + esac fi - libfile="$libdir/"`$ECHO "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test - if test -n "$libdir" && test ! -f "$libfile"; then - func_warning "\`$lib' has not been installed in \`$libdir'" - finalize=no + if test "$linkmode" = prog; then + test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" + test -n "$add" && compile_deplibs="$add $compile_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + if test "$hardcode_direct" != yes && \ + test "$hardcode_minus_L" != yes && \ + test "$hardcode_shlibpath_var" = yes; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; + esac + fi fi - done + fi - relink_command= - func_source "$wrapper" + if test "$linkmode" = prog || test "$mode" = relink; then + add_shlibpath= + add_dir= + add= + # Finalize command for both is simple: just hardcode it. + if test "$hardcode_direct" = yes; then + add="$libdir/$linklib" + elif test "$hardcode_minus_L" = yes; then + add_dir="-L$libdir" + add="-l$name" + elif test "$hardcode_shlibpath_var" = yes; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; + esac + add="-l$name" + elif test "$hardcode_automatic" = yes; then + if test -n "$inst_prefix_dir" && + test -f "$inst_prefix_dir$libdir/$linklib" ; then + add="$inst_prefix_dir$libdir/$linklib" + else + add="$libdir/$linklib" + fi + else + # We cannot seem to hardcode it, guess we'll fake it. + add_dir="-L$libdir" + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case "$libdir" in + [\\/]*) + add_dir="$add_dir -L$inst_prefix_dir$libdir" + ;; + esac + fi + add="-l$name" + fi - outputname= - if test "$fast_install" = no && test -n "$relink_command"; then - $opt_dry_run || { - if test "$finalize" = yes; then - tmpdir=`func_mktempdir` - func_basename "$file$stripped_ext" - file="$func_basename_result" - outputname="$tmpdir/$file" - # Replace the output file specification. - relink_command=`$ECHO "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'` - - $opt_silent || { - func_quote_for_expand "$relink_command" - eval "func_echo $func_quote_for_expand_result" - } - if eval "$relink_command"; then : - else - func_error "error: relink \`$file' with the above command before installing it" - $opt_dry_run || ${RM}r "$tmpdir" - continue - fi - file="$outputname" + if test "$linkmode" = prog; then + test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" + test -n "$add" && finalize_deplibs="$add $finalize_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + fi + fi + elif test "$linkmode" = prog; then + # Here we assume that one of hardcode_direct or hardcode_minus_L + # is not unsupported. This is valid on all known static and + # shared platforms. + if test "$hardcode_direct" != unsupported; then + test -n "$old_library" && linklib="$old_library" + compile_deplibs="$dir/$linklib $compile_deplibs" + finalize_deplibs="$dir/$linklib $finalize_deplibs" + else + compile_deplibs="-l$name -L$dir $compile_deplibs" + finalize_deplibs="-l$name -L$dir $finalize_deplibs" + fi + elif test "$build_libtool_libs" = yes; then + # Not a shared library + if test "$deplibs_check_method" != pass_all; then + # We're trying link a shared library against a static one + # but the system doesn't support it. + + # Just print a warning and add the library to dependency_libs so + # that the program can be linked against the static library. + $echo + $echo "*** Warning: This system can not link to static lib archive $lib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have." + if test "$module" = yes; then + $echo "*** But as you try to build a module library, libtool will still create " + $echo "*** a static module, that should work as long as the dlopening application" + $echo "*** is linked with the -dlopen flag to resolve symbols at runtime." + if test -z "$global_symbol_pipe"; then + $echo + $echo "*** However, this would only work if libtool was able to extract symbol" + $echo "*** lists from a program, using \`nm' or equivalent, but libtool could" + $echo "*** not find such a program. So, this module is probably useless." + $echo "*** \`nm' from GNU binutils and a full rebuild may help." + fi + if test "$build_old_libs" = no; then + build_libtool_libs=module + build_old_libs=yes else - func_warning "cannot relink \`$file'" + build_libtool_libs=no fi - } + fi else - # Install the binary that we compiled earlier. - file=`$ECHO "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"` + convenience="$convenience $dir/$old_library" + old_convenience="$old_convenience $dir/$old_library" + deplibs="$dir/$old_library $deplibs" + link_static=yes fi - fi + fi # link shared/static library? - # remove .exe since cygwin /usr/bin/install will append another - # one anyway - case $install_prog,$host in - */usr/bin/install*,*cygwin*) - case $file:$destfile in - *.exe:*.exe) - # this is ok - ;; - *.exe:*) - destfile=$destfile.exe - ;; - *:*.exe) - func_stripname '' '.exe' "$destfile" - destfile=$func_stripname_result - ;; - esac - ;; - esac - func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' - $opt_dry_run || if test -n "$outputname"; then - ${RM}r "$tmpdir" - fi - ;; - esac - done - - for file in $staticlibs; do - func_basename "$file" - name="$func_basename_result" - - # Set up the ranlib parameters. - oldlib="$destdir/$name" + if test "$linkmode" = lib; then + if test -n "$dependency_libs" && + { test "$hardcode_into_libs" != yes || + test "$build_old_libs" = yes || + test "$link_static" = yes; }; then + # Extract -R from dependency_libs + temp_deplibs= + for libdir in $dependency_libs; do + case $libdir in + -R*) temp_xrpath=`$echo "X$libdir" | $Xsed -e 's/^-R//'` + case " $xrpath " in + *" $temp_xrpath "*) ;; + *) xrpath="$xrpath $temp_xrpath";; + esac;; + *) temp_deplibs="$temp_deplibs $libdir";; + esac + done + dependency_libs="$temp_deplibs" + fi - func_show_eval "$install_prog \$file \$oldlib" 'exit $?' + newlib_search_path="$newlib_search_path $absdir" + # Link against this library + test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs" + # ... and its dependency_libs + tmp_libs= + for deplib in $dependency_libs; do + newdependency_libs="$deplib $newdependency_libs" + if test "X$duplicate_deps" = "Xyes" ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done - if test -n "$stripme" && test -n "$old_striplib"; then - func_show_eval "$old_striplib $oldlib" 'exit $?' + if test "$link_all_deplibs" != no; then + # Add the search paths of all dependency libraries + for deplib in $dependency_libs; do + case $deplib in + -L*) path="$deplib" ;; + *.la) + dir=`$echo "X$deplib" | $Xsed -e 's%/[^/]*$%%'` + test "X$dir" = "X$deplib" && dir="." + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;; + *) + absdir=`cd "$dir" && pwd` + if test -z "$absdir"; then + $echo "$modename: warning: cannot determine absolute directory name of \`$dir'" 1>&2 + absdir="$dir" + fi + ;; + esac + if grep "^installed=no" $deplib > /dev/null; then + path="$absdir/$objdir" + else + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` + if test -z "$libdir"; then + $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE + fi + if test "$absdir" != "$libdir"; then + $echo "$modename: warning: \`$deplib' seems to be moved" 1>&2 + fi + path="$absdir" + fi + depdepl= + case $host in + *-*-darwin*) + # we do not want to link against static libs, + # but need to link against shared + eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` + if test -n "$deplibrary_names" ; then + for tmp in $deplibrary_names ; do + depdepl=$tmp + done + if test -f "$path/$depdepl" ; then + depdepl="$path/$depdepl" + fi + # do not add paths which are already there + case " $newlib_search_path " in + *" $path "*) ;; + *) newlib_search_path="$newlib_search_path $path";; + esac + fi + path="" + ;; + *) + path="-L$path" + ;; + esac + ;; + -l*) + case $host in + *-*-darwin*) + # Again, we only want to link against shared libraries + eval tmp_libs=`$echo "X$deplib" | $Xsed -e "s,^\-l,,"` + for tmp in $newlib_search_path ; do + if test -f "$tmp/lib$tmp_libs.dylib" ; then + eval depdepl="$tmp/lib$tmp_libs.dylib" + break + fi + done + path="" + ;; + *) continue ;; + esac + ;; + *) continue ;; + esac + case " $deplibs " in + *" $depdepl "*) ;; + *) deplibs="$depdepl $deplibs" ;; + esac + case " $deplibs " in + *" $path "*) ;; + *) deplibs="$deplibs $path" ;; + esac + done + fi # link_all_deplibs != no + fi # linkmode = lib + done # for deplib in $libs + dependency_libs="$newdependency_libs" + if test "$pass" = dlpreopen; then + # Link the dlpreopened libraries before other libraries + for deplib in $save_deplibs; do + deplibs="$deplib $deplibs" + done fi + if test "$pass" != dlopen; then + if test "$pass" != conv; then + # Make sure lib_search_path contains only unique directories. + lib_search_path= + for dir in $newlib_search_path; do + case "$lib_search_path " in + *" $dir "*) ;; + *) lib_search_path="$lib_search_path $dir" ;; + esac + done + newlib_search_path= + fi - # Do each command in the postinstall commands. - func_execute_cmds "$old_postinstall_cmds" 'exit $?' - done - - test -n "$future_libdirs" && \ - func_warning "remember to run \`$progname --finish$future_libdirs'" - - if test -n "$current_libdirs"; then - # Maybe just do a dry run. - $opt_dry_run && current_libdirs=" -n$current_libdirs" - exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs' - else - exit $EXIT_SUCCESS + if test "$linkmode,$pass" != "prog,link"; then + vars="deplibs" + else + vars="compile_deplibs finalize_deplibs" + fi + for var in $vars dependency_libs; do + # Add libraries to $var in reverse order + eval tmp_libs=\"\$$var\" + new_libs= + for deplib in $tmp_libs; do + # FIXME: Pedantically, this is the right thing to do, so + # that some nasty dependency loop isn't accidentally + # broken: + #new_libs="$deplib $new_libs" + # Pragmatically, this seems to cause very few problems in + # practice: + case $deplib in + -L*) new_libs="$deplib $new_libs" ;; + -R*) ;; + *) + # And here is the reason: when a library appears more + # than once as an explicit dependence of a library, or + # is implicitly linked in more than once by the + # compiler, it is considered special, and multiple + # occurrences thereof are not removed. Compare this + # with having the same library being listed as a + # dependency of multiple other libraries: in this case, + # we know (pedantically, we assume) the library does not + # need to be listed more than once, so we keep only the + # last copy. This is not always right, but it is rare + # enough that we require users that really mean to play + # such unportable linking tricks to link the library + # using -Wl,-lname, so that libtool does not consider it + # for duplicate removal. + case " $specialdeplibs " in + *" $deplib "*) new_libs="$deplib $new_libs" ;; + *) + case " $new_libs " in + *" $deplib "*) ;; + *) new_libs="$deplib $new_libs" ;; + esac + ;; + esac + ;; + esac + done + tmp_libs= + for deplib in $new_libs; do + case $deplib in + -L*) + case " $tmp_libs " in + *" $deplib "*) ;; + *) tmp_libs="$tmp_libs $deplib" ;; + esac + ;; + *) tmp_libs="$tmp_libs $deplib" ;; + esac + done + eval $var=\"$tmp_libs\" + done # for var + fi + # Last step: remove runtime libs from dependency_libs + # (they stay in deplibs) + tmp_libs= + for i in $dependency_libs ; do + case " $predeps $postdeps $compiler_lib_search_path " in + *" $i "*) + i="" + ;; + esac + if test -n "$i" ; then + tmp_libs="$tmp_libs $i" + fi + done + dependency_libs=$tmp_libs + done # for pass + if test "$linkmode" = prog; then + dlfiles="$newdlfiles" + dlprefiles="$newdlprefiles" fi -} - -test "$mode" = install && func_mode_install ${1+"$@"} + case $linkmode in + oldlib) + if test -n "$deplibs"; then + $echo "$modename: warning: \`-l' and \`-L' are ignored for archives" 1>&2 + fi -# func_generate_dlsyms outputname originator pic_p -# Extract symbols from dlprefiles and create ${outputname}S.o with -# a dlpreopen symbol table. -func_generate_dlsyms () -{ - $opt_debug - my_outputname="$1" - my_originator="$2" - my_pic_p="${3-no}" - my_prefix=`$ECHO "$my_originator" | sed 's%[^a-zA-Z0-9]%_%g'` - my_dlsyms= - - if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then - if test -n "$NM" && test -n "$global_symbol_pipe"; then - my_dlsyms="${my_outputname}S.c" - else - func_error "not configured to extract global symbols from dlpreopened files" + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + $echo "$modename: warning: \`-dlopen' is ignored for archives" 1>&2 fi - fi - if test -n "$my_dlsyms"; then - case $my_dlsyms in - "") ;; - *.c) - # Discover the nlist of each of the dlfiles. - nlist="$output_objdir/${my_outputname}.nm" + if test -n "$rpath"; then + $echo "$modename: warning: \`-rpath' is ignored for archives" 1>&2 + fi - func_show_eval "$RM $nlist ${nlist}S ${nlist}T" + if test -n "$xrpath"; then + $echo "$modename: warning: \`-R' is ignored for archives" 1>&2 + fi - # Parse the name list into a source file. - func_verbose "creating $output_objdir/$my_dlsyms" + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info/-version-number' is ignored for archives" 1>&2 + fi - $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ -/* $my_dlsyms - symbol resolution table for \`$my_outputname' dlsym emulation. */ -/* Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION */ + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for archives" 1>&2 + fi -#ifdef __cplusplus -extern \"C\" { -#endif + if test -n "$export_symbols" || test -n "$export_symbols_regex"; then + $echo "$modename: warning: \`-export-symbols' is ignored for archives" 1>&2 + fi -/* External symbol declarations for the compiler. */\ -" + # Now set the variables for building old libraries. + build_libtool_libs=no + oldlibs="$output" + objs="$objs$old_deplibs" + ;; - if test "$dlself" = yes; then - func_verbose "generating symbol list for \`$output'" + lib) + # Make sure we only generate libraries of the form `libNAME.la'. + case $outputname in + lib*) + name=`$echo "X$outputname" | $Xsed -e 's/\.la$//' -e 's/^lib//'` + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + ;; + *) + if test "$module" = no; then + $echo "$modename: libtool library \`$output' must begin with \`lib'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + if test "$need_lib_prefix" != no; then + # Add the "lib" prefix for modules if required + name=`$echo "X$outputname" | $Xsed -e 's/\.la$//'` + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + else + libname=`$echo "X$outputname" | $Xsed -e 's/\.la$//'` + fi + ;; + esac - $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" + if test -n "$objs"; then + if test "$deplibs_check_method" != pass_all; then + $echo "$modename: cannot build libtool library \`$output' from non-libtool objects on this host:$objs" 2>&1 + exit $EXIT_FAILURE + else + $echo + $echo "*** Warning: Linking the shared library $output against the non-libtool" + $echo "*** objects $objs is not portable!" + libobjs="$libobjs $objs" + fi + fi - # Add our own program objects to the symbol list. - progfiles=`$ECHO "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` - for progfile in $progfiles; do - func_verbose "extracting global C symbols from \`$progfile'" - $opt_dry_run || eval "$NM $progfile | $global_symbol_pipe >> '$nlist'" - done + if test "$dlself" != no; then + $echo "$modename: warning: \`-dlopen self' is ignored for libtool libraries" 1>&2 + fi - if test -n "$exclude_expsyms"; then - $opt_dry_run || { - eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' - eval '$MV "$nlist"T "$nlist"' - } - fi - - if test -n "$export_symbols_regex"; then - $opt_dry_run || { - eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' - eval '$MV "$nlist"T "$nlist"' - } - fi - - # Prepare the list of exported symbols - if test -z "$export_symbols"; then - export_symbols="$output_objdir/$outputname.exp" - $opt_dry_run || { - $RM $export_symbols - eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' - case $host in - *cygwin* | *mingw* | *cegcc* ) - eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' - eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' - ;; - esac - } - else - $opt_dry_run || { - eval "${SED} -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' - eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' - eval '$MV "$nlist"T "$nlist"' - case $host in - *cygwin | *mingw* | *cegcc* ) - eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' - eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' - ;; - esac - } - fi - fi - - for dlprefile in $dlprefiles; do - func_verbose "extracting global C symbols from \`$dlprefile'" - func_basename "$dlprefile" - name="$func_basename_result" - $opt_dry_run || { - eval '$ECHO ": $name " >> "$nlist"' - eval "$NM $dlprefile 2>/dev/null | $global_symbol_pipe >> '$nlist'" - } - done + set dummy $rpath + if test "$#" -gt 2; then + $echo "$modename: warning: ignoring multiple \`-rpath's for a libtool library" 1>&2 + fi + install_libdir="$2" - $opt_dry_run || { - # Make sure we have at least an empty file. - test -f "$nlist" || : > "$nlist" - - if test -n "$exclude_expsyms"; then - $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T - $MV "$nlist"T "$nlist" - fi + oldlibs= + if test -z "$rpath"; then + if test "$build_libtool_libs" = yes; then + # Building a libtool convenience library. + # Some compilers have problems with a `.al' extension so + # convenience libraries should have the same extension an + # archive normally would. + oldlibs="$output_objdir/$libname.$libext $oldlibs" + build_libtool_libs=convenience + build_old_libs=yes + fi - # Try sorting and uniquifying the output. - if $GREP -v "^: " < "$nlist" | - if sort -k 3 /dev/null 2>&1; then - sort -k 3 - else - sort +2 - fi | - uniq > "$nlist"S; then - : - else - $GREP -v "^: " < "$nlist" > "$nlist"S - fi + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info/-version-number' is ignored for convenience libraries" 1>&2 + fi - if test -f "$nlist"S; then - eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' - else - $ECHO '/* NONE */' >> "$output_objdir/$my_dlsyms" - fi + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for convenience libraries" 1>&2 + fi + else - $ECHO >> "$output_objdir/$my_dlsyms" "\ + # Parse the version information argument. + save_ifs="$IFS"; IFS=':' + set dummy $vinfo 0 0 0 + IFS="$save_ifs" -/* The mapping between symbol names and symbols. */ -typedef struct { - const char *name; - void *address; -} lt_dlsymlist; -" - case $host in - *cygwin* | *mingw* | *cegcc* ) - $ECHO >> "$output_objdir/$my_dlsyms" "\ -/* DATA imports from DLLs on WIN32 con't be const, because - runtime relocations are performed -- see ld's documentation - on pseudo-relocs. */" - lt_dlsym_const= ;; - *osf5*) - echo >> "$output_objdir/$my_dlsyms" "\ -/* This system does not cope well with relocations in const data */" - lt_dlsym_const= ;; - *) - lt_dlsym_const=const ;; - esac + if test -n "$8"; then + $echo "$modename: too many parameters to \`-version-info'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi - $ECHO >> "$output_objdir/$my_dlsyms" "\ -extern $lt_dlsym_const lt_dlsymlist -lt_${my_prefix}_LTX_preloaded_symbols[]; -$lt_dlsym_const lt_dlsymlist -lt_${my_prefix}_LTX_preloaded_symbols[] = -{\ - { \"$my_originator\", (void *) 0 }," + # convert absolute version numbers to libtool ages + # this retains compatibility with .la files and attempts + # to make the code below a bit more comprehensible - case $need_lib_prefix in - no) - eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" + case $vinfo_number in + yes) + number_major="$2" + number_minor="$3" + number_revision="$4" + # + # There are really only two kinds -- those that + # use the current revision as the major version + # and those that subtract age and use age as + # a minor version. But, then there is irix + # which has an extra 1 added just for fun + # + case $version_type in + darwin|linux|osf|windows) + current=`expr $number_major + $number_minor` + age="$number_minor" + revision="$number_revision" ;; - *) - eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" + freebsd-aout|freebsd-elf|sunos) + current="$number_major" + revision="$number_minor" + age="0" ;; - esac - $ECHO >> "$output_objdir/$my_dlsyms" "\ - {0, (void *) 0} -}; - -/* This works around a problem in FreeBSD linker */ -#ifdef FREEBSD_WORKAROUND -static const void *lt_preloaded_setup() { - return lt_${my_prefix}_LTX_preloaded_symbols; -} -#endif - -#ifdef __cplusplus -} -#endif\ -" - } # !$opt_dry_run - - pic_flag_for_symtable= - case "$compile_command " in - *" -static "*) ;; - *) - case $host in - # compiling the symbol table file with pic_flag works around - # a FreeBSD bug that causes programs to crash when -lm is - # linked before any other PIC object. But we must not use - # pic_flag when linking with -static. The problem exists in - # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. - *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) - pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; - *-*-hpux*) - pic_flag_for_symtable=" $pic_flag" ;; - *) - if test "X$my_pic_p" != Xno; then - pic_flag_for_symtable=" $pic_flag" - fi + irix|nonstopux) + current=`expr $number_major + $number_minor - 1` + age="$number_minor" + revision="$number_minor" ;; esac ;; + no) + current="$2" + revision="$3" + age="$4" + ;; esac - symtab_cflags= - for arg in $LTCFLAGS; do - case $arg in - -pie | -fpie | -fPIE) ;; - *) symtab_cflags="$symtab_cflags $arg" ;; - esac - done - - # Now compile the dynamic symbol file. - func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' - # Clean up the generated files. - func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T"' - - # Transform the symbol file into the correct name. - symfileobj="$output_objdir/${my_outputname}S.$objext" - case $host in - *cygwin* | *mingw* | *cegcc* ) - if test -f "$output_objdir/$my_outputname.def"; then - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` - else - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` - fi - ;; + # Check that each of the things are valid numbers. + case $current in + [0-9]*) ;; *) - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` + $echo "$modename: CURRENT \`$current' is not a nonnegative integer" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE ;; esac - ;; - *) - func_fatal_error "unknown suffix for \`$my_dlsyms'" - ;; - esac - else - # We keep going just in case the user didn't refer to - # lt_preloaded_symbols. The linker will fail if global_symbol_pipe - # really was required. - - # Nullify the symbol file. - compile_command=`$ECHO "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"` - finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"` - fi -} -# func_win32_libid arg -# return the library type of file 'arg' -# -# Need a lot of goo to handle *both* DLLs and import libs -# Has to be a shell function in order to 'eat' the argument -# that is supplied when $file_magic_command is called. -func_win32_libid () -{ - $opt_debug - win32_libid_type="unknown" - win32_fileres=`file -L $1 2>/dev/null` - case $win32_fileres in - *ar\ archive\ import\ library*) # definitely import - win32_libid_type="x86 archive import" - ;; - *ar\ archive*) # could be an import, or static - if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | - $EGREP 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then - win32_nmres=`eval $NM -f posix -A $1 | - $SED -n -e ' - 1,100{ - / I /{ - s,.*,import, - p - q - } - }'` - case $win32_nmres in - import*) win32_libid_type="x86 archive import";; - *) win32_libid_type="x86 archive static";; - esac - fi - ;; - *DLL*) - win32_libid_type="x86 DLL" - ;; - *executable*) # but shell scripts are "executable" too... - case $win32_fileres in - *MS\ Windows\ PE\ Intel*) - win32_libid_type="x86 DLL" - ;; - esac - ;; - esac - $ECHO "$win32_libid_type" -} + case $revision in + [0-9]*) ;; + *) + $echo "$modename: REVISION \`$revision' is not a nonnegative integer" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE + ;; + esac + case $age in + [0-9]*) ;; + *) + $echo "$modename: AGE \`$age' is not a nonnegative integer" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE + ;; + esac + if test "$age" -gt "$current"; then + $echo "$modename: AGE \`$age' is greater than the current interface number \`$current'" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE + fi -# func_extract_an_archive dir oldlib -func_extract_an_archive () -{ - $opt_debug - f_ex_an_ar_dir="$1"; shift - f_ex_an_ar_oldlib="$1" - func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" 'exit $?' - if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then - : - else - func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" - fi -} + # Calculate the version variables. + major= + versuffix= + verstring= + case $version_type in + none) ;; + darwin) + # Like Linux, but with the current version available in + # verstring for coding it into the library header + major=.`expr $current - $age` + versuffix="$major.$age.$revision" + # Darwin ld doesn't like 0 for these options... + minor_current=`expr $current + 1` + verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" + ;; -# func_extract_archives gentop oldlib ... -func_extract_archives () -{ - $opt_debug - my_gentop="$1"; shift - my_oldlibs=${1+"$@"} - my_oldobjs="" - my_xlib="" - my_xabs="" - my_xdir="" - - for my_xlib in $my_oldlibs; do - # Extract the objects. - case $my_xlib in - [\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;; - *) my_xabs=`pwd`"/$my_xlib" ;; - esac - func_basename "$my_xlib" - my_xlib="$func_basename_result" - my_xlib_u=$my_xlib - while :; do - case " $extracted_archives " in - *" $my_xlib_u "*) - func_arith $extracted_serial + 1 - extracted_serial=$func_arith_result - my_xlib_u=lt$extracted_serial-$my_xlib ;; - *) break ;; - esac - done - extracted_archives="$extracted_archives $my_xlib_u" - my_xdir="$my_gentop/$my_xlib_u" + freebsd-aout) + major=".$current" + versuffix=".$current.$revision"; + ;; - func_mkdir_p "$my_xdir" + freebsd-elf) + major=".$current" + versuffix=".$current"; + ;; - case $host in - *-darwin*) - func_verbose "Extracting $my_xabs" - # Do not bother doing anything if just a dry run - $opt_dry_run || { - darwin_orig_dir=`pwd` - cd $my_xdir || exit $? - darwin_archive=$my_xabs - darwin_curdir=`pwd` - darwin_base_archive=`basename "$darwin_archive"` - darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` - if test -n "$darwin_arches"; then - darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` - darwin_arch= - func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" - for darwin_arch in $darwin_arches ; do - func_mkdir_p "unfat-$$/${darwin_base_archive}-${darwin_arch}" - $LIPO -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}" - cd "unfat-$$/${darwin_base_archive}-${darwin_arch}" - func_extract_an_archive "`pwd`" "${darwin_base_archive}" - cd "$darwin_curdir" - $RM "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" - done # $darwin_arches - ## 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_file= - darwin_files= - for darwin_file in $darwin_filelist; do - darwin_files=`find unfat-$$ -name $darwin_file -print | $NL2SP` - $LIPO -create -output "$darwin_file" $darwin_files - done # $darwin_filelist - $RM -rf unfat-$$ - cd "$darwin_orig_dir" - else - cd $darwin_orig_dir - func_extract_an_archive "$my_xdir" "$my_xabs" - fi # $darwin_arches - } # !$opt_dry_run - ;; - *) - func_extract_an_archive "$my_xdir" "$my_xabs" - ;; - esac - my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP` - done + irix | nonstopux) + major=`expr $current - $age + 1` - func_extract_archives_result="$my_oldobjs" -} + case $version_type in + nonstopux) verstring_prefix=nonstopux ;; + *) verstring_prefix=sgi ;; + esac + verstring="$verstring_prefix$major.$revision" + # Add in all the interfaces that we are compatible with. + loop=$revision + while test "$loop" -ne 0; do + iface=`expr $revision - $loop` + loop=`expr $loop - 1` + verstring="$verstring_prefix$major.$iface:$verstring" + done + # Before this point, $major must not contain `.'. + major=.$major + versuffix="$major.$revision" + ;; -# func_emit_wrapper_part1 [arg=no] -# -# Emit the first part of a libtool wrapper script on stdout. -# For more information, see the description associated with -# func_emit_wrapper(), below. -func_emit_wrapper_part1 () -{ - func_emit_wrapper_part1_arg1=no - if test -n "$1" ; then - func_emit_wrapper_part1_arg1=$1 - fi + linux) + major=.`expr $current - $age` + versuffix="$major.$age.$revision" + ;; - $ECHO "\ -#! $SHELL + osf) + major=.`expr $current - $age` + versuffix=".$current.$age.$revision" + verstring="$current.$age.$revision" -# $output - temporary wrapper script for $objdir/$outputname -# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION -# -# The $output program cannot be directly executed until all the libtool -# libraries that it depends on are installed. -# -# This wrapper script should never be moved out of the build directory. -# If it is, it will not operate correctly. + # Add in all the interfaces that we are compatible with. + loop=$age + while test "$loop" -ne 0; do + iface=`expr $current - $loop` + loop=`expr $loop - 1` + verstring="$verstring:${iface}.0" + done -# Sed substitution that helps us do robust quoting. It backslashifies -# metacharacters that are still active within double-quoted strings. -Xsed='${SED} -e 1s/^X//' -sed_quote_subst='$sed_quote_subst' + # Make executables depend on our current version. + verstring="$verstring:${current}.0" + ;; -# Be Bourne compatible -if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which - # is contrary to our usage. Disable this feature. - alias -g '\${1+\"\$@\"}'='\"\$@\"' - setopt NO_GLOB_SUBST -else - case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac -fi -BIN_SH=xpg4; export BIN_SH # for Tru64 -DUALCASE=1; export DUALCASE # for MKS sh + sunos) + major=".$current" + versuffix=".$current.$revision" + ;; -# The HP-UX ksh and POSIX shell print the target directory to stdout -# if CDPATH is set. -(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + windows) + # Use '-' rather than '.', since we only want one + # extension on DOS 8.3 filesystems. + major=`expr $current - $age` + versuffix="-$major" + ;; -relink_command=\"$relink_command\" + *) + $echo "$modename: unknown library version type \`$version_type'" 1>&2 + $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2 + exit $EXIT_FAILURE + ;; + esac -# This environment variable determines our operation mode. -if test \"\$libtool_install_magic\" = \"$magic\"; then - # install mode needs the following variables: - generated_by_libtool_version='$macro_version' - notinst_deplibs='$notinst_deplibs' -else - # When we are sourced in execute mode, \$file and \$ECHO are already set. - if test \"\$libtool_execute_magic\" != \"$magic\"; then - ECHO=\"$qecho\" - file=\"\$0\" - # Make sure echo works. - if test \"X\$1\" = X--no-reexec; then - # Discard the --no-reexec flag, and continue. - shift - elif test \"X\`{ \$ECHO '\t'; } 2>/dev/null\`\" = 'X\t'; then - # Yippee, \$ECHO works! - : - else - # Restart under the correct shell, and then maybe \$ECHO will work. - exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"} - fi - fi\ -" - $ECHO "\ - - # Find the directory that this script lives in. - thisdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\` - test \"x\$thisdir\" = \"x\$file\" && thisdir=. - - # Follow symbolic links until we get to the real thisdir. - file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\` - while test -n \"\$file\"; do - destdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\` - - # If there was a directory component, then change thisdir. - if test \"x\$destdir\" != \"x\$file\"; then - case \"\$destdir\" in - [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; - *) thisdir=\"\$thisdir/\$destdir\" ;; - esac - fi - - file=\`\$ECHO \"X\$file\" | \$Xsed -e 's%^.*/%%'\` - file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\` - done -" -} -# end: func_emit_wrapper_part1 - -# func_emit_wrapper_part2 [arg=no] -# -# Emit the second part of a libtool wrapper script on stdout. -# For more information, see the description associated with -# func_emit_wrapper(), below. -func_emit_wrapper_part2 () -{ - func_emit_wrapper_part2_arg1=no - if test -n "$1" ; then - func_emit_wrapper_part2_arg1=$1 - fi - - $ECHO "\ - - # Usually 'no', except on cygwin/mingw when embedded into - # the cwrapper. - WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_part2_arg1 - if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then - # special case for '.' - if test \"\$thisdir\" = \".\"; then - thisdir=\`pwd\` - fi - # remove .libs from thisdir - case \"\$thisdir\" in - *[\\\\/]$objdir ) thisdir=\`\$ECHO \"X\$thisdir\" | \$Xsed -e 's%[\\\\/][^\\\\/]*$%%'\` ;; - $objdir ) thisdir=. ;; - esac - fi - - # Try to get the absolute directory name. - absdir=\`cd \"\$thisdir\" && pwd\` - test -n \"\$absdir\" && thisdir=\"\$absdir\" -" - - if test "$fast_install" = yes; then - $ECHO "\ - program=lt-'$outputname'$exeext - progdir=\"\$thisdir/$objdir\" - - if test ! -f \"\$progdir/\$program\" || - { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\ - test \"X\$file\" != \"X\$progdir/\$program\"; }; then - - file=\"\$\$-\$program\" - - if test ! -d \"\$progdir\"; then - $MKDIR \"\$progdir\" - else - $RM \"\$progdir/\$file\" - fi" - - $ECHO "\ + # Clear the version info if we defaulted, and they specified a release. + if test -z "$vinfo" && test -n "$release"; then + major= + case $version_type in + darwin) + # we can't check for "0.0" in archive_cmds due to quoting + # problems, so we reset it completely + verstring= + ;; + *) + verstring="0.0" + ;; + esac + if test "$need_version" = no; then + versuffix= + else + versuffix=".0.0" + fi + fi - # relink executable if necessary - if test -n \"\$relink_command\"; then - if relink_command_output=\`eval \$relink_command 2>&1\`; then : - else - $ECHO \"\$relink_command_output\" >&2 - $RM \"\$progdir/\$file\" - exit 1 - fi - fi + # Remove version info from name if versioning should be avoided + if test "$avoid_version" = yes && test "$need_version" = no; then + major= + versuffix= + verstring="" + fi - $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || - { $RM \"\$progdir/\$program\"; - $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } - $RM \"\$progdir/\$file\" - fi" + # Check to see if the archive will have undefined symbols. + if test "$allow_undefined" = yes; then + if test "$allow_undefined_flag" = unsupported; then + $echo "$modename: warning: undefined symbols not allowed in $host shared libraries" 1>&2 + build_libtool_libs=no + build_old_libs=yes + fi else - $ECHO "\ - program='$outputname' - progdir=\"\$thisdir/$objdir\" -" + # Don't allow undefined symbols. + allow_undefined_flag="$no_undefined_flag" fi + fi - $ECHO "\ - - if test -f \"\$progdir/\$program\"; then" + if test "$mode" != relink; then + # Remove our outputs, but don't remove object files since they + # may have been created when compiling PIC objects. + removelist= + tempremovelist=`$echo "$output_objdir/*"` + for p in $tempremovelist; do + case $p in + *.$objext) + ;; + $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*) + if test "X$precious_files_regex" != "X"; then + if echo $p | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 + then + continue + fi + fi + removelist="$removelist $p" + ;; + *) ;; + esac + done + if test -n "$removelist"; then + $show "${rm}r $removelist" + $run ${rm}r $removelist + fi + fi - # Export our shlibpath_var if we have one. - if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then - $ECHO "\ - # Add our own library path to $shlibpath_var - $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" + # Now set the variables for building old libraries. + if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then + oldlibs="$oldlibs $output_objdir/$libname.$libext" - # Some systems cannot cope with colon-terminated $shlibpath_var - # The second colon is a workaround for a bug in BeOS R4 sed - $shlibpath_var=\`\$ECHO \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\` + # Transform .lo files to .o files. + oldobjs="$objs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP` + fi - export $shlibpath_var -" - fi + # Eliminate all temporary directories. + for path in $notinst_path; do + lib_search_path=`$echo "$lib_search_path " | ${SED} -e 's% $path % %g'` + deplibs=`$echo "$deplibs " | ${SED} -e 's% -L$path % %g'` + dependency_libs=`$echo "$dependency_libs " | ${SED} -e 's% -L$path % %g'` + done - # fixup the dll searchpath if we need to. - if test -n "$dllsearchpath"; then - $ECHO "\ - # Add the dll search path components to the executable PATH - PATH=$dllsearchpath:\$PATH -" + if test -n "$xrpath"; then + # If the user specified any rpath flags, then add them. + temp_xrpath= + for libdir in $xrpath; do + temp_xrpath="$temp_xrpath -R$libdir" + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" ;; + esac + done + if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then + dependency_libs="$temp_xrpath $dependency_libs" fi + fi - $ECHO "\ - if test \"\$libtool_execute_magic\" != \"$magic\"; then - # Run the actual program with our arguments. -" - case $host in - # Backslashes separate directories on plain windows - *-*-mingw | *-*-os2* | *-cegcc*) - $ECHO "\ - exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} -" - ;; - - *) - $ECHO "\ - exec \"\$progdir/\$program\" \${1+\"\$@\"} -" - ;; + # Make sure dlfiles contains only unique files that won't be dlpreopened + old_dlfiles="$dlfiles" + dlfiles= + for lib in $old_dlfiles; do + case " $dlprefiles $dlfiles " in + *" $lib "*) ;; + *) dlfiles="$dlfiles $lib" ;; esac - $ECHO "\ - \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 - exit 1 - fi - else - # The program doesn't exist. - \$ECHO \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2 - \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 - $ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 - exit 1 - fi -fi\ -" -} -# end: func_emit_wrapper_part2 + done + # Make sure dlprefiles contains only unique files + old_dlprefiles="$dlprefiles" + dlprefiles= + for lib in $old_dlprefiles; do + case "$dlprefiles " in + *" $lib "*) ;; + *) dlprefiles="$dlprefiles $lib" ;; + esac + done -# func_emit_wrapper [arg=no] -# -# Emit a libtool wrapper script on stdout. -# Don't directly open a file because we may want to -# incorporate the script contents within a cygwin/mingw -# wrapper executable. Must ONLY be called from within -# func_mode_link because it depends on a number of variables -# set therein. -# -# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR -# variable will take. If 'yes', then the emitted script -# will assume that the directory in which it is stored is -# the $objdir directory. This is a cygwin/mingw-specific -# behavior. -func_emit_wrapper () -{ - func_emit_wrapper_arg1=no - if test -n "$1" ; then - func_emit_wrapper_arg1=$1 + if test "$build_libtool_libs" = yes; then + if test -n "$rpath"; then + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos*) + # these systems don't actually have a c library (as such)! + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C library is in the System framework + deplibs="$deplibs -framework System" + ;; + *-*-netbsd*) + # Don't link with libc until the a.out ld.so is fixed. + ;; + *-*-openbsd* | *-*-freebsd*) + # Do not include libc due to us having libc/libc_r. + test "X$arg" = "X-lc" && continue + ;; + *) + # Add libc to deplibs on all other systems if necessary. + if test "$build_libtool_need_lc" = "yes"; then + deplibs="$deplibs -lc" + fi + ;; + esac fi - # split this up so that func_emit_cwrapperexe_src - # can call each part independently. - func_emit_wrapper_part1 "${func_emit_wrapper_arg1}" - func_emit_wrapper_part2 "${func_emit_wrapper_arg1}" -} - - -# func_to_host_path arg -# -# Convert paths to host format when used with build tools. -# Intended for use with "native" mingw (where libtool itself -# is running under the msys shell), or in the following cross- -# build environments: -# $build $host -# mingw (msys) mingw [e.g. native] -# cygwin mingw -# *nix + wine mingw -# where wine is equipped with the `winepath' executable. -# In the native mingw case, the (msys) shell automatically -# converts paths for any non-msys applications it launches, -# but that facility isn't available from inside the cwrapper. -# Similar accommodations are necessary for $host mingw and -# $build cygwin. Calling this function does no harm for other -# $host/$build combinations not listed above. -# -# ARG is the path (on $build) that should be converted to -# the proper representation for $host. The result is stored -# in $func_to_host_path_result. -func_to_host_path () -{ - func_to_host_path_result="$1" - if test -n "$1" ; then - case $host in - *mingw* ) - lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' - case $build in - *mingw* ) # actually, msys - # awkward: cmd appends spaces to result - lt_sed_strip_trailing_spaces="s/[ ]*\$//" - func_to_host_path_tmp1=`( cmd //c echo "$1" |\ - $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""` - func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\ - $SED -e "$lt_sed_naive_backslashify"` - ;; - *cygwin* ) - func_to_host_path_tmp1=`cygpath -w "$1"` - func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\ - $SED -e "$lt_sed_naive_backslashify"` - ;; - * ) - # Unfortunately, winepath does not exit with a non-zero - # error code, so we are forced to check the contents of - # stdout. On the other hand, if the command is not - # found, the shell will set an exit code of 127 and print - # *an error message* to stdout. So we must check for both - # error code of zero AND non-empty stdout, which explains - # the odd construction: - func_to_host_path_tmp1=`winepath -w "$1" 2>/dev/null` - if test "$?" -eq 0 && test -n "${func_to_host_path_tmp1}"; then - func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\ - $SED -e "$lt_sed_naive_backslashify"` - else - # Allow warning below. - func_to_host_path_result="" - fi - ;; - esac - if test -z "$func_to_host_path_result" ; then - func_error "Could not determine host path corresponding to" - func_error " '$1'" - func_error "Continuing, but uninstalled executables may not work." - # Fallback: - func_to_host_path_result="$1" - fi - ;; - esac - fi -} -# end: func_to_host_path - -# func_to_host_pathlist arg -# -# Convert pathlists to host format when used with build tools. -# See func_to_host_path(), above. This function supports the -# following $build/$host combinations (but does no harm for -# combinations not listed here): -# $build $host -# mingw (msys) mingw [e.g. native] -# cygwin mingw -# *nix + wine mingw -# -# Path separators are also converted from $build format to -# $host format. If ARG begins or ends with a path separator -# character, it is preserved (but converted to $host format) -# on output. -# -# ARG is a pathlist (on $build) that should be converted to -# the proper representation on $host. The result is stored -# in $func_to_host_pathlist_result. -func_to_host_pathlist () -{ - func_to_host_pathlist_result="$1" - if test -n "$1" ; then - case $host in - *mingw* ) - lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' - # Remove leading and trailing path separator characters from - # ARG. msys behavior is inconsistent here, cygpath turns them - # into '.;' and ';.', and winepath ignores them completely. - func_to_host_pathlist_tmp2="$1" - # Once set for this call, this variable should not be - # reassigned. It is used in tha fallback case. - func_to_host_pathlist_tmp1=`echo "$func_to_host_pathlist_tmp2" |\ - $SED -e 's|^:*||' -e 's|:*$||'` - case $build in - *mingw* ) # Actually, msys. - # Awkward: cmd appends spaces to result. - lt_sed_strip_trailing_spaces="s/[ ]*\$//" - func_to_host_pathlist_tmp2=`( cmd //c echo "$func_to_host_pathlist_tmp1" |\ - $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""` - func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\ - $SED -e "$lt_sed_naive_backslashify"` - ;; - *cygwin* ) - func_to_host_pathlist_tmp2=`cygpath -w -p "$func_to_host_pathlist_tmp1"` - func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\ - $SED -e "$lt_sed_naive_backslashify"` - ;; - * ) - # unfortunately, winepath doesn't convert pathlists - func_to_host_pathlist_result="" - func_to_host_pathlist_oldIFS=$IFS - IFS=: - for func_to_host_pathlist_f in $func_to_host_pathlist_tmp1 ; do - IFS=$func_to_host_pathlist_oldIFS - if test -n "$func_to_host_pathlist_f" ; then - func_to_host_path "$func_to_host_pathlist_f" - if test -n "$func_to_host_path_result" ; then - if test -z "$func_to_host_pathlist_result" ; then - func_to_host_pathlist_result="$func_to_host_path_result" - else - func_to_host_pathlist_result="$func_to_host_pathlist_result;$func_to_host_path_result" - fi - fi - fi - IFS=: - done - IFS=$func_to_host_pathlist_oldIFS - ;; - esac - if test -z "$func_to_host_pathlist_result" ; then - func_error "Could not determine the host path(s) corresponding to" - func_error " '$1'" - func_error "Continuing, but uninstalled executables may not work." - # Fallback. This may break if $1 contains DOS-style drive - # specifications. The fix is not to complicate the expression - # below, but for the user to provide a working wine installation - # with winepath so that path translation in the cross-to-mingw - # case works properly. - lt_replace_pathsep_nix_to_dos="s|:|;|g" - func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp1" |\ - $SED -e "$lt_replace_pathsep_nix_to_dos"` - fi - # Now, add the leading and trailing path separators back - case "$1" in - :* ) func_to_host_pathlist_result=";$func_to_host_pathlist_result" - ;; - esac - case "$1" in - *: ) func_to_host_pathlist_result="$func_to_host_pathlist_result;" - ;; - esac - ;; - esac - fi -} -# end: func_to_host_pathlist - -# func_emit_cwrapperexe_src -# emit the source code for a wrapper executable on stdout -# Must ONLY be called from within func_mode_link because -# it depends on a number of variable set therein. -func_emit_cwrapperexe_src () -{ - cat < -#include -#ifdef _MSC_VER -# include -# include -# include -# define setmode _setmode -#else -# include -# include -# ifdef __CYGWIN__ -# include -# define HAVE_SETENV -# ifdef __STRICT_ANSI__ -char *realpath (const char *, char *); -int putenv (char *); -int setenv (const char *, const char *, int); -# endif -# endif -#endif -#include -#include -#include -#include -#include -#include -#include -#include - -#if defined(PATH_MAX) -# define LT_PATHMAX PATH_MAX -#elif defined(MAXPATHLEN) -# define LT_PATHMAX MAXPATHLEN -#else -# define LT_PATHMAX 1024 -#endif - -#ifndef S_IXOTH -# define S_IXOTH 0 -#endif -#ifndef S_IXGRP -# define S_IXGRP 0 -#endif - -#ifdef _MSC_VER -# define S_IXUSR _S_IEXEC -# define stat _stat -# ifndef _INTPTR_T_DEFINED -# define intptr_t int -# endif -#endif - -#ifndef DIR_SEPARATOR -# define DIR_SEPARATOR '/' -# define PATH_SEPARATOR ':' -#endif - -#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \ - defined (__OS2__) -# define HAVE_DOS_BASED_FILE_SYSTEM -# define FOPEN_WB "wb" -# ifndef DIR_SEPARATOR_2 -# define DIR_SEPARATOR_2 '\\' -# endif -# ifndef PATH_SEPARATOR_2 -# define PATH_SEPARATOR_2 ';' -# endif -#endif - -#ifndef DIR_SEPARATOR_2 -# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) -#else /* DIR_SEPARATOR_2 */ -# define IS_DIR_SEPARATOR(ch) \ - (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) -#endif /* DIR_SEPARATOR_2 */ - -#ifndef PATH_SEPARATOR_2 -# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) -#else /* PATH_SEPARATOR_2 */ -# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) -#endif /* PATH_SEPARATOR_2 */ - -#ifdef __CYGWIN__ -# define FOPEN_WB "wb" -#endif - -#ifndef FOPEN_WB -# define FOPEN_WB "w" -#endif -#ifndef _O_BINARY -# define _O_BINARY 0 -#endif - -#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) -#define XFREE(stale) do { \ - if (stale) { free ((void *) stale); stale = 0; } \ -} while (0) - -#undef LTWRAPPER_DEBUGPRINTF -#if defined DEBUGWRAPPER -# define LTWRAPPER_DEBUGPRINTF(args) ltwrapper_debugprintf args -static void -ltwrapper_debugprintf (const char *fmt, ...) -{ - va_list args; - va_start (args, fmt); - (void) vfprintf (stderr, fmt, args); - va_end (args); -} -#else -# define LTWRAPPER_DEBUGPRINTF(args) -#endif - -const char *program_name = NULL; - -void *xmalloc (size_t num); -char *xstrdup (const char *string); -const char *base_name (const char *name); -char *find_executable (const char *wrapper); -char *chase_symlinks (const char *pathspec); -int make_executable (const char *path); -int check_executable (const char *path); -char *strendzap (char *str, const char *pat); -void lt_fatal (const char *message, ...); -void lt_setenv (const char *name, const char *value); -char *lt_extend_str (const char *orig_value, const char *add, int to_end); -void lt_opt_process_env_set (const char *arg); -void lt_opt_process_env_prepend (const char *arg); -void lt_opt_process_env_append (const char *arg); -int lt_split_name_value (const char *arg, char** name, char** value); -void lt_update_exe_path (const char *name, const char *value); -void lt_update_lib_path (const char *name, const char *value); - -static const char *script_text_part1 = -EOF - - func_emit_wrapper_part1 yes | - $SED -e 's/\([\\"]\)/\\\1/g' \ - -e 's/^/ "/' -e 's/$/\\n"/' - echo ";" - cat < conftest.c </dev/null` + for potent_lib in $potential_libs; do + # Follow soft links. + if ls -lLd "$potent_lib" 2>/dev/null \ + | grep " -> " >/dev/null; then + continue + fi + # The statement above tries to avoid entering an + # endless loop below, in case of cyclic links. + # We might still enter an endless loop, since a link + # loop can be closed while we follow links, + # but so what? + potlib="$potent_lib" + while test -h "$potlib" 2>/dev/null; do + potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'` + case $potliblink in + [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";; + *) potlib=`$echo "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";; + esac + done + if eval $file_magic_cmd \"\$potlib\" 2>/dev/null \ + | ${SED} 10q \ + | $EGREP "$file_magic_regex" > /dev/null; then + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + break 2 + fi + done + done + fi + if test -n "$a_deplib" ; then + droppeddeps=yes + $echo + $echo "*** Warning: linker path does not have real file for library $a_deplib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have" + $echo "*** because I did check the linker path looking for a file starting" + if test -z "$potlib" ; then + $echo "*** with $libname but no candidates were found. (...for file magic test)" + else + $echo "*** with $libname and none of the candidates passed a file format test" + $echo "*** using a file magic. Last file checked: $potlib" + fi + fi else - cat <<"EOF" -const char * LIB_PATH_VALUE = ""; -EOF + # Add a -L argument. + newdeplibs="$newdeplibs $a_deplib" fi - - if test -n "$dllsearchpath"; then - func_to_host_pathlist "$dllsearchpath:" - cat </dev/null` + for potent_lib in $potential_libs; do + potlib="$potent_lib" # see symlink-check above in file_magic test + if eval $echo \"$potent_lib\" 2>/dev/null \ + | ${SED} 10q \ + | $EGREP "$match_pattern_regex" > /dev/null; then + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + break 2 + fi + done + done + fi + if test -n "$a_deplib" ; then + droppeddeps=yes + $echo + $echo "*** Warning: linker path does not have real file for library $a_deplib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have" + $echo "*** because I did check the linker path looking for a file starting" + if test -z "$potlib" ; then + $echo "*** with $libname but no candidates were found. (...for regex pattern test)" + else + $echo "*** with $libname and none of the candidates passed a file format test" + $echo "*** using a regex pattern. Last file checked: $potlib" + fi + fi else - cat <<"EOF" -const char * EXE_PATH_VARNAME = ""; -const char * EXE_PATH_VALUE = ""; -EOF + # Add a -L argument. + newdeplibs="$newdeplibs $a_deplib" fi - - if test "$fast_install" = yes; then - cat </dev/null; then + $echo + if test "X$deplibs_check_method" = "Xnone"; then + $echo "*** Warning: inter-library dependencies are not supported in this platform." else - cat <"))); - for (i = 0; i < newargc; i++) - { - LTWRAPPER_DEBUGPRINTF (("(main) newargz[%d] : %s\n", i, (newargz[i] ? newargz[i] : ""))); - } + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then + $show "generating symbol list for \`$libname.la'" + export_symbols="$output_objdir/$libname.exp" + $run $rm $export_symbols + cmds=$export_symbols_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + if len=`expr "X$cmd" : ".*"` && + test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then + $show "$cmd" + $run eval "$cmd" || exit $? + skipped_export=false + else + # The command line is too long to execute in one step. + $show "using reloadable object file for export list..." + skipped_export=: + fi + done + IFS="$save_ifs" + if test -n "$export_symbols_regex"; then + $show "$EGREP -e \"$export_symbols_regex\" \"$export_symbols\" > \"${export_symbols}T\"" + $run eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' + $show "$mv \"${export_symbols}T\" \"$export_symbols\"" + $run eval '$mv "${export_symbols}T" "$export_symbols"' + fi + fi + fi -EOF + if test -n "$export_symbols" && test -n "$include_expsyms"; then + $run eval '$echo "X$include_expsyms" | $SP2NL >> "$export_symbols"' + fi - case $host_os in - mingw*) - cat <<"EOF" - /* execv doesn't actually work on mingw as expected on unix */ - rval = _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz); - if (rval == -1) - { - /* failed to start process */ - LTWRAPPER_DEBUGPRINTF (("(main) failed to launch target \"%s\": errno = %d\n", lt_argv_zero, errno)); - return 127; - } - return rval; -EOF - ;; - *) - cat <<"EOF" - execv (lt_argv_zero, newargz); - return rval; /* =127, but avoids unused variable warning */ -EOF - ;; - esac + tmp_deplibs= + for test_deplib in $deplibs; do + case " $convenience " in + *" $test_deplib "*) ;; + *) + tmp_deplibs="$tmp_deplibs $test_deplib" + ;; + esac + done + deplibs="$tmp_deplibs" - cat <<"EOF" -} + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + else + gentop="$output_objdir/${outputname}x" + $show "${rm}r $gentop" + $run ${rm}r "$gentop" + $show "$mkdir $gentop" + $run $mkdir "$gentop" + status=$? + if test "$status" -ne 0 && test ! -d "$gentop"; then + exit $status + fi + generated="$generated $gentop" -void * -xmalloc (size_t num) -{ - void *p = (void *) malloc (num); - if (!p) - lt_fatal ("Memory exhausted"); + for xlib in $convenience; do + # Extract the objects. + case $xlib in + [\\/]* | [A-Za-z]:[\\/]*) xabs="$xlib" ;; + *) xabs=`pwd`"/$xlib" ;; + esac + xlib=`$echo "X$xlib" | $Xsed -e 's%^.*/%%'` + xdir="$gentop/$xlib" - return p; -} + $show "${rm}r $xdir" + $run ${rm}r "$xdir" + $show "$mkdir $xdir" + $run $mkdir "$xdir" + status=$? + if test "$status" -ne 0 && test ! -d "$xdir"; then + exit $status + fi + # We will extract separately just the conflicting names and we will no + # longer touch any unique names. It is faster to leave these extract + # automatically by $AR in one run. + $show "(cd $xdir && $AR x $xabs)" + $run eval "(cd \$xdir && $AR x \$xabs)" || exit $? + if ($AR t "$xabs" | sort | sort -uc >/dev/null 2>&1); then + : + else + $echo "$modename: warning: object name conflicts; renaming object files" 1>&2 + $echo "$modename: warning: to ensure that they will not overwrite" 1>&2 + $AR t "$xabs" | sort | uniq -cd | while read -r count name + do + i=1 + while test "$i" -le "$count" + do + # Put our $i before any first dot (extension) + # Never overwrite any file + name_to="$name" + while test "X$name_to" = "X$name" || test -f "$xdir/$name_to" + do + name_to=`$echo "X$name_to" | $Xsed -e "s/\([^.]*\)/\1-$i/"` + done + $show "(cd $xdir && $AR xN $i $xabs '$name' && $mv '$name' '$name_to')" + $run eval "(cd \$xdir && $AR xN $i \$xabs '$name' && $mv '$name' '$name_to')" || exit $? + i=`expr $i + 1` + done + done + fi -char * -xstrdup (const char *string) -{ - return string ? strcpy ((char *) xmalloc (strlen (string) + 1), - string) : NULL; -} + libobjs="$libobjs "`find $xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP` + done + fi + fi -const char * -base_name (const char *name) -{ - const char *base; + if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then + eval flag=\"$thread_safe_flag_spec\" + linker_flags="$linker_flags $flag" + fi -#if defined (HAVE_DOS_BASED_FILE_SYSTEM) - /* Skip over the disk name in MSDOS pathnames. */ - if (isalpha ((unsigned char) name[0]) && name[1] == ':') - name += 2; -#endif + # Make a backup of the uninstalled library when relinking + if test "$mode" = relink; then + $run eval '(cd $output_objdir && $rm ${realname}U && $mv $realname ${realname}U)' || exit $? + fi - for (base = name; *name; name++) - if (IS_DIR_SEPARATOR (*name)) - base = name + 1; - return base; -} + # Do each of the archive commands. + if test "$module" = yes && test -n "$module_cmds" ; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + eval test_cmds=\"$module_expsym_cmds\" + cmds=$module_expsym_cmds + else + eval test_cmds=\"$module_cmds\" + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + eval test_cmds=\"$archive_expsym_cmds\" + cmds=$archive_expsym_cmds + else + eval test_cmds=\"$archive_cmds\" + cmds=$archive_cmds + fi + fi -int -check_executable (const char *path) -{ - struct stat st; + if test "X$skipped_export" != "X:" && len=`expr "X$test_cmds" : ".*"` && + test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then + : + else + # The command line is too long to link in one step, link piecewise. + $echo "creating reloadable object files..." - LTWRAPPER_DEBUGPRINTF (("(check_executable) : %s\n", - path ? (*path ? path : "EMPTY!") : "NULL!")); - if ((!path) || (!*path)) - return 0; - - if ((stat (path, &st) >= 0) - && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) - return 1; - else - return 0; -} + # Save the value of $output and $libobjs because we want to + # use them later. If we have whole_archive_flag_spec, we + # want to use save_libobjs as it was before + # whole_archive_flag_spec was expanded, because we can't + # assume the linker understands whole_archive_flag_spec. + # This may have to be revisited, in case too many + # convenience libraries get linked in and end up exceeding + # the spec. + if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + fi + save_output=$output -int -make_executable (const char *path) -{ - int rval = 0; - struct stat st; + # Clear the reloadable object creation command queue and + # initialize k to one. + test_cmds= + concat_cmds= + objlist= + delfiles= + last_robj= + k=1 + output=$output_objdir/$save_output-${k}.$objext + # Loop over the list of objects to be linked. + for obj in $save_libobjs + do + eval test_cmds=\"$reload_cmds $objlist $last_robj\" + if test "X$objlist" = X || + { len=`expr "X$test_cmds" : ".*"` && + test "$len" -le "$max_cmd_len"; }; then + objlist="$objlist $obj" + else + # The command $test_cmds is almost too long, add a + # command to the queue. + if test "$k" -eq 1 ; then + # The first file doesn't have a previous command to add. + eval concat_cmds=\"$reload_cmds $objlist $last_robj\" + else + # All subsequent reloadable object files will link in + # the last one created. + eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj\" + fi + last_robj=$output_objdir/$save_output-${k}.$objext + k=`expr $k + 1` + output=$output_objdir/$save_output-${k}.$objext + objlist=$obj + len=1 + fi + done + # Handle the remaining objects by creating one last + # reloadable object file. All subsequent reloadable object + # files will link in the last one created. + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\" - LTWRAPPER_DEBUGPRINTF (("(make_executable) : %s\n", - path ? (*path ? path : "EMPTY!") : "NULL!")); - if ((!path) || (!*path)) - return 0; - - if (stat (path, &st) >= 0) - { - rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); - } - return rval; -} + if ${skipped_export-false}; then + $show "generating symbol list for \`$libname.la'" + export_symbols="$output_objdir/$libname.exp" + $run $rm $export_symbols + libobjs=$output + # Append the command to create the export file. + eval concat_cmds=\"\$concat_cmds~$export_symbols_cmds\" + fi + + # Set up a command to remove the reloadale object files + # after they are used. + i=0 + while test "$i" -lt "$k" + do + i=`expr $i + 1` + delfiles="$delfiles $output_objdir/$save_output-${i}.$objext" + done -/* Searches for the full path of the wrapper. Returns - newly allocated full path name if found, NULL otherwise - Does not chase symlinks, even on platforms that support them. -*/ -char * -find_executable (const char *wrapper) -{ - int has_slash = 0; - const char *p; - const char *p_next; - /* static buffer for getcwd */ - char tmp[LT_PATHMAX + 1]; - int tmp_len; - char *concat_name; + $echo "creating a temporary reloadable object file: $output" - LTWRAPPER_DEBUGPRINTF (("(find_executable) : %s\n", - wrapper ? (*wrapper ? wrapper : "EMPTY!") : "NULL!")); + # Loop through the commands generated above and execute them. + save_ifs="$IFS"; IFS='~' + for cmd in $concat_cmds; do + IFS="$save_ifs" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" - if ((wrapper == NULL) || (*wrapper == '\0')) - return NULL; + libobjs=$output + # Restore the value of output. + output=$save_output - /* Absolute path? */ -#if defined (HAVE_DOS_BASED_FILE_SYSTEM) - if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') - { - concat_name = xstrdup (wrapper); - if (check_executable (concat_name)) - return concat_name; - XFREE (concat_name); - } - else - { -#endif - if (IS_DIR_SEPARATOR (wrapper[0])) - { - concat_name = xstrdup (wrapper); - if (check_executable (concat_name)) - return concat_name; - XFREE (concat_name); - } -#if defined (HAVE_DOS_BASED_FILE_SYSTEM) - } -#endif + if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + fi + # Expand the library linking commands again to reset the + # value of $libobjs for piecewise linking. - for (p = wrapper; *p; p++) - if (*p == '/') - { - has_slash = 1; - break; - } - if (!has_slash) - { - /* no slashes; search PATH */ - const char *path = getenv ("PATH"); - if (path != NULL) - { - for (p = path; *p; p = p_next) - { - const char *q; - size_t p_len; - for (q = p; *q; q++) - if (IS_PATH_SEPARATOR (*q)) - break; - p_len = q - p; - p_next = (*q == '\0' ? q : q + 1); - if (p_len == 0) - { - /* empty path: current directory */ - if (getcwd (tmp, LT_PATHMAX) == NULL) - lt_fatal ("getcwd failed"); - tmp_len = strlen (tmp); - concat_name = - XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); - memcpy (concat_name, tmp, tmp_len); - concat_name[tmp_len] = '/'; - strcpy (concat_name + tmp_len + 1, wrapper); - } - else - { - concat_name = - XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); - memcpy (concat_name, p, p_len); - concat_name[p_len] = '/'; - strcpy (concat_name + p_len + 1, wrapper); - } - if (check_executable (concat_name)) - return concat_name; - XFREE (concat_name); - } - } - /* not found in PATH; assume curdir */ - } - /* Relative path | not found in path: prepend cwd */ - if (getcwd (tmp, LT_PATHMAX) == NULL) - lt_fatal ("getcwd failed"); - tmp_len = strlen (tmp); - concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); - memcpy (concat_name, tmp, tmp_len); - concat_name[tmp_len] = '/'; - strcpy (concat_name + tmp_len + 1, wrapper); - - if (check_executable (concat_name)) - return concat_name; - XFREE (concat_name); - return NULL; -} + # Do each of the archive commands. + if test "$module" = yes && test -n "$module_cmds" ; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + cmds=$module_expsym_cmds + else + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + cmds=$archive_expsym_cmds + else + cmds=$archive_cmds + fi + fi -char * -chase_symlinks (const char *pathspec) -{ -#ifndef S_ISLNK - return xstrdup (pathspec); -#else - char buf[LT_PATHMAX]; - struct stat s; - char *tmp_pathspec = xstrdup (pathspec); - char *p; - int has_symlinks = 0; - while (strlen (tmp_pathspec) && !has_symlinks) - { - LTWRAPPER_DEBUGPRINTF (("checking path component for symlinks: %s\n", - tmp_pathspec)); - if (lstat (tmp_pathspec, &s) == 0) - { - if (S_ISLNK (s.st_mode) != 0) - { - has_symlinks = 1; - break; - } - - /* search backwards for last DIR_SEPARATOR */ - p = tmp_pathspec + strlen (tmp_pathspec) - 1; - while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) - p--; - if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) - { - /* no more DIR_SEPARATORS left */ - break; - } - *p = '\0'; - } - else - { - char *errstr = strerror (errno); - lt_fatal ("Error accessing file %s (%s)", tmp_pathspec, errstr); - } - } - XFREE (tmp_pathspec); - - if (!has_symlinks) - { - return xstrdup (pathspec); - } - - tmp_pathspec = realpath (pathspec, buf); - if (tmp_pathspec == 0) - { - lt_fatal ("Could not follow symlinks for %s", pathspec); - } - return xstrdup (tmp_pathspec); -#endif -} + # Append the command to remove the reloadable object files + # to the just-reset $cmds. + eval cmds=\"\$cmds~\$rm $delfiles\" + fi + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" -char * -strendzap (char *str, const char *pat) -{ - size_t len, patlen; + # Restore the uninstalled library and exit + if test "$mode" = relink; then + $run eval '(cd $output_objdir && $rm ${realname}T && $mv $realname ${realname}T && $mv "$realname"U $realname)' || exit $? + exit $EXIT_SUCCESS + fi - assert (str != NULL); - assert (pat != NULL); + # Create links to the real library. + for linkname in $linknames; do + if test "$realname" != "$linkname"; then + $show "(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)" + $run eval '(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)' || exit $? + fi + done - len = strlen (str); - patlen = strlen (pat); + # If -module or -export-dynamic was specified, set the dlname. + if test "$module" = yes || test "$export_dynamic" = yes; then + # On all known operating systems, these are identical. + dlname="$soname" + fi + fi + ;; - if (patlen <= len) - { - str += len - patlen; - if (strcmp (str, pat) == 0) - *str = '\0'; - } - return str; -} + obj) + if test -n "$deplibs"; then + $echo "$modename: warning: \`-l' and \`-L' are ignored for objects" 1>&2 + fi -static void -lt_error_core (int exit_status, const char *mode, - const char *message, va_list ap) -{ - fprintf (stderr, "%s: %s: ", program_name, mode); - vfprintf (stderr, message, ap); - fprintf (stderr, ".\n"); + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + $echo "$modename: warning: \`-dlopen' is ignored for objects" 1>&2 + fi - if (exit_status >= 0) - exit (exit_status); -} + if test -n "$rpath"; then + $echo "$modename: warning: \`-rpath' is ignored for objects" 1>&2 + fi -void -lt_fatal (const char *message, ...) -{ - va_list ap; - va_start (ap, message); - lt_error_core (EXIT_FAILURE, "FATAL", message, ap); - va_end (ap); -} + if test -n "$xrpath"; then + $echo "$modename: warning: \`-R' is ignored for objects" 1>&2 + fi -void -lt_setenv (const char *name, const char *value) -{ - LTWRAPPER_DEBUGPRINTF (("(lt_setenv) setting '%s' to '%s'\n", - (name ? name : ""), - (value ? value : ""))); - { -#ifdef HAVE_SETENV - /* always make a copy, for consistency with !HAVE_SETENV */ - char *str = xstrdup (value); - setenv (name, str, 1); -#else - int len = strlen (name) + 1 + strlen (value) + 1; - char *str = XMALLOC (char, len); - sprintf (str, "%s=%s", name, value); - if (putenv (str) != EXIT_SUCCESS) - { - XFREE (str); - } -#endif - } -} + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info' is ignored for objects" 1>&2 + fi -char * -lt_extend_str (const char *orig_value, const char *add, int to_end) -{ - char *new_value; - if (orig_value && *orig_value) - { - int orig_value_len = strlen (orig_value); - int add_len = strlen (add); - new_value = XMALLOC (char, add_len + orig_value_len + 1); - if (to_end) - { - strcpy (new_value, orig_value); - strcpy (new_value + orig_value_len, add); - } - else - { - strcpy (new_value, add); - strcpy (new_value + add_len, orig_value); - } - } - else - { - new_value = xstrdup (add); - } - return new_value; -} + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for objects" 1>&2 + fi -int -lt_split_name_value (const char *arg, char** name, char** value) -{ - const char *p; - int len; - if (!arg || !*arg) - return 1; + case $output in + *.lo) + if test -n "$objs$old_deplibs"; then + $echo "$modename: cannot build library object \`$output' from non-libtool objects" 1>&2 + exit $EXIT_FAILURE + fi + libobj="$output" + obj=`$echo "X$output" | $Xsed -e "$lo2o"` + ;; + *) + libobj= + obj="$output" + ;; + esac - p = strchr (arg, (int)'='); + # Delete the old objects. + $run $rm $obj $libobj - if (!p) - return 1; + # Objects from convenience libraries. This assumes + # single-version convenience libraries. Whenever we create + # different ones for PIC/non-PIC, this we'll have to duplicate + # the extraction. + reload_conv_objs= + gentop= + # reload_cmds runs $LD directly, so let us get rid of + # -Wl from whole_archive_flag_spec + wl= - *value = xstrdup (++p); + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec"; then + eval reload_conv_objs=\"\$reload_objs $whole_archive_flag_spec\" + else + gentop="$output_objdir/${obj}x" + $show "${rm}r $gentop" + $run ${rm}r "$gentop" + $show "$mkdir $gentop" + $run $mkdir "$gentop" + status=$? + if test "$status" -ne 0 && test ! -d "$gentop"; then + exit $status + fi + generated="$generated $gentop" - len = strlen (arg) - strlen (*value); - *name = XMALLOC (char, len); - strncpy (*name, arg, len-1); - (*name)[len - 1] = '\0'; + for xlib in $convenience; do + # Extract the objects. + case $xlib in + [\\/]* | [A-Za-z]:[\\/]*) xabs="$xlib" ;; + *) xabs=`pwd`"/$xlib" ;; + esac + xlib=`$echo "X$xlib" | $Xsed -e 's%^.*/%%'` + xdir="$gentop/$xlib" - return 0; -} + $show "${rm}r $xdir" + $run ${rm}r "$xdir" + $show "$mkdir $xdir" + $run $mkdir "$xdir" + status=$? + if test "$status" -ne 0 && test ! -d "$xdir"; then + exit $status + fi + # We will extract separately just the conflicting names and we will no + # longer touch any unique names. It is faster to leave these extract + # automatically by $AR in one run. + $show "(cd $xdir && $AR x $xabs)" + $run eval "(cd \$xdir && $AR x \$xabs)" || exit $? + if ($AR t "$xabs" | sort | sort -uc >/dev/null 2>&1); then + : + else + $echo "$modename: warning: object name conflicts; renaming object files" 1>&2 + $echo "$modename: warning: to ensure that they will not overwrite" 1>&2 + $AR t "$xabs" | sort | uniq -cd | while read -r count name + do + i=1 + while test "$i" -le "$count" + do + # Put our $i before any first dot (extension) + # Never overwrite any file + name_to="$name" + while test "X$name_to" = "X$name" || test -f "$xdir/$name_to" + do + name_to=`$echo "X$name_to" | $Xsed -e "s/\([^.]*\)/\1-$i/"` + done + $show "(cd $xdir && $AR xN $i $xabs '$name' && $mv '$name' '$name_to')" + $run eval "(cd \$xdir && $AR xN $i \$xabs '$name' && $mv '$name' '$name_to')" || exit $? + i=`expr $i + 1` + done + done + fi -void -lt_opt_process_env_set (const char *arg) -{ - char *name = NULL; - char *value = NULL; + reload_conv_objs="$reload_objs "`find $xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP` + done + fi + fi - if (lt_split_name_value (arg, &name, &value) != 0) - { - XFREE (name); - XFREE (value); - lt_fatal ("bad argument for %s: '%s'", env_set_opt, arg); - } - - lt_setenv (name, value); - XFREE (name); - XFREE (value); -} + # Create the old-style object. + reload_objs="$objs$old_deplibs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test -void -lt_opt_process_env_prepend (const char *arg) -{ - char *name = NULL; - char *value = NULL; - char *new_value = NULL; - - if (lt_split_name_value (arg, &name, &value) != 0) - { - XFREE (name); - XFREE (value); - lt_fatal ("bad argument for %s: '%s'", env_prepend_opt, arg); - } - - new_value = lt_extend_str (getenv (name), value, 0); - lt_setenv (name, new_value); - XFREE (new_value); - XFREE (name); - XFREE (value); -} + output="$obj" + cmds=$reload_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" -void -lt_opt_process_env_append (const char *arg) -{ - char *name = NULL; - char *value = NULL; - char *new_value = NULL; - - if (lt_split_name_value (arg, &name, &value) != 0) - { - XFREE (name); - XFREE (value); - lt_fatal ("bad argument for %s: '%s'", env_append_opt, arg); - } - - new_value = lt_extend_str (getenv (name), value, 1); - lt_setenv (name, new_value); - XFREE (new_value); - XFREE (name); - XFREE (value); -} + # Exit if we aren't doing a library object file. + if test -z "$libobj"; then + if test -n "$gentop"; then + $show "${rm}r $gentop" + $run ${rm}r $gentop + fi -void -lt_update_exe_path (const char *name, const char *value) -{ - LTWRAPPER_DEBUGPRINTF (("(lt_update_exe_path) modifying '%s' by prepending '%s'\n", - (name ? name : ""), - (value ? value : ""))); - - if (name && *name && value && *value) - { - char *new_value = lt_extend_str (getenv (name), value, 0); - /* some systems can't cope with a ':'-terminated path #' */ - int len = strlen (new_value); - while (((len = strlen (new_value)) > 0) && IS_PATH_SEPARATOR (new_value[len-1])) - { - new_value[len-1] = '\0'; - } - lt_setenv (name, new_value); - XFREE (new_value); - } -} + exit $EXIT_SUCCESS + fi -void -lt_update_lib_path (const char *name, const char *value) -{ - LTWRAPPER_DEBUGPRINTF (("(lt_update_lib_path) modifying '%s' by prepending '%s'\n", - (name ? name : ""), - (value ? value : ""))); - - if (name && *name && value && *value) - { - char *new_value = lt_extend_str (getenv (name), value, 0); - lt_setenv (name, new_value); - XFREE (new_value); - } -} + if test "$build_libtool_libs" != yes; then + if test -n "$gentop"; then + $show "${rm}r $gentop" + $run ${rm}r $gentop + fi + # Create an invalid libtool object if no PIC, so that we don't + # accidentally link it into a program. + # $show "echo timestamp > $libobj" + # $run eval "echo timestamp > $libobj" || exit $? + exit $EXIT_SUCCESS + fi -EOF -} -# end: func_emit_cwrapperexe_src + if test -n "$pic_flag" || test "$pic_mode" != default; then + # Only do commands if we really have different PIC objects. + reload_objs="$libobjs $reload_conv_objs" + output="$libobj" + cmds=$reload_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + fi -# func_mode_link arg... -func_mode_link () -{ - $opt_debug - case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) - # It is impossible to link a dll without this setting, and - # we shouldn't force the makefile maintainer to figure out - # which system we are compiling for in order to pass an extra - # flag for every libtool invocation. - # allow_undefined=no + if test -n "$gentop"; then + $show "${rm}r $gentop" + $run ${rm}r $gentop + fi - # FIXME: Unfortunately, there are problems with the above when trying - # to make a dll which has undefined symbols, in which case not - # even a static library is built. For now, we need to specify - # -no-undefined on the libtool link line when we can be certain - # that all symbols are satisfied, otherwise we get a static library. - allow_undefined=yes - ;; - *) - allow_undefined=yes + exit $EXIT_SUCCESS ;; - esac - libtool_args=$nonopt - base_compile="$nonopt $@" - compile_command=$nonopt - finalize_command=$nonopt - compile_rpath= - finalize_rpath= - compile_shlibpath= - finalize_shlibpath= - convenience= - old_convenience= - deplibs= - old_deplibs= - compiler_flags= - linker_flags= - dllsearchpath= - lib_search_path=`pwd` - inst_prefix_dir= - new_inherited_linker_flags= + prog) + case $host in + *cygwin*) output=`$echo $output | ${SED} -e 's,.exe$,,;s,$,.exe,'` ;; + esac + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info' is ignored for programs" 1>&2 + fi - avoid_version=no - dlfiles= - dlprefiles= - dlself=no - export_dynamic=no - export_symbols= - export_symbols_regex= - generated= - libobjs= - ltlibs= - module=no - no_install=no - objs= - non_pic_objects= - precious_files_regex= - prefer_static_libs=no - preload=no - prev= - prevarg= - release= - rpath= - xrpath= - perm_rpath= - temp_rpath= - thread_safe=no - vinfo= - vinfo_number=no - weak_libs= - single_module="${wl}-single_module" - func_infer_tag $base_compile + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for programs" 1>&2 + fi - # We need to know -static, to get the right output filenames. - for arg - do - case $arg in - -shared) - test "$build_libtool_libs" != yes && \ - func_fatal_configuration "can not build a shared library" - build_old_libs=no - break - ;; - -all-static | -static | -static-libtool-libs) - case $arg in - -all-static) - if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then - func_warning "complete static linking is impossible in this configuration" - fi - if test -n "$link_static_flag"; then - dlopen_self=$dlopen_self_static - fi - prefer_static_libs=yes - ;; - -static) - if test -z "$pic_flag" && test -n "$link_static_flag"; then - dlopen_self=$dlopen_self_static - fi - prefer_static_libs=built - ;; - -static-libtool-libs) - if test -z "$pic_flag" && test -n "$link_static_flag"; then - dlopen_self=$dlopen_self_static - fi - prefer_static_libs=yes - ;; - esac - build_libtool_libs=no - build_old_libs=yes - break + if test "$preload" = yes; then + if test "$dlopen_support" = unknown && test "$dlopen_self" = unknown && + test "$dlopen_self_static" = unknown; then + $echo "$modename: warning: \`AC_LIBTOOL_DLOPEN' not used. Assuming no dlopen support." + fi + fi + + case $host in + *-*-rhapsody* | *-*-darwin1.[012]) + # On Rhapsody replace the C library is the System framework + compile_deplibs=`$echo "X $compile_deplibs" | $Xsed -e 's/ -lc / -framework System /'` + finalize_deplibs=`$echo "X $finalize_deplibs" | $Xsed -e 's/ -lc / -framework System /'` ;; esac - done - # See if our shared archives depend on static archives. - test -n "$old_archive_from_new_cmds" && build_old_libs=yes + case $host in + *darwin*) + # Don't allow lazy linking, it breaks C++ global constructors + if test "$tagname" = CXX ; then + compile_command="$compile_command ${wl}-bind_at_load" + finalize_command="$finalize_command ${wl}-bind_at_load" + fi + ;; + esac - # Go through the arguments, transforming them on the way. - while test "$#" -gt 0; do - arg="$1" - shift - func_quote_for_eval "$arg" - qarg=$func_quote_for_eval_unquoted_result - func_append libtool_args " $func_quote_for_eval_result" + compile_command="$compile_command $compile_deplibs" + finalize_command="$finalize_command $finalize_deplibs" - # If the previous option needs an argument, assign it. - if test -n "$prev"; then - case $prev in - output) - func_append compile_command " @OUTPUT@" - func_append finalize_command " @OUTPUT@" - ;; - esac + if test -n "$rpath$xrpath"; then + # If the user specified any rpath flags, then add them. + for libdir in $rpath $xrpath; do + # This is the magic to use -rpath. + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" ;; + esac + done + fi - case $prev in - dlfiles|dlprefiles) - if test "$preload" = no; then - # Add the symbol object into the linking commands. - func_append compile_command " @SYMFILE@" - func_append finalize_command " @SYMFILE@" - preload=yes - fi - case $arg in - *.la | *.lo) ;; # We handle these cases below. - force) - if test "$dlself" = no; then - dlself=needless - export_dynamic=yes - fi - prev= - continue - ;; - self) - if test "$prev" = dlprefiles; then - dlself=yes - elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then - dlself=yes - else - dlself=needless - export_dynamic=yes - fi - prev= - continue - ;; - *) - if test "$prev" = dlfiles; then - dlfiles="$dlfiles $arg" + # Now hardcode the library paths + rpath= + hardcode_libdirs= + for libdir in $compile_rpath $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" else - dlprefiles="$dlprefiles $arg" + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; + esac fi - prev= - continue - ;; + else + eval flag=\"$hardcode_libdir_flag_spec\" + rpath="$rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$perm_rpath " in + *" $libdir "*) ;; + *) perm_rpath="$perm_rpath $libdir" ;; + esac + fi + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*) + case :$dllsearchpath: in + *":$libdir:"*) ;; + *) dllsearchpath="$dllsearchpath:$libdir";; esac ;; - expsyms) - export_symbols="$arg" - test -f "$arg" \ - || func_fatal_error "symbol file \`$arg' does not exist" - prev= - continue - ;; - expsyms_regex) - export_symbols_regex="$arg" - prev= - continue - ;; - framework) - case $host in - *-*-darwin*) - case "$deplibs " in - *" $qarg.ltframework "*) ;; - *) deplibs="$deplibs $qarg.ltframework" # this is fixed later - ;; + esac + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + compile_rpath="$rpath" + + rpath= + hardcode_libdirs= + for libdir in $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; esac - ;; + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + rpath="$rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$finalize_perm_rpath " in + *" $libdir "*) ;; + *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;; esac - prev= - continue - ;; - inst_prefix) - inst_prefix_dir="$arg" - prev= - continue - ;; - objectlist) - if test -f "$arg"; then - save_arg=$arg - moreargs= - for fil in `cat "$save_arg"` - do -# moreargs="$moreargs $fil" - arg=$fil - # A libtool-controlled object. + fi + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + finalize_rpath="$rpath" - # Check to see that this really is a libtool object. - if func_lalib_unsafe_p "$arg"; then - pic_object= - non_pic_object= + if test -n "$libobjs" && test "$build_old_libs" = yes; then + # Transform all the library objects into standard objects. + compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + fi - # Read the .lo file - func_source "$arg" + dlsyms= + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + if test -n "$NM" && test -n "$global_symbol_pipe"; then + dlsyms="${outputname}S.c" + else + $echo "$modename: not configured to extract global symbols from dlpreopened files" 1>&2 + fi + fi - if test -z "$pic_object" || - test -z "$non_pic_object" || - test "$pic_object" = none && - test "$non_pic_object" = none; then - func_fatal_error "cannot find name of object for \`$arg'" - fi + if test -n "$dlsyms"; then + case $dlsyms in + "") ;; + *.c) + # Discover the nlist of each of the dlfiles. + nlist="$output_objdir/${outputname}.nm" - # Extract subdirectory from the argument. - func_dirname "$arg" "/" "" - xdir="$func_dirname_result" + $show "$rm $nlist ${nlist}S ${nlist}T" + $run $rm "$nlist" "${nlist}S" "${nlist}T" - if test "$pic_object" != none; then - # Prepend the subdirectory the object is found in. - pic_object="$xdir$pic_object" + # Parse the name list into a source file. + $show "creating $output_objdir/$dlsyms" - if test "$prev" = dlfiles; then - if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then - dlfiles="$dlfiles $pic_object" - prev= - continue - else - # If libtool objects are unsupported, then we need to preload. - prev=dlprefiles - fi - fi + test -z "$run" && $echo > "$output_objdir/$dlsyms" "\ +/* $dlsyms - symbol resolution table for \`$outputname' dlsym emulation. */ +/* Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP */ - # CHECK ME: I think I busted this. -Ossama - if test "$prev" = dlprefiles; then - # Preload the old-style object. - dlprefiles="$dlprefiles $pic_object" - prev= - fi +#ifdef __cplusplus +extern \"C\" { +#endif - # A PIC object. - func_append libobjs " $pic_object" - arg="$pic_object" - fi +/* Prevent the only kind of declaration conflicts we can make. */ +#define lt_preloaded_symbols some_other_symbol - # Non-PIC object. - if test "$non_pic_object" != none; then - # Prepend the subdirectory the object is found in. - non_pic_object="$xdir$non_pic_object" +/* External symbol declarations for the compiler. */\ +" - # A standard non-PIC object - func_append non_pic_objects " $non_pic_object" - if test -z "$pic_object" || test "$pic_object" = none ; then - arg="$non_pic_object" - fi - else - # If the PIC object exists, use it instead. - # $xdir was prepended to $pic_object above. - non_pic_object="$pic_object" - func_append non_pic_objects " $non_pic_object" - fi - else - # Only an error if not doing a dry-run. - if $opt_dry_run; then - # Extract subdirectory from the argument. - func_dirname "$arg" "/" "" - xdir="$func_dirname_result" + if test "$dlself" = yes; then + $show "generating symbol list for \`$output'" - func_lo2o "$arg" - pic_object=$xdir$objdir/$func_lo2o_result - non_pic_object=$xdir$func_lo2o_result - func_append libobjs " $pic_object" - func_append non_pic_objects " $non_pic_object" - else - func_fatal_error "\`$arg' is not a valid libtool object" - fi - fi + test -z "$run" && $echo ': @PROGRAM@ ' > "$nlist" + + # Add our own program objects to the symbol list. + progfiles=`$echo "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + for arg in $progfiles; do + $show "extracting global C symbols from \`$arg'" + $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'" done - else - func_fatal_error "link input file \`$arg' does not exist" + + if test -n "$exclude_expsyms"; then + $run eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' + $run eval '$mv "$nlist"T "$nlist"' + fi + + if test -n "$export_symbols_regex"; then + $run eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' + $run eval '$mv "$nlist"T "$nlist"' + fi + + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + export_symbols="$output_objdir/$output.exp" + $run $rm $export_symbols + $run eval "${SED} -n -e '/^: @PROGRAM@$/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' + else + $run eval "${SED} -e 's/\([][.*^$]\)/\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$output.exp"' + $run eval 'grep -f "$output_objdir/$output.exp" < "$nlist" > "$nlist"T' + $run eval 'mv "$nlist"T "$nlist"' + fi fi - arg=$save_arg - prev= - continue - ;; - precious_regex) - precious_files_regex="$arg" - prev= - continue - ;; - release) - release="-$arg" - prev= - continue - ;; - rpath | xrpath) - # We need an absolute path. - case $arg in - [\\/]* | [A-Za-z]:[\\/]*) ;; - *) - func_fatal_error "only absolute run-paths are allowed" - ;; - esac - if test "$prev" = rpath; then - case "$rpath " in - *" $arg "*) ;; - *) rpath="$rpath $arg" ;; - esac - else - case "$xrpath " in - *" $arg "*) ;; - *) xrpath="$xrpath $arg" ;; - esac - fi - prev= - continue - ;; - shrext) - shrext_cmds="$arg" - prev= - continue - ;; - weak) - weak_libs="$weak_libs $arg" - prev= - continue - ;; - xcclinker) - linker_flags="$linker_flags $qarg" - compiler_flags="$compiler_flags $qarg" - prev= - func_append compile_command " $qarg" - func_append finalize_command " $qarg" - continue - ;; - xcompiler) - compiler_flags="$compiler_flags $qarg" - prev= - func_append compile_command " $qarg" - func_append finalize_command " $qarg" - continue - ;; - xlinker) - linker_flags="$linker_flags $qarg" - compiler_flags="$compiler_flags $wl$qarg" - prev= - func_append compile_command " $wl$qarg" - func_append finalize_command " $wl$qarg" - continue - ;; - *) - eval "$prev=\"\$arg\"" - prev= - continue - ;; - esac - fi # test -n "$prev" - prevarg="$arg" + for arg in $dlprefiles; do + $show "extracting global C symbols from \`$arg'" + name=`$echo "$arg" | ${SED} -e 's%^.*/%%'` + $run eval '$echo ": $name " >> "$nlist"' + $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'" + done - case $arg in - -all-static) - if test -n "$link_static_flag"; then - # See comment for -static flag below, for more details. - func_append compile_command " $link_static_flag" - func_append finalize_command " $link_static_flag" - fi - continue - ;; + if test -z "$run"; then + # Make sure we have at least an empty file. + test -f "$nlist" || : > "$nlist" + + if test -n "$exclude_expsyms"; then + $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T + $mv "$nlist"T "$nlist" + fi - -allow-undefined) - # FIXME: remove this flag sometime in the future. - func_fatal_error "\`-allow-undefined' must not be used because it is the default" - ;; + # Try sorting and uniquifying the output. + if grep -v "^: " < "$nlist" | + if sort -k 3 /dev/null 2>&1; then + sort -k 3 + else + sort +2 + fi | + uniq > "$nlist"S; then + : + else + grep -v "^: " < "$nlist" > "$nlist"S + fi - -avoid-version) - avoid_version=yes - continue - ;; + if test -f "$nlist"S; then + eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$dlsyms"' + else + $echo '/* NONE */' >> "$output_objdir/$dlsyms" + fi - -dlopen) - prev=dlfiles - continue - ;; + $echo >> "$output_objdir/$dlsyms" "\ - -dlpreopen) - prev=dlprefiles - continue - ;; +#undef lt_preloaded_symbols - -export-dynamic) - export_dynamic=yes - continue - ;; +#if defined (__STDC__) && __STDC__ +# define lt_ptr void * +#else +# define lt_ptr char * +# define const +#endif - -export-symbols | -export-symbols-regex) - if test -n "$export_symbols" || test -n "$export_symbols_regex"; then - func_fatal_error "more than one -exported-symbols argument is not allowed" - fi - if test "X$arg" = "X-export-symbols"; then - prev=expsyms - else - prev=expsyms_regex - fi - continue - ;; +/* The mapping between symbol names and symbols. */ +const struct { + const char *name; + lt_ptr address; +} +lt_preloaded_symbols[] = +{\ +" - -framework) - prev=framework - continue - ;; + eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$dlsyms" - -inst-prefix-dir) - prev=inst_prefix - continue - ;; + $echo >> "$output_objdir/$dlsyms" "\ + {0, (lt_ptr) 0} +}; - # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* - # so, if we see these flags be careful not to treat them like -L - -L[A-Z][A-Z]*:*) - case $with_gcc/$host in - no/*-*-irix* | /*-*-irix*) - func_append compile_command " $arg" - func_append finalize_command " $arg" - ;; - esac - continue - ;; +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt_preloaded_symbols; +} +#endif - -L*) - func_stripname '-L' '' "$arg" - dir=$func_stripname_result - if test -z "$dir"; then - if test "$#" -gt 0; then - func_fatal_error "require no space between \`-L' and \`$1'" - else - func_fatal_error "need path for \`-L' option" +#ifdef __cplusplus +} +#endif\ +" fi - fi - # We need an absolute path. - case $dir in - [\\/]* | [A-Za-z]:[\\/]*) ;; - *) - absdir=`cd "$dir" && pwd` - test -z "$absdir" && \ - func_fatal_error "cannot determine absolute directory name of \`$dir'" - dir="$absdir" - ;; - esac - case "$deplibs " in - *" -L$dir "*) ;; - *) - deplibs="$deplibs -L$dir" - lib_search_path="$lib_search_path $dir" - ;; - esac - case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) - testbindir=`$ECHO "X$dir" | $Xsed -e 's*/lib$*/bin*'` - case :$dllsearchpath: in - *":$dir:"*) ;; - ::) dllsearchpath=$dir;; - *) dllsearchpath="$dllsearchpath:$dir";; - esac - case :$dllsearchpath: in - *":$testbindir:"*) ;; - ::) dllsearchpath=$testbindir;; - *) dllsearchpath="$dllsearchpath:$testbindir";; - esac - ;; - esac - continue - ;; - -l*) - if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then + pic_flag_for_symtable= case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc*) - # These systems don't actually have a C or math library (as such) - continue - ;; - *-*-os2*) - # These systems don't actually have a C library (as such) - test "X$arg" = "X-lc" && continue - ;; - *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) - # Do not include libc due to us having libc/libc_r. - test "X$arg" = "X-lc" && continue - ;; - *-*-rhapsody* | *-*-darwin1.[012]) - # Rhapsody C and math libraries are in the System framework - deplibs="$deplibs System.ltframework" - continue - ;; - *-*-sco3.2v5* | *-*-sco5v6*) - # Causes problems with __ctype - test "X$arg" = "X-lc" && continue - ;; - *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) - # Compiler inserts libc in the correct place for threads to work - test "X$arg" = "X-lc" && continue - ;; + # compiling the symbol table file with pic_flag works around + # a FreeBSD bug that causes programs to crash when -lm is + # linked before any other PIC object. But we must not use + # pic_flag when linking with -static. The problem exists in + # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. + *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) + case "$compile_command " in + *" -static "*) ;; + *) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND";; + esac;; + *-*-hpux*) + case "$compile_command " in + *" -static "*) ;; + *) pic_flag_for_symtable=" $pic_flag";; + esac esac - elif test "X$arg" = "X-lc_r"; then - case $host in - *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) - # Do not include libc_r directly, use -pthread flag. - continue - ;; - esac - fi - deplibs="$deplibs $arg" - continue - ;; - - -module) - module=yes - continue - ;; - - # Tru64 UNIX uses -model [arg] to determine the layout of C++ - # classes, name mangling, and exception handling. - # Darwin uses the -arch flag to determine output architecture. - -model|-arch|-isysroot) - compiler_flags="$compiler_flags $arg" - func_append compile_command " $arg" - func_append finalize_command " $arg" - prev=xcompiler - continue - ;; - -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads) - compiler_flags="$compiler_flags $arg" - func_append compile_command " $arg" - func_append finalize_command " $arg" - case "$new_inherited_linker_flags " in - *" $arg "*) ;; - * ) new_inherited_linker_flags="$new_inherited_linker_flags $arg" ;; + # Now compile the dynamic symbol file. + $show "(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable \"$dlsyms\")" + $run eval '(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable "$dlsyms")' || exit $? + + # Clean up the generated files. + $show "$rm $output_objdir/$dlsyms $nlist ${nlist}S ${nlist}T" + $run $rm "$output_objdir/$dlsyms" "$nlist" "${nlist}S" "${nlist}T" + + # Transform the symbol file into the correct name. + compile_command=`$echo "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"` + finalize_command=`$echo "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"` + ;; + *) + $echo "$modename: unknown suffix for \`$dlsyms'" 1>&2 + exit $EXIT_FAILURE + ;; esac - continue - ;; - - -multi_module) - single_module="${wl}-multi_module" - continue - ;; + else + # We keep going just in case the user didn't refer to + # lt_preloaded_symbols. The linker will fail if global_symbol_pipe + # really was required. - -no-fast-install) - fast_install=no - continue - ;; + # Nullify the symbol file. + compile_command=`$echo "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"` + finalize_command=`$echo "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"` + fi - -no-install) - case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) - # The PATH hackery in wrapper scripts is required on Windows - # and Darwin in order for the loader to find any dlls it needs. - func_warning "\`-no-install' is ignored for $host" - func_warning "assuming \`-no-fast-install' instead" - fast_install=no - ;; - *) no_install=yes ;; - esac - continue - ;; + if test "$need_relink" = no || test "$build_libtool_libs" != yes; then + # Replace the output file specification. + compile_command=`$echo "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` + link_command="$compile_command$compile_rpath" - -no-undefined) - allow_undefined=no - continue - ;; + # We have no uninstalled library dependencies, so finalize right now. + $show "$link_command" + $run eval "$link_command" + status=$? - -objectlist) - prev=objectlist - continue - ;; + # Delete the generated files. + if test -n "$dlsyms"; then + $show "$rm $output_objdir/${outputname}S.${objext}" + $run $rm "$output_objdir/${outputname}S.${objext}" + fi - -o) prev=output ;; + exit $status + fi - -precious-files-regex) - prev=precious_regex - continue - ;; + if test -n "$shlibpath_var"; then + # We should set the shlibpath_var + rpath= + for dir in $temp_rpath; do + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) + # Absolute path. + rpath="$rpath$dir:" + ;; + *) + # Relative path: add a thisdir entry. + rpath="$rpath\$thisdir/$dir:" + ;; + esac + done + temp_rpath="$rpath" + fi - -release) - prev=release - continue - ;; + if test -n "$compile_shlibpath$finalize_shlibpath"; then + compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" + fi + if test -n "$finalize_shlibpath"; then + finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" + fi - -rpath) - prev=rpath - continue - ;; + compile_var= + finalize_var= + if test -n "$runpath_var"; then + if test -n "$perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $perm_rpath; do + rpath="$rpath$dir:" + done + compile_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + if test -n "$finalize_perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $finalize_perm_rpath; do + rpath="$rpath$dir:" + done + finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + fi - -R) - prev=xrpath - continue - ;; + if test "$no_install" = yes; then + # We don't need to create a wrapper script. + link_command="$compile_var$compile_command$compile_rpath" + # Replace the output file specification. + link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` + # Delete the old output file. + $run $rm $output + # Link the executable and exit + $show "$link_command" + $run eval "$link_command" || exit $? + exit $EXIT_SUCCESS + fi - -R*) - func_stripname '-R' '' "$arg" - dir=$func_stripname_result - # We need an absolute path. - case $dir in - [\\/]* | [A-Za-z]:[\\/]*) ;; - *) - func_fatal_error "only absolute run-paths are allowed" - ;; - esac - case "$xrpath " in - *" $dir "*) ;; - *) xrpath="$xrpath $dir" ;; - esac - continue - ;; + if test "$hardcode_action" = relink; then + # Fast installation is not supported + link_command="$compile_var$compile_command$compile_rpath" + relink_command="$finalize_var$finalize_command$finalize_rpath" - -shared) - # The effects of -shared are defined in a previous loop. - continue - ;; + $echo "$modename: warning: this platform does not like uninstalled shared libraries" 1>&2 + $echo "$modename: \`$output' will be relinked during installation" 1>&2 + else + if test "$fast_install" != no; then + link_command="$finalize_var$compile_command$finalize_rpath" + if test "$fast_install" = yes; then + relink_command=`$echo "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'` + else + # fast_install is set to needless + relink_command= + fi + else + link_command="$compile_var$compile_command$compile_rpath" + relink_command="$finalize_var$finalize_command$finalize_rpath" + fi + fi - -shrext) - prev=shrext - continue - ;; + # Replace the output file specification. + link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` - -static | -static-libtool-libs) - # The effects of -static are defined in a previous loop. - # We used to do the same as -all-static on platforms that - # didn't have a PIC flag, but the assumption that the effects - # would be equivalent was wrong. It would break on at least - # Digital Unix and AIX. - continue - ;; + # Delete the old output files. + $run $rm $output $output_objdir/$outputname $output_objdir/lt-$outputname - -thread-safe) - thread_safe=yes - continue - ;; + $show "$link_command" + $run eval "$link_command" || exit $? - -version-info) - prev=vinfo - continue - ;; + # Now create the wrapper script. + $show "creating $output" - -version-number) - prev=vinfo - vinfo_number=yes - continue - ;; + # Quote the relink command for shipping. + if test -n "$relink_command"; then + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"` + relink_command="$var=\"$var_value\"; export $var; $relink_command" + fi + done + relink_command="(cd `pwd`; $relink_command)" + relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"` + fi - -weak) - prev=weak - continue - ;; + # Quote $echo for shipping. + if test "X$echo" = "X$SHELL $progpath --fallback-echo"; then + case $progpath in + [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";; + *) qecho="$SHELL `pwd`/$progpath --fallback-echo";; + esac + qecho=`$echo "X$qecho" | $Xsed -e "$sed_quote_subst"` + else + qecho=`$echo "X$echo" | $Xsed -e "$sed_quote_subst"` + fi - -Wc,*) - func_stripname '-Wc,' '' "$arg" - args=$func_stripname_result - arg= - save_ifs="$IFS"; IFS=',' - for flag in $args; do - IFS="$save_ifs" - func_quote_for_eval "$flag" - arg="$arg $wl$func_quote_for_eval_result" - compiler_flags="$compiler_flags $func_quote_for_eval_result" - done - IFS="$save_ifs" - func_stripname ' ' '' "$arg" - arg=$func_stripname_result - ;; + # Only actually do things if our run command is non-null. + if test -z "$run"; then + # win32 will think the script is a binary if it has + # a .exe suffix, so we strip it off here. + case $output in + *.exe) output=`$echo $output|${SED} 's,.exe$,,'` ;; + esac + # test for cygwin because mv fails w/o .exe extensions + case $host in + *cygwin*) + exeext=.exe + outputname=`$echo $outputname|${SED} 's,.exe$,,'` ;; + *) exeext= ;; + esac + case $host in + *cygwin* | *mingw* ) + cwrappersource=`$echo ${objdir}/lt-${output}.c` + cwrapper=`$echo ${output}.exe` + $rm $cwrappersource $cwrapper + trap "$rm $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 - -Wl,*) - func_stripname '-Wl,' '' "$arg" - args=$func_stripname_result - arg= - save_ifs="$IFS"; IFS=',' - for flag in $args; do - IFS="$save_ifs" - func_quote_for_eval "$flag" - arg="$arg $wl$func_quote_for_eval_result" - compiler_flags="$compiler_flags $wl$func_quote_for_eval_result" - linker_flags="$linker_flags $func_quote_for_eval_result" - done - IFS="$save_ifs" - func_stripname ' ' '' "$arg" - arg=$func_stripname_result - ;; + cat > $cwrappersource <> $cwrappersource<<"EOF" +#include +#include +#include +#include +#include +#include - # Some other compiler flag. - -* | +*) - func_quote_for_eval "$arg" - arg="$func_quote_for_eval_result" - ;; +#if defined(PATH_MAX) +# define LT_PATHMAX PATH_MAX +#elif defined(MAXPATHLEN) +# define LT_PATHMAX MAXPATHLEN +#else +# define LT_PATHMAX 1024 +#endif - *.$objext) - # A standard object. - objs="$objs $arg" - ;; +#ifndef DIR_SEPARATOR +#define DIR_SEPARATOR '/' +#endif - *.lo) - # A libtool-controlled object. +#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \ + defined (__OS2__) +#define HAVE_DOS_BASED_FILE_SYSTEM +#ifndef DIR_SEPARATOR_2 +#define DIR_SEPARATOR_2 '\\' +#endif +#endif - # Check to see that this really is a libtool object. - if func_lalib_unsafe_p "$arg"; then - pic_object= - non_pic_object= +#ifndef DIR_SEPARATOR_2 +# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) +#else /* DIR_SEPARATOR_2 */ +# define IS_DIR_SEPARATOR(ch) \ + (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) +#endif /* DIR_SEPARATOR_2 */ - # Read the .lo file - func_source "$arg" +#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) +#define XFREE(stale) do { \ + if (stale) { free ((void *) stale); stale = 0; } \ +} while (0) - if test -z "$pic_object" || - test -z "$non_pic_object" || - test "$pic_object" = none && - test "$non_pic_object" = none; then - func_fatal_error "cannot find name of object for \`$arg'" - fi +const char *program_name = NULL; - # Extract subdirectory from the argument. - func_dirname "$arg" "/" "" - xdir="$func_dirname_result" +void * xmalloc (size_t num); +char * xstrdup (const char *string); +char * basename (const char *name); +char * fnqualify(const char *path); +char * strendzap(char *str, const char *pat); +void lt_fatal (const char *message, ...); - if test "$pic_object" != none; then - # Prepend the subdirectory the object is found in. - pic_object="$xdir$pic_object" +int +main (int argc, char *argv[]) +{ + char **newargz; + int i; - if test "$prev" = dlfiles; then - if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then - dlfiles="$dlfiles $pic_object" - prev= - continue - else - # If libtool objects are unsupported, then we need to preload. - prev=dlprefiles - fi - fi + program_name = (char *) xstrdup ((char *) basename (argv[0])); + newargz = XMALLOC(char *, argc+2); +EOF - # CHECK ME: I think I busted this. -Ossama - if test "$prev" = dlprefiles; then - # Preload the old-style object. - dlprefiles="$dlprefiles $pic_object" - prev= - fi - - # A PIC object. - func_append libobjs " $pic_object" - arg="$pic_object" - fi - - # Non-PIC object. - if test "$non_pic_object" != none; then - # Prepend the subdirectory the object is found in. - non_pic_object="$xdir$non_pic_object" - - # A standard non-PIC object - func_append non_pic_objects " $non_pic_object" - if test -z "$pic_object" || test "$pic_object" = none ; then - arg="$non_pic_object" - fi - else - # If the PIC object exists, use it instead. - # $xdir was prepended to $pic_object above. - non_pic_object="$pic_object" - func_append non_pic_objects " $non_pic_object" - fi - else - # Only an error if not doing a dry-run. - if $opt_dry_run; then - # Extract subdirectory from the argument. - func_dirname "$arg" "/" "" - xdir="$func_dirname_result" + cat >> $cwrappersource <> $cwrappersource <<"EOF" + newargz[1] = fnqualify(argv[0]); + /* we know the script has the same name, without the .exe */ + /* so make sure newargz[1] doesn't end in .exe */ + strendzap(newargz[1],".exe"); + for (i = 1; i < argc; i++) + newargz[i+1] = xstrdup(argv[i]); + newargz[argc+1] = NULL; +EOF - *.$libext) - # An archive. - deplibs="$deplibs $arg" - old_deplibs="$old_deplibs $arg" - continue - ;; + cat >> $cwrappersource <> $cwrappersource <<"EOF" +} - if test "$prev" = dlfiles; then - # This library was specified with -dlopen. - dlfiles="$dlfiles $arg" - prev= - elif test "$prev" = dlprefiles; then - # The library was specified with -dlpreopen. - dlprefiles="$dlprefiles $arg" - prev= - else - deplibs="$deplibs $arg" - fi - continue - ;; +void * +xmalloc (size_t num) +{ + void * p = (void *) malloc (num); + if (!p) + lt_fatal ("Memory exhausted"); - # Some other compiler argument. - *) - # Unknown arguments in both finalize_command and compile_command need - # to be aesthetically quoted because they are evaled later. - func_quote_for_eval "$arg" - arg="$func_quote_for_eval_result" - ;; - esac # arg + return p; +} - # Now actually substitute the argument into the commands. - if test -n "$arg"; then - func_append compile_command " $arg" - func_append finalize_command " $arg" - fi - done # argument parsing loop +char * +xstrdup (const char *string) +{ + return string ? strcpy ((char *) xmalloc (strlen (string) + 1), string) : NULL +; +} - test -n "$prev" && \ - func_fatal_help "the \`$prevarg' option requires an argument" +char * +basename (const char *name) +{ + const char *base; - if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then - eval arg=\"$export_dynamic_flag_spec\" - func_append compile_command " $arg" - func_append finalize_command " $arg" - fi +#if defined (HAVE_DOS_BASED_FILE_SYSTEM) + /* Skip over the disk name in MSDOS pathnames. */ + if (isalpha (name[0]) && name[1] == ':') + name += 2; +#endif - oldlibs= - # calculate the name of the file, without its directory - func_basename "$output" - outputname="$func_basename_result" - libobjs_save="$libobjs" + for (base = name; *name; name++) + if (IS_DIR_SEPARATOR (*name)) + base = name + 1; + return (char *) base; +} - if test -n "$shlibpath_var"; then - # get the directories listed in $shlibpath_var - eval shlib_search_path=\`\$ECHO \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\` - else - shlib_search_path= - fi - eval sys_lib_search_path=\"$sys_lib_search_path_spec\" - eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" +char * +fnqualify(const char *path) +{ + size_t size; + char *p; + char tmp[LT_PATHMAX + 1]; - func_dirname "$output" "/" "" - output_objdir="$func_dirname_result$objdir" - # Create the object directory. - func_mkdir_p "$output_objdir" + assert(path != NULL); - # Determine the type of output - case $output in - "") - func_fatal_help "you must specify an output file" - ;; - *.$libext) linkmode=oldlib ;; - *.lo | *.$objext) linkmode=obj ;; - *.la) linkmode=lib ;; - *) linkmode=prog ;; # Anything else should be a program. - esac + /* Is it qualified already? */ +#if defined (HAVE_DOS_BASED_FILE_SYSTEM) + if (isalpha (path[0]) && path[1] == ':') + return xstrdup (path); +#endif + if (IS_DIR_SEPARATOR (path[0])) + return xstrdup (path); - specialdeplibs= + /* prepend the current directory */ + /* doesn't handle '~' */ + if (getcwd (tmp, LT_PATHMAX) == NULL) + lt_fatal ("getcwd failed"); + size = strlen(tmp) + 1 + strlen(path) + 1; /* +2 for '/' and '\0' */ + p = XMALLOC(char, size); + sprintf(p, "%s%c%s", tmp, DIR_SEPARATOR, path); + return p; +} - libs= - # Find all interdependent deplibs by searching for libraries - # that are linked more than once (e.g. -la -lb -la) - for deplib in $deplibs; do - if $opt_duplicate_deps ; then - case "$libs " in - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; - esac - fi - libs="$libs $deplib" - done +char * +strendzap(char *str, const char *pat) +{ + size_t len, patlen; - if test "$linkmode" = lib; then - libs="$predeps $libs $compiler_lib_search_path $postdeps" + assert(str != NULL); + assert(pat != NULL); - # Compute libraries that are listed more than once in $predeps - # $postdeps and mark them as special (i.e., whose duplicates are - # not to be eliminated). - pre_post_deps= - if $opt_duplicate_compiler_generated_deps; then - for pre_post_dep in $predeps $postdeps; do - case "$pre_post_deps " in - *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;; - esac - pre_post_deps="$pre_post_deps $pre_post_dep" - done - fi - pre_post_deps= - fi + len = strlen(str); + patlen = strlen(pat); - deplibs= - newdependency_libs= - newlib_search_path= - need_relink=no # whether we're linking any uninstalled libtool libraries - notinst_deplibs= # not-installed libtool libraries - notinst_path= # paths that contain not-installed libtool libraries + if (patlen <= len) + { + str += len - patlen; + if (strcmp(str, pat) == 0) + *str = '\0'; + } + return str; +} - case $linkmode in - lib) - passes="conv dlpreopen link" - for file in $dlfiles $dlprefiles; do - case $file in - *.la) ;; - *) - func_fatal_help "libraries can \`-dlopen' only libtool libraries: $file" - ;; - esac - done - ;; - prog) - compile_deplibs= - finalize_deplibs= - alldeplibs=no - newdlfiles= - newdlprefiles= - passes="conv scan dlopen dlpreopen link" - ;; - *) passes="conv" - ;; - esac +static void +lt_error_core (int exit_status, const char * mode, + const char * message, va_list ap) +{ + fprintf (stderr, "%s: %s: ", program_name, mode); + vfprintf (stderr, message, ap); + fprintf (stderr, ".\n"); - for pass in $passes; do - # The preopen pass in lib mode reverses $deplibs; put it back here - # so that -L comes before libs that need it for instance... - if test "$linkmode,$pass" = "lib,link"; then - ## FIXME: Find the place where the list is rebuilt in the wrong - ## order, and fix it there properly - tmp_deplibs= - for deplib in $deplibs; do - tmp_deplibs="$deplib $tmp_deplibs" - done - deplibs="$tmp_deplibs" - fi + if (exit_status >= 0) + exit (exit_status); +} - if test "$linkmode,$pass" = "lib,link" || - test "$linkmode,$pass" = "prog,scan"; then - libs="$deplibs" - deplibs= - fi - if test "$linkmode" = prog; then - case $pass in - dlopen) libs="$dlfiles" ;; - dlpreopen) libs="$dlprefiles" ;; - link) - libs="$deplibs %DEPLIBS%" - test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs" +void +lt_fatal (const char *message, ...) +{ + va_list ap; + va_start (ap, message); + lt_error_core (EXIT_FAILURE, "FATAL", message, ap); + va_end (ap); +} +EOF + # we should really use a build-platform specific compiler + # here, but OTOH, the wrappers (shell script and this C one) + # are only useful if you want to execute the "real" binary. + # Since the "real" binary is built for $host, then this + # wrapper might as well be built for $host, too. + $run $LTCC -s -o $cwrapper $cwrappersource ;; esac - fi - if test "$linkmode,$pass" = "lib,dlpreopen"; then - # Collect and forward deplibs of preopened libtool libs - for lib in $dlprefiles; do - # Ignore non-libtool-libs - dependency_libs= - case $lib in - *.la) func_source "$lib" ;; - esac + $rm $output + trap "$rm $output; exit $EXIT_FAILURE" 1 2 15 - # Collect preopened libtool deplibs, except any this library - # has declared as weak libs - for deplib in $dependency_libs; do - deplib_base=`$ECHO "X$deplib" | $Xsed -e "$basename"` - case " $weak_libs " in - *" $deplib_base "*) ;; - *) deplibs="$deplibs $deplib" ;; - esac - done - done - libs="$dlprefiles" - fi - if test "$pass" = dlopen; then - # Collect dlpreopened libraries - save_deplibs="$deplibs" - deplibs= - fi + $echo > $output "\ +#! $SHELL - for deplib in $libs; do - lib= - found=no - case $deplib in - -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads) - if test "$linkmode,$pass" = "prog,link"; then - compile_deplibs="$deplib $compile_deplibs" - finalize_deplibs="$deplib $finalize_deplibs" - else - compiler_flags="$compiler_flags $deplib" - if test "$linkmode" = lib ; then - case "$new_inherited_linker_flags " in - *" $deplib "*) ;; - * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;; - esac - fi - fi - continue - ;; - -l*) - if test "$linkmode" != lib && test "$linkmode" != prog; then - func_warning "\`-l' is ignored for archives/objects" - continue - fi - func_stripname '-l' '' "$deplib" - name=$func_stripname_result - if test "$linkmode" = lib; then - searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" - else - searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" - fi - for searchdir in $searchdirs; do - for search_ext in .la $std_shrext .so .a; do - # Search the libtool library - lib="$searchdir/lib${name}${search_ext}" - if test -f "$lib"; then - if test "$search_ext" = ".la"; then - found=yes - else - found=no - fi - break 2 - fi - done - done - if test "$found" != yes; then - # deplib doesn't seem to be a libtool library - if test "$linkmode,$pass" = "prog,link"; then - compile_deplibs="$deplib $compile_deplibs" - finalize_deplibs="$deplib $finalize_deplibs" - else - deplibs="$deplib $deplibs" - test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" - fi - continue - else # deplib is a libtool library - # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, - # We need to do some special things here, and not later. - if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then - case " $predeps $postdeps " in - *" $deplib "*) - if func_lalib_p "$lib"; then - library_names= - old_library= - func_source "$lib" - for l in $old_library $library_names; do - ll="$l" - done - if test "X$ll" = "X$old_library" ; then # only static version available - found=no - func_dirname "$lib" "" "." - ladir="$func_dirname_result" - lib=$ladir/$old_library - if test "$linkmode,$pass" = "prog,link"; then - compile_deplibs="$deplib $compile_deplibs" - finalize_deplibs="$deplib $finalize_deplibs" - else - deplibs="$deplib $deplibs" - test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" - fi - continue - fi - fi - ;; - *) ;; - esac - fi - fi - ;; # -l - *.ltframework) - if test "$linkmode,$pass" = "prog,link"; then - compile_deplibs="$deplib $compile_deplibs" - finalize_deplibs="$deplib $finalize_deplibs" - else - deplibs="$deplib $deplibs" - if test "$linkmode" = lib ; then - case "$new_inherited_linker_flags " in - *" $deplib "*) ;; - * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;; - esac - fi - fi - continue - ;; - -L*) - case $linkmode in - lib) - deplibs="$deplib $deplibs" - test "$pass" = conv && continue - newdependency_libs="$deplib $newdependency_libs" - func_stripname '-L' '' "$deplib" - newlib_search_path="$newlib_search_path $func_stripname_result" - ;; - prog) - if test "$pass" = conv; then - deplibs="$deplib $deplibs" - continue - fi - if test "$pass" = scan; then - deplibs="$deplib $deplibs" - else - compile_deplibs="$deplib $compile_deplibs" - finalize_deplibs="$deplib $finalize_deplibs" - fi - func_stripname '-L' '' "$deplib" - newlib_search_path="$newlib_search_path $func_stripname_result" - ;; - *) - func_warning "\`-L' is ignored for archives/objects" - ;; - esac # linkmode - continue - ;; # -L - -R*) - if test "$pass" = link; then - func_stripname '-R' '' "$deplib" - dir=$func_stripname_result - # Make sure the xrpath contains only unique directories. - case "$xrpath " in - *" $dir "*) ;; - *) xrpath="$xrpath $dir" ;; - esac - fi - deplibs="$deplib $deplibs" - continue - ;; - *.la) lib="$deplib" ;; - *.$libext) - if test "$pass" = conv; then - deplibs="$deplib $deplibs" - continue - fi - case $linkmode in - lib) - # Linking convenience modules into shared libraries is allowed, - # but linking other static libraries is non-portable. - case " $dlpreconveniencelibs " in - *" $deplib "*) ;; - *) - valid_a_lib=no - case $deplibs_check_method in - match_pattern*) - set dummy $deplibs_check_method; shift - match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` - if eval "\$ECHO \"X$deplib\"" 2>/dev/null | $Xsed -e 10q \ - | $EGREP "$match_pattern_regex" > /dev/null; then - valid_a_lib=yes - fi - ;; - pass_all) - valid_a_lib=yes - ;; - esac - if test "$valid_a_lib" != yes; then - $ECHO - $ECHO "*** Warning: Trying to link with static lib archive $deplib." - $ECHO "*** I have the capability to make that library automatically link in when" - $ECHO "*** you link to this library. But I can only do this if you have a" - $ECHO "*** shared version of the library, which you do not appear to have" - $ECHO "*** because the file extensions .$libext of this argument makes me believe" - $ECHO "*** that it is just a static archive that I should not use here." - else - $ECHO - $ECHO "*** Warning: Linking the shared library $output against the" - $ECHO "*** static library $deplib is not portable!" - deplibs="$deplib $deplibs" - fi - ;; - esac - continue - ;; - prog) - if test "$pass" != link; then - deplibs="$deplib $deplibs" - else - compile_deplibs="$deplib $compile_deplibs" - finalize_deplibs="$deplib $finalize_deplibs" - fi - continue - ;; - esac # linkmode - ;; # *.$libext - *.lo | *.$objext) - if test "$pass" = conv; then - deplibs="$deplib $deplibs" - elif test "$linkmode" = prog; then - if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then - # If there is no dlopen support or we're linking statically, - # we need to preload. - newdlprefiles="$newdlprefiles $deplib" - compile_deplibs="$deplib $compile_deplibs" - finalize_deplibs="$deplib $finalize_deplibs" - else - newdlfiles="$newdlfiles $deplib" - fi - fi - continue - ;; - %DEPLIBS%) - alldeplibs=yes - continue - ;; - esac # case $deplib - - if test "$found" = yes || test -f "$lib"; then : - else - func_fatal_error "cannot find the library \`$lib' or unhandled argument \`$deplib'" - fi - - # Check to see that this really is a libtool archive. - func_lalib_unsafe_p "$lib" \ - || func_fatal_error "\`$lib' is not a valid libtool archive" - - func_dirname "$lib" "" "." - ladir="$func_dirname_result" - - dlname= - dlopen= - dlpreopen= - libdir= - library_names= - old_library= - inherited_linker_flags= - # If the library was installed with an old release of libtool, - # it will not redefine variables installed, or shouldnotlink - installed=yes - shouldnotlink=no - avoidtemprpath= - - - # Read the .la file - func_source "$lib" - - # Convert "-framework foo" to "foo.ltframework" - if test -n "$inherited_linker_flags"; then - tmp_inherited_linker_flags=`$ECHO "X$inherited_linker_flags" | $Xsed -e 's/-framework \([^ $]*\)/\1.ltframework/g'` - for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do - case " $new_inherited_linker_flags " in - *" $tmp_inherited_linker_flag "*) ;; - *) new_inherited_linker_flags="$new_inherited_linker_flags $tmp_inherited_linker_flag";; - esac - done - fi - dependency_libs=`$ECHO "X $dependency_libs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` - if test "$linkmode,$pass" = "lib,link" || - test "$linkmode,$pass" = "prog,scan" || - { test "$linkmode" != prog && test "$linkmode" != lib; }; then - test -n "$dlopen" && dlfiles="$dlfiles $dlopen" - test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen" - fi - - if test "$pass" = conv; then - # Only check for convenience libraries - deplibs="$lib $deplibs" - if test -z "$libdir"; then - if test -z "$old_library"; then - func_fatal_error "cannot find name of link library for \`$lib'" - fi - # It is a libtool convenience library, so add in its objects. - convenience="$convenience $ladir/$objdir/$old_library" - old_convenience="$old_convenience $ladir/$objdir/$old_library" - tmp_libs= - for deplib in $dependency_libs; do - deplibs="$deplib $deplibs" - if $opt_duplicate_deps ; then - case "$tmp_libs " in - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; - esac - fi - tmp_libs="$tmp_libs $deplib" - done - elif test "$linkmode" != prog && test "$linkmode" != lib; then - func_fatal_error "\`$lib' is not a convenience library" - fi - continue - fi # $pass = conv - - - # Get the name of the library we link against. - linklib= - for l in $old_library $library_names; do - linklib="$l" - done - if test -z "$linklib"; then - func_fatal_error "cannot find name of link library for \`$lib'" - fi - - # This library was specified with -dlopen. - if test "$pass" = dlopen; then - if test -z "$libdir"; then - func_fatal_error "cannot -dlopen a convenience library: \`$lib'" - fi - if test -z "$dlname" || - test "$dlopen_support" != yes || - test "$build_libtool_libs" = no; then - # If there is no dlname, no dlopen support or we're linking - # statically, we need to preload. We also need to preload any - # dependent libraries so libltdl's deplib preloader doesn't - # bomb out in the load deplibs phase. - dlprefiles="$dlprefiles $lib $dependency_libs" - else - newdlfiles="$newdlfiles $lib" - fi - continue - fi # $pass = dlopen - - # We need an absolute path. - case $ladir in - [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;; - *) - abs_ladir=`cd "$ladir" && pwd` - if test -z "$abs_ladir"; then - func_warning "cannot determine absolute directory name of \`$ladir'" - func_warning "passing it literally to the linker, although it might fail" - abs_ladir="$ladir" - fi - ;; - esac - func_basename "$lib" - laname="$func_basename_result" - - # Find the relevant object directory and library name. - if test "X$installed" = Xyes; then - if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then - func_warning "library \`$lib' was moved." - dir="$ladir" - absdir="$abs_ladir" - libdir="$abs_ladir" - else - dir="$libdir" - absdir="$libdir" - fi - test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes - else - if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then - dir="$ladir" - absdir="$abs_ladir" - # Remove this search path later - notinst_path="$notinst_path $abs_ladir" - else - dir="$ladir/$objdir" - absdir="$abs_ladir/$objdir" - # Remove this search path later - notinst_path="$notinst_path $abs_ladir" - fi - fi # $installed = yes - func_stripname 'lib' '.la' "$laname" - name=$func_stripname_result - - # This library was specified with -dlpreopen. - if test "$pass" = dlpreopen; then - if test -z "$libdir" && test "$linkmode" = prog; then - func_fatal_error "only libraries may -dlpreopen a convenience library: \`$lib'" - fi - # Prefer using a static library (so that no silly _DYNAMIC symbols - # are required to link). - if test -n "$old_library"; then - newdlprefiles="$newdlprefiles $dir/$old_library" - # Keep a list of preopened convenience libraries to check - # that they are being used correctly in the link pass. - test -z "$libdir" && \ - dlpreconveniencelibs="$dlpreconveniencelibs $dir/$old_library" - # Otherwise, use the dlname, so that lt_dlopen finds it. - elif test -n "$dlname"; then - newdlprefiles="$newdlprefiles $dir/$dlname" - else - newdlprefiles="$newdlprefiles $dir/$linklib" - fi - fi # $pass = dlpreopen - - if test -z "$libdir"; then - # Link the convenience library - if test "$linkmode" = lib; then - deplibs="$dir/$old_library $deplibs" - elif test "$linkmode,$pass" = "prog,link"; then - compile_deplibs="$dir/$old_library $compile_deplibs" - finalize_deplibs="$dir/$old_library $finalize_deplibs" - else - deplibs="$lib $deplibs" # used for prog,scan pass - fi - continue - fi - - - if test "$linkmode" = prog && test "$pass" != link; then - newlib_search_path="$newlib_search_path $ladir" - deplibs="$lib $deplibs" - - linkalldeplibs=no - if test "$link_all_deplibs" != no || test -z "$library_names" || - test "$build_libtool_libs" = no; then - linkalldeplibs=yes - fi - - tmp_libs= - for deplib in $dependency_libs; do - case $deplib in - -L*) func_stripname '-L' '' "$deplib" - newlib_search_path="$newlib_search_path $func_stripname_result" - ;; - esac - # Need to link against all dependency_libs? - if test "$linkalldeplibs" = yes; then - deplibs="$deplib $deplibs" - else - # Need to hardcode shared library paths - # or/and link against static libraries - newdependency_libs="$deplib $newdependency_libs" - fi - if $opt_duplicate_deps ; then - case "$tmp_libs " in - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; - esac - fi - tmp_libs="$tmp_libs $deplib" - done # for deplib - continue - fi # $linkmode = prog... - - if test "$linkmode,$pass" = "prog,link"; then - if test -n "$library_names" && - { { test "$prefer_static_libs" = no || - test "$prefer_static_libs,$installed" = "built,yes"; } || - test -z "$old_library"; }; then - # We need to hardcode the library path - if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then - # Make sure the rpath contains only unique directories. - case "$temp_rpath:" in - *"$absdir:"*) ;; - *) temp_rpath="$temp_rpath$absdir:" ;; - esac - fi - - # Hardcode the library path. - # Skip directories that are in the system default run-time - # search path. - case " $sys_lib_dlsearch_path " in - *" $absdir "*) ;; - *) - case "$compile_rpath " in - *" $absdir "*) ;; - *) compile_rpath="$compile_rpath $absdir" - esac - ;; - esac - case " $sys_lib_dlsearch_path " in - *" $libdir "*) ;; - *) - case "$finalize_rpath " in - *" $libdir "*) ;; - *) finalize_rpath="$finalize_rpath $libdir" - esac - ;; - esac - fi # $linkmode,$pass = prog,link... - - if test "$alldeplibs" = yes && - { test "$deplibs_check_method" = pass_all || - { test "$build_libtool_libs" = yes && - test -n "$library_names"; }; }; then - # We only need to search for static libraries - continue - fi - fi - - link_static=no # Whether the deplib will be linked statically - use_static_libs=$prefer_static_libs - if test "$use_static_libs" = built && test "$installed" = yes; then - use_static_libs=no - fi - if test -n "$library_names" && - { test "$use_static_libs" = no || test -z "$old_library"; }; then - case $host in - *cygwin* | *mingw* | *cegcc*) - # No point in relinking DLLs because paths are not encoded - notinst_deplibs="$notinst_deplibs $lib" - need_relink=no - ;; - *) - if test "$installed" = no; then - notinst_deplibs="$notinst_deplibs $lib" - need_relink=yes - fi - ;; - esac - # This is a shared library - - # Warn about portability, can't link against -module's on some - # systems (darwin). Don't bleat about dlopened modules though! - dlopenmodule="" - for dlpremoduletest in $dlprefiles; do - if test "X$dlpremoduletest" = "X$lib"; then - dlopenmodule="$dlpremoduletest" - break - fi - done - if test -z "$dlopenmodule" && test "$shouldnotlink" = yes && test "$pass" = link; then - $ECHO - if test "$linkmode" = prog; then - $ECHO "*** Warning: Linking the executable $output against the loadable module" - else - $ECHO "*** Warning: Linking the shared library $output against the loadable module" - fi - $ECHO "*** $linklib is not portable!" - fi - if test "$linkmode" = lib && - test "$hardcode_into_libs" = yes; then - # Hardcode the library path. - # Skip directories that are in the system default run-time - # search path. - case " $sys_lib_dlsearch_path " in - *" $absdir "*) ;; - *) - case "$compile_rpath " in - *" $absdir "*) ;; - *) compile_rpath="$compile_rpath $absdir" - esac - ;; - esac - case " $sys_lib_dlsearch_path " in - *" $libdir "*) ;; - *) - case "$finalize_rpath " in - *" $libdir "*) ;; - *) finalize_rpath="$finalize_rpath $libdir" - esac - ;; - esac - fi - - if test -n "$old_archive_from_expsyms_cmds"; then - # figure out the soname - set dummy $library_names - shift - realname="$1" - shift - libname=`eval "\\$ECHO \"$libname_spec\""` - # use dlname if we got it. it's perfectly good, no? - if test -n "$dlname"; then - soname="$dlname" - elif test -n "$soname_spec"; then - # bleh windows - case $host in - *cygwin* | mingw* | *cegcc*) - func_arith $current - $age - major=$func_arith_result - versuffix="-$major" - ;; - esac - eval soname=\"$soname_spec\" - else - soname="$realname" - fi - - # Make a new name for the extract_expsyms_cmds to use - soroot="$soname" - func_basename "$soroot" - soname="$func_basename_result" - func_stripname 'lib' '.dll' "$soname" - newlib=libimp-$func_stripname_result.a - - # If the library has no export list, then create one now - if test -f "$output_objdir/$soname-def"; then : - else - func_verbose "extracting exported symbol list from \`$soname'" - func_execute_cmds "$extract_expsyms_cmds" 'exit $?' - fi - - # Create $newlib - if test -f "$output_objdir/$newlib"; then :; else - func_verbose "generating import library for \`$soname'" - func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' - fi - # make sure the library variables are pointing to the new library - dir=$output_objdir - linklib=$newlib - fi # test -n "$old_archive_from_expsyms_cmds" - - if test "$linkmode" = prog || test "$mode" != relink; then - add_shlibpath= - add_dir= - add= - lib_linked=yes - case $hardcode_action in - immediate | unsupported) - if test "$hardcode_direct" = no; then - add="$dir/$linklib" - case $host in - *-*-sco3.2v5.0.[024]*) add_dir="-L$dir" ;; - *-*-sysv4*uw2*) add_dir="-L$dir" ;; - *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ - *-*-unixware7*) add_dir="-L$dir" ;; - *-*-darwin* ) - # if the lib is a (non-dlopened) module then we can not - # link against it, someone is ignoring the earlier warnings - if /usr/bin/file -L $add 2> /dev/null | - $GREP ": [^:]* bundle" >/dev/null ; then - if test "X$dlopenmodule" != "X$lib"; then - $ECHO "*** Warning: lib $linklib is a module, not a shared library" - if test -z "$old_library" ; then - $ECHO - $ECHO "*** And there doesn't seem to be a static archive available" - $ECHO "*** The link will probably fail, sorry" - else - add="$dir/$old_library" - fi - elif test -n "$old_library"; then - add="$dir/$old_library" - fi - fi - esac - elif test "$hardcode_minus_L" = no; then - case $host in - *-*-sunos*) add_shlibpath="$dir" ;; - esac - add_dir="-L$dir" - add="-l$name" - elif test "$hardcode_shlibpath_var" = no; then - add_shlibpath="$dir" - add="-l$name" - else - lib_linked=no - fi - ;; - relink) - if test "$hardcode_direct" = yes && - test "$hardcode_direct_absolute" = no; then - add="$dir/$linklib" - elif test "$hardcode_minus_L" = yes; then - add_dir="-L$dir" - # Try looking first in the location we're being installed to. - if test -n "$inst_prefix_dir"; then - case $libdir in - [\\/]*) - add_dir="$add_dir -L$inst_prefix_dir$libdir" - ;; - esac - fi - add="-l$name" - elif test "$hardcode_shlibpath_var" = yes; then - add_shlibpath="$dir" - add="-l$name" - else - lib_linked=no - fi - ;; - *) lib_linked=no ;; - esac - - if test "$lib_linked" != yes; then - func_fatal_configuration "unsupported hardcode properties" - fi - - if test -n "$add_shlibpath"; then - case :$compile_shlibpath: in - *":$add_shlibpath:"*) ;; - *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;; - esac - fi - if test "$linkmode" = prog; then - test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" - test -n "$add" && compile_deplibs="$add $compile_deplibs" - else - test -n "$add_dir" && deplibs="$add_dir $deplibs" - test -n "$add" && deplibs="$add $deplibs" - if test "$hardcode_direct" != yes && - test "$hardcode_minus_L" != yes && - test "$hardcode_shlibpath_var" = yes; then - case :$finalize_shlibpath: in - *":$libdir:"*) ;; - *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; - esac - fi - fi - fi - - if test "$linkmode" = prog || test "$mode" = relink; then - add_shlibpath= - add_dir= - add= - # Finalize command for both is simple: just hardcode it. - if test "$hardcode_direct" = yes && - test "$hardcode_direct_absolute" = no; then - add="$libdir/$linklib" - elif test "$hardcode_minus_L" = yes; then - add_dir="-L$libdir" - add="-l$name" - elif test "$hardcode_shlibpath_var" = yes; then - case :$finalize_shlibpath: in - *":$libdir:"*) ;; - *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; - esac - add="-l$name" - elif test "$hardcode_automatic" = yes; then - if test -n "$inst_prefix_dir" && - test -f "$inst_prefix_dir$libdir/$linklib" ; then - add="$inst_prefix_dir$libdir/$linklib" - else - add="$libdir/$linklib" - fi - else - # We cannot seem to hardcode it, guess we'll fake it. - add_dir="-L$libdir" - # Try looking first in the location we're being installed to. - if test -n "$inst_prefix_dir"; then - case $libdir in - [\\/]*) - add_dir="$add_dir -L$inst_prefix_dir$libdir" - ;; - esac - fi - add="-l$name" - fi - - if test "$linkmode" = prog; then - test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" - test -n "$add" && finalize_deplibs="$add $finalize_deplibs" - else - test -n "$add_dir" && deplibs="$add_dir $deplibs" - test -n "$add" && deplibs="$add $deplibs" - fi - fi - elif test "$linkmode" = prog; then - # Here we assume that one of hardcode_direct or hardcode_minus_L - # is not unsupported. This is valid on all known static and - # shared platforms. - if test "$hardcode_direct" != unsupported; then - test -n "$old_library" && linklib="$old_library" - compile_deplibs="$dir/$linklib $compile_deplibs" - finalize_deplibs="$dir/$linklib $finalize_deplibs" - else - compile_deplibs="-l$name -L$dir $compile_deplibs" - finalize_deplibs="-l$name -L$dir $finalize_deplibs" - fi - elif test "$build_libtool_libs" = yes; then - # Not a shared library - if test "$deplibs_check_method" != pass_all; then - # We're trying link a shared library against a static one - # but the system doesn't support it. - - # Just print a warning and add the library to dependency_libs so - # that the program can be linked against the static library. - $ECHO - $ECHO "*** Warning: This system can not link to static lib archive $lib." - $ECHO "*** I have the capability to make that library automatically link in when" - $ECHO "*** you link to this library. But I can only do this if you have a" - $ECHO "*** shared version of the library, which you do not appear to have." - if test "$module" = yes; then - $ECHO "*** But as you try to build a module library, libtool will still create " - $ECHO "*** a static module, that should work as long as the dlopening application" - $ECHO "*** is linked with the -dlopen flag to resolve symbols at runtime." - if test -z "$global_symbol_pipe"; then - $ECHO - $ECHO "*** However, this would only work if libtool was able to extract symbol" - $ECHO "*** lists from a program, using \`nm' or equivalent, but libtool could" - $ECHO "*** not find such a program. So, this module is probably useless." - $ECHO "*** \`nm' from GNU binutils and a full rebuild may help." - fi - if test "$build_old_libs" = no; then - build_libtool_libs=module - build_old_libs=yes - else - build_libtool_libs=no - fi - fi - else - deplibs="$dir/$old_library $deplibs" - link_static=yes - fi - fi # link shared/static library? - - if test "$linkmode" = lib; then - if test -n "$dependency_libs" && - { test "$hardcode_into_libs" != yes || - test "$build_old_libs" = yes || - test "$link_static" = yes; }; then - # Extract -R from dependency_libs - temp_deplibs= - for libdir in $dependency_libs; do - case $libdir in - -R*) func_stripname '-R' '' "$libdir" - temp_xrpath=$func_stripname_result - case " $xrpath " in - *" $temp_xrpath "*) ;; - *) xrpath="$xrpath $temp_xrpath";; - esac;; - *) temp_deplibs="$temp_deplibs $libdir";; - esac - done - dependency_libs="$temp_deplibs" - fi - - newlib_search_path="$newlib_search_path $absdir" - # Link against this library - test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs" - # ... and its dependency_libs - tmp_libs= - for deplib in $dependency_libs; do - newdependency_libs="$deplib $newdependency_libs" - if $opt_duplicate_deps ; then - case "$tmp_libs " in - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; - esac - fi - tmp_libs="$tmp_libs $deplib" - done - - if test "$link_all_deplibs" != no; then - # Add the search paths of all dependency libraries - for deplib in $dependency_libs; do - path= - case $deplib in - -L*) path="$deplib" ;; - *.la) - func_dirname "$deplib" "" "." - dir="$func_dirname_result" - # We need an absolute path. - case $dir in - [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;; - *) - absdir=`cd "$dir" && pwd` - if test -z "$absdir"; then - func_warning "cannot determine absolute directory name of \`$dir'" - absdir="$dir" - fi - ;; - esac - if $GREP "^installed=no" $deplib > /dev/null; then - case $host in - *-*-darwin*) - depdepl= - eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` - if test -n "$deplibrary_names" ; then - for tmp in $deplibrary_names ; do - depdepl=$tmp - done - if test -f "$absdir/$objdir/$depdepl" ; then - depdepl="$absdir/$objdir/$depdepl" - darwin_install_name=`${OTOOL} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` - if test -z "$darwin_install_name"; then - darwin_install_name=`${OTOOL64} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` - fi - compiler_flags="$compiler_flags ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}" - linker_flags="$linker_flags -dylib_file ${darwin_install_name}:${depdepl}" - path= - fi - fi - ;; - *) - path="-L$absdir/$objdir" - ;; - esac - else - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` - test -z "$libdir" && \ - func_fatal_error "\`$deplib' is not a valid libtool archive" - test "$absdir" != "$libdir" && \ - func_warning "\`$deplib' seems to be moved" - - path="-L$absdir" - fi - ;; - esac - case " $deplibs " in - *" $path "*) ;; - *) deplibs="$path $deplibs" ;; - esac - done - fi # link_all_deplibs != no - fi # linkmode = lib - done # for deplib in $libs - if test "$pass" = link; then - if test "$linkmode" = "prog"; then - compile_deplibs="$new_inherited_linker_flags $compile_deplibs" - finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" - else - compiler_flags="$compiler_flags "`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` - fi - fi - dependency_libs="$newdependency_libs" - if test "$pass" = dlpreopen; then - # Link the dlpreopened libraries before other libraries - for deplib in $save_deplibs; do - deplibs="$deplib $deplibs" - done - fi - if test "$pass" != dlopen; then - if test "$pass" != conv; then - # Make sure lib_search_path contains only unique directories. - lib_search_path= - for dir in $newlib_search_path; do - case "$lib_search_path " in - *" $dir "*) ;; - *) lib_search_path="$lib_search_path $dir" ;; - esac - done - newlib_search_path= - fi - - if test "$linkmode,$pass" != "prog,link"; then - vars="deplibs" - else - vars="compile_deplibs finalize_deplibs" - fi - for var in $vars dependency_libs; do - # Add libraries to $var in reverse order - eval tmp_libs=\"\$$var\" - new_libs= - for deplib in $tmp_libs; do - # FIXME: Pedantically, this is the right thing to do, so - # that some nasty dependency loop isn't accidentally - # broken: - #new_libs="$deplib $new_libs" - # Pragmatically, this seems to cause very few problems in - # practice: - case $deplib in - -L*) new_libs="$deplib $new_libs" ;; - -R*) ;; - *) - # And here is the reason: when a library appears more - # than once as an explicit dependence of a library, or - # is implicitly linked in more than once by the - # compiler, it is considered special, and multiple - # occurrences thereof are not removed. Compare this - # with having the same library being listed as a - # dependency of multiple other libraries: in this case, - # we know (pedantically, we assume) the library does not - # need to be listed more than once, so we keep only the - # last copy. This is not always right, but it is rare - # enough that we require users that really mean to play - # such unportable linking tricks to link the library - # using -Wl,-lname, so that libtool does not consider it - # for duplicate removal. - case " $specialdeplibs " in - *" $deplib "*) new_libs="$deplib $new_libs" ;; - *) - case " $new_libs " in - *" $deplib "*) ;; - *) new_libs="$deplib $new_libs" ;; - esac - ;; - esac - ;; - esac - done - tmp_libs= - for deplib in $new_libs; do - case $deplib in - -L*) - case " $tmp_libs " in - *" $deplib "*) ;; - *) tmp_libs="$tmp_libs $deplib" ;; - esac - ;; - *) tmp_libs="$tmp_libs $deplib" ;; - esac - done - eval $var=\"$tmp_libs\" - done # for var - fi - # Last step: remove runtime libs from dependency_libs - # (they stay in deplibs) - tmp_libs= - for i in $dependency_libs ; do - case " $predeps $postdeps $compiler_lib_search_path " in - *" $i "*) - i="" - ;; - esac - if test -n "$i" ; then - tmp_libs="$tmp_libs $i" - fi - done - dependency_libs=$tmp_libs - done # for pass - if test "$linkmode" = prog; then - dlfiles="$newdlfiles" - fi - if test "$linkmode" = prog || test "$linkmode" = lib; then - dlprefiles="$newdlprefiles" - fi - - case $linkmode in - oldlib) - if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then - func_warning "\`-dlopen' is ignored for archives" - fi - - case " $deplibs" in - *\ -l* | *\ -L*) - func_warning "\`-l' and \`-L' are ignored for archives" ;; - esac - - test -n "$rpath" && \ - func_warning "\`-rpath' is ignored for archives" - - test -n "$xrpath" && \ - func_warning "\`-R' is ignored for archives" - - test -n "$vinfo" && \ - func_warning "\`-version-info/-version-number' is ignored for archives" - - test -n "$release" && \ - func_warning "\`-release' is ignored for archives" - - test -n "$export_symbols$export_symbols_regex" && \ - func_warning "\`-export-symbols' is ignored for archives" - - # Now set the variables for building old libraries. - build_libtool_libs=no - oldlibs="$output" - objs="$objs$old_deplibs" - ;; - - lib) - # Make sure we only generate libraries of the form `libNAME.la'. - case $outputname in - lib*) - func_stripname 'lib' '.la' "$outputname" - name=$func_stripname_result - eval shared_ext=\"$shrext_cmds\" - eval libname=\"$libname_spec\" - ;; - *) - test "$module" = no && \ - func_fatal_help "libtool library \`$output' must begin with \`lib'" - - if test "$need_lib_prefix" != no; then - # Add the "lib" prefix for modules if required - func_stripname '' '.la' "$outputname" - name=$func_stripname_result - eval shared_ext=\"$shrext_cmds\" - eval libname=\"$libname_spec\" - else - func_stripname '' '.la' "$outputname" - libname=$func_stripname_result - fi - ;; - esac - - if test -n "$objs"; then - if test "$deplibs_check_method" != pass_all; then - func_fatal_error "cannot build libtool library \`$output' from non-libtool objects on this host:$objs" - else - $ECHO - $ECHO "*** Warning: Linking the shared library $output against the non-libtool" - $ECHO "*** objects $objs is not portable!" - libobjs="$libobjs $objs" - fi - fi - - test "$dlself" != no && \ - func_warning "\`-dlopen self' is ignored for libtool libraries" - - set dummy $rpath - shift - test "$#" -gt 1 && \ - func_warning "ignoring multiple \`-rpath's for a libtool library" - - install_libdir="$1" - - oldlibs= - if test -z "$rpath"; then - if test "$build_libtool_libs" = yes; then - # Building a libtool convenience library. - # Some compilers have problems with a `.al' extension so - # convenience libraries should have the same extension an - # archive normally would. - oldlibs="$output_objdir/$libname.$libext $oldlibs" - build_libtool_libs=convenience - build_old_libs=yes - fi - - test -n "$vinfo" && \ - func_warning "\`-version-info/-version-number' is ignored for convenience libraries" - - test -n "$release" && \ - func_warning "\`-release' is ignored for convenience libraries" - else - - # Parse the version information argument. - save_ifs="$IFS"; IFS=':' - set dummy $vinfo 0 0 0 - shift - IFS="$save_ifs" - - test -n "$7" && \ - func_fatal_help "too many parameters to \`-version-info'" - - # convert absolute version numbers to libtool ages - # this retains compatibility with .la files and attempts - # to make the code below a bit more comprehensible - - case $vinfo_number in - yes) - number_major="$1" - number_minor="$2" - number_revision="$3" - # - # There are really only two kinds -- those that - # use the current revision as the major version - # and those that subtract age and use age as - # a minor version. But, then there is irix - # which has an extra 1 added just for fun - # - case $version_type in - darwin|linux|osf|windows|none) - func_arith $number_major + $number_minor - current=$func_arith_result - age="$number_minor" - revision="$number_revision" - ;; - freebsd-aout|freebsd-elf|sunos) - current="$number_major" - revision="$number_minor" - age="0" - ;; - irix|nonstopux) - func_arith $number_major + $number_minor - current=$func_arith_result - age="$number_minor" - revision="$number_minor" - lt_irix_increment=no - ;; - *) - func_fatal_configuration "$modename: unknown library version type \`$version_type'" - ;; - esac - ;; - no) - current="$1" - revision="$2" - age="$3" - ;; - esac - - # Check that each of the things are valid numbers. - case $current in - 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; - *) - func_error "CURRENT \`$current' must be a nonnegative integer" - func_fatal_error "\`$vinfo' is not valid version information" - ;; - esac - - case $revision in - 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; - *) - func_error "REVISION \`$revision' must be a nonnegative integer" - func_fatal_error "\`$vinfo' is not valid version information" - ;; - esac - - case $age in - 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; - *) - func_error "AGE \`$age' must be a nonnegative integer" - func_fatal_error "\`$vinfo' is not valid version information" - ;; - esac - - if test "$age" -gt "$current"; then - func_error "AGE \`$age' is greater than the current interface number \`$current'" - func_fatal_error "\`$vinfo' is not valid version information" - fi - - # Calculate the version variables. - major= - versuffix= - verstring= - case $version_type in - none) ;; - - darwin) - # Like Linux, but with the current version available in - # verstring for coding it into the library header - func_arith $current - $age - major=.$func_arith_result - versuffix="$major.$age.$revision" - # Darwin ld doesn't like 0 for these options... - func_arith $current + 1 - minor_current=$func_arith_result - xlcverstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision" - verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" - ;; - - freebsd-aout) - major=".$current" - versuffix=".$current.$revision"; - ;; - - freebsd-elf) - major=".$current" - versuffix=".$current" - ;; - - irix | nonstopux) - if test "X$lt_irix_increment" = "Xno"; then - func_arith $current - $age - else - func_arith $current - $age + 1 - fi - major=$func_arith_result - - case $version_type in - nonstopux) verstring_prefix=nonstopux ;; - *) verstring_prefix=sgi ;; - esac - verstring="$verstring_prefix$major.$revision" - - # Add in all the interfaces that we are compatible with. - loop=$revision - while test "$loop" -ne 0; do - func_arith $revision - $loop - iface=$func_arith_result - func_arith $loop - 1 - loop=$func_arith_result - verstring="$verstring_prefix$major.$iface:$verstring" - done - - # Before this point, $major must not contain `.'. - major=.$major - versuffix="$major.$revision" - ;; - - linux) - func_arith $current - $age - major=.$func_arith_result - versuffix="$major.$age.$revision" - ;; - - osf) - func_arith $current - $age - major=.$func_arith_result - versuffix=".$current.$age.$revision" - verstring="$current.$age.$revision" - - # Add in all the interfaces that we are compatible with. - loop=$age - while test "$loop" -ne 0; do - func_arith $current - $loop - iface=$func_arith_result - func_arith $loop - 1 - loop=$func_arith_result - verstring="$verstring:${iface}.0" - done - - # Make executables depend on our current version. - verstring="$verstring:${current}.0" - ;; - - qnx) - major=".$current" - versuffix=".$current" - ;; - - sunos) - major=".$current" - versuffix=".$current.$revision" - ;; - - windows) - # Use '-' rather than '.', since we only want one - # extension on DOS 8.3 filesystems. - func_arith $current - $age - major=$func_arith_result - versuffix="-$major" - ;; - - *) - func_fatal_configuration "unknown library version type \`$version_type'" - ;; - esac - - # Clear the version info if we defaulted, and they specified a release. - if test -z "$vinfo" && test -n "$release"; then - major= - case $version_type in - darwin) - # we can't check for "0.0" in archive_cmds due to quoting - # problems, so we reset it completely - verstring= - ;; - *) - verstring="0.0" - ;; - esac - if test "$need_version" = no; then - versuffix= - else - versuffix=".0.0" - fi - fi - - # Remove version info from name if versioning should be avoided - if test "$avoid_version" = yes && test "$need_version" = no; then - major= - versuffix= - verstring="" - fi - - # Check to see if the archive will have undefined symbols. - if test "$allow_undefined" = yes; then - if test "$allow_undefined_flag" = unsupported; then - func_warning "undefined symbols not allowed in $host shared libraries" - build_libtool_libs=no - build_old_libs=yes - fi - else - # Don't allow undefined symbols. - allow_undefined_flag="$no_undefined_flag" - fi - - fi - - func_generate_dlsyms "$libname" "$libname" "yes" - libobjs="$libobjs $symfileobj" - test "X$libobjs" = "X " && libobjs= - - if test "$mode" != relink; then - # Remove our outputs, but don't remove object files since they - # may have been created when compiling PIC objects. - removelist= - tempremovelist=`$ECHO "$output_objdir/*"` - for p in $tempremovelist; do - case $p in - *.$objext | *.gcno) - ;; - $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*) - if test "X$precious_files_regex" != "X"; then - if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 - then - continue - fi - fi - removelist="$removelist $p" - ;; - *) ;; - esac - done - test -n "$removelist" && \ - func_show_eval "${RM}r \$removelist" - fi - - # Now set the variables for building old libraries. - if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then - oldlibs="$oldlibs $output_objdir/$libname.$libext" - - # Transform .lo files to .o files. - oldobjs="$objs "`$ECHO "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP` - fi - - # Eliminate all temporary directories. - #for path in $notinst_path; do - # lib_search_path=`$ECHO "X$lib_search_path " | $Xsed -e "s% $path % %g"` - # deplibs=`$ECHO "X$deplibs " | $Xsed -e "s% -L$path % %g"` - # dependency_libs=`$ECHO "X$dependency_libs " | $Xsed -e "s% -L$path % %g"` - #done - - if test -n "$xrpath"; then - # If the user specified any rpath flags, then add them. - temp_xrpath= - for libdir in $xrpath; do - temp_xrpath="$temp_xrpath -R$libdir" - case "$finalize_rpath " in - *" $libdir "*) ;; - *) finalize_rpath="$finalize_rpath $libdir" ;; - esac - done - if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then - dependency_libs="$temp_xrpath $dependency_libs" - fi - fi - - # Make sure dlfiles contains only unique files that won't be dlpreopened - old_dlfiles="$dlfiles" - dlfiles= - for lib in $old_dlfiles; do - case " $dlprefiles $dlfiles " in - *" $lib "*) ;; - *) dlfiles="$dlfiles $lib" ;; - esac - done - - # Make sure dlprefiles contains only unique files - old_dlprefiles="$dlprefiles" - dlprefiles= - for lib in $old_dlprefiles; do - case "$dlprefiles " in - *" $lib "*) ;; - *) dlprefiles="$dlprefiles $lib" ;; - esac - done - - if test "$build_libtool_libs" = yes; then - if test -n "$rpath"; then - case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc*) - # these systems don't actually have a c library (as such)! - ;; - *-*-rhapsody* | *-*-darwin1.[012]) - # Rhapsody C library is in the System framework - deplibs="$deplibs System.ltframework" - ;; - *-*-netbsd*) - # Don't link with libc until the a.out ld.so is fixed. - ;; - *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) - # Do not include libc due to us having libc/libc_r. - ;; - *-*-sco3.2v5* | *-*-sco5v6*) - # Causes problems with __ctype - ;; - *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) - # Compiler inserts libc in the correct place for threads to work - ;; - *) - # Add libc to deplibs on all other systems if necessary. - if test "$build_libtool_need_lc" = "yes"; then - deplibs="$deplibs -lc" - fi - ;; - esac - fi - - # Transform deplibs into only deplibs that can be linked in shared. - name_save=$name - libname_save=$libname - release_save=$release - versuffix_save=$versuffix - major_save=$major - # I'm not sure if I'm treating the release correctly. I think - # release should show up in the -l (ie -lgmp5) so we don't want to - # add it in twice. Is that correct? - release="" - versuffix="" - major="" - newdeplibs= - droppeddeps=no - case $deplibs_check_method in - pass_all) - # Don't check for shared/static. Everything works. - # This might be a little naive. We might want to check - # whether the library exists or not. But this is on - # osf3 & osf4 and I'm not really sure... Just - # implementing what was already the behavior. - newdeplibs=$deplibs - ;; - test_compile) - # This code stresses the "libraries are programs" paradigm to its - # limits. Maybe even breaks it. We compile a program, linking it - # against the deplibs as a proxy for the library. Then we can check - # whether they linked in statically or dynamically with ldd. - $opt_dry_run || $RM conftest.c - cat > conftest.c </dev/null` - for potent_lib in $potential_libs; do - # Follow soft links. - if ls -lLd "$potent_lib" 2>/dev/null | - $GREP " -> " >/dev/null; then - continue - fi - # The statement above tries to avoid entering an - # endless loop below, in case of cyclic links. - # We might still enter an endless loop, since a link - # loop can be closed while we follow links, - # but so what? - potlib="$potent_lib" - while test -h "$potlib" 2>/dev/null; do - potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'` - case $potliblink in - [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";; - *) potlib=`$ECHO "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";; - esac - done - if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | - $SED -e 10q | - $EGREP "$file_magic_regex" > /dev/null; then - newdeplibs="$newdeplibs $a_deplib" - a_deplib="" - break 2 - fi - done - done - fi - if test -n "$a_deplib" ; then - droppeddeps=yes - $ECHO - $ECHO "*** Warning: linker path does not have real file for library $a_deplib." - $ECHO "*** I have the capability to make that library automatically link in when" - $ECHO "*** you link to this library. But I can only do this if you have a" - $ECHO "*** shared version of the library, which you do not appear to have" - $ECHO "*** because I did check the linker path looking for a file starting" - if test -z "$potlib" ; then - $ECHO "*** with $libname but no candidates were found. (...for file magic test)" - else - $ECHO "*** with $libname and none of the candidates passed a file format test" - $ECHO "*** using a file magic. Last file checked: $potlib" - fi - fi - ;; - *) - # Add a -L argument. - newdeplibs="$newdeplibs $a_deplib" - ;; - esac - done # Gone through all deplibs. - ;; - match_pattern*) - set dummy $deplibs_check_method; shift - match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` - for a_deplib in $deplibs; do - case $a_deplib in - -l*) - func_stripname -l '' "$a_deplib" - name=$func_stripname_result - if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then - case " $predeps $postdeps " in - *" $a_deplib "*) - newdeplibs="$newdeplibs $a_deplib" - a_deplib="" - ;; - esac - fi - if test -n "$a_deplib" ; then - libname=`eval "\\$ECHO \"$libname_spec\""` - for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do - potential_libs=`ls $i/$libname[.-]* 2>/dev/null` - for potent_lib in $potential_libs; do - potlib="$potent_lib" # see symlink-check above in file_magic test - if eval "\$ECHO \"X$potent_lib\"" 2>/dev/null | $Xsed -e 10q | \ - $EGREP "$match_pattern_regex" > /dev/null; then - newdeplibs="$newdeplibs $a_deplib" - a_deplib="" - break 2 - fi - done - done - fi - if test -n "$a_deplib" ; then - droppeddeps=yes - $ECHO - $ECHO "*** Warning: linker path does not have real file for library $a_deplib." - $ECHO "*** I have the capability to make that library automatically link in when" - $ECHO "*** you link to this library. But I can only do this if you have a" - $ECHO "*** shared version of the library, which you do not appear to have" - $ECHO "*** because I did check the linker path looking for a file starting" - if test -z "$potlib" ; then - $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" - else - $ECHO "*** with $libname and none of the candidates passed a file format test" - $ECHO "*** using a regex pattern. Last file checked: $potlib" - fi - fi - ;; - *) - # Add a -L argument. - newdeplibs="$newdeplibs $a_deplib" - ;; - esac - done # Gone through all deplibs. - ;; - none | unknown | *) - newdeplibs="" - tmp_deplibs=`$ECHO "X $deplibs" | $Xsed \ - -e 's/ -lc$//' -e 's/ -[LR][^ ]*//g'` - if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then - for i in $predeps $postdeps ; do - # can't use Xsed below, because $i might contain '/' - tmp_deplibs=`$ECHO "X $tmp_deplibs" | $Xsed -e "s,$i,,"` - done - fi - if $ECHO "X $tmp_deplibs" | $Xsed -e 's/[ ]//g' | - $GREP . >/dev/null; then - $ECHO - if test "X$deplibs_check_method" = "Xnone"; then - $ECHO "*** Warning: inter-library dependencies are not supported in this platform." - else - $ECHO "*** Warning: inter-library dependencies are not known to be supported." - fi - $ECHO "*** All declared inter-library dependencies are being dropped." - droppeddeps=yes - fi - ;; - esac - versuffix=$versuffix_save - major=$major_save - release=$release_save - libname=$libname_save - name=$name_save +# $output - temporary wrapper script for $objdir/$outputname +# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP +# +# The $output program cannot be directly executed until all the libtool +# libraries that it depends on are installed. +# +# This wrapper script should never be moved out of the build directory. +# If it is, it will not operate correctly. - case $host in - *-*-rhapsody* | *-*-darwin1.[012]) - # On Rhapsody replace the C library with the System framework - newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's/ -lc / System.ltframework /'` - ;; - esac +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed='${SED} -e 1s/^X//' +sed_quote_subst='$sed_quote_subst' - if test "$droppeddeps" = yes; then - if test "$module" = yes; then - $ECHO - $ECHO "*** Warning: libtool could not satisfy all declared inter-library" - $ECHO "*** dependencies of module $libname. Therefore, libtool will create" - $ECHO "*** a static module, that should work as long as the dlopening" - $ECHO "*** application is linked with the -dlopen flag." - if test -z "$global_symbol_pipe"; then - $ECHO - $ECHO "*** However, this would only work if libtool was able to extract symbol" - $ECHO "*** lists from a program, using \`nm' or equivalent, but libtool could" - $ECHO "*** not find such a program. So, this module is probably useless." - $ECHO "*** \`nm' from GNU binutils and a full rebuild may help." - fi - if test "$build_old_libs" = no; then - oldlibs="$output_objdir/$libname.$libext" - build_libtool_libs=module - build_old_libs=yes - else - build_libtool_libs=no - fi - else - $ECHO "*** The inter-library dependencies that have been dropped here will be" - $ECHO "*** automatically added whenever a program is linked with this library" - $ECHO "*** or is declared to -dlopen it." +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +if test \"\${CDPATH+set}\" = set; then CDPATH=:; export CDPATH; fi - if test "$allow_undefined" = no; then - $ECHO - $ECHO "*** Since this library must not contain undefined symbols," - $ECHO "*** because either the platform does not support them or" - $ECHO "*** it was explicitly requested with -no-undefined," - $ECHO "*** libtool will only create a static version of it." - if test "$build_old_libs" = no; then - oldlibs="$output_objdir/$libname.$libext" - build_libtool_libs=module - build_old_libs=yes - else - build_libtool_libs=no - fi - fi - fi - fi - # Done checking deplibs! - deplibs=$newdeplibs - fi - # Time to change all our "foo.ltframework" stuff back to "-framework foo" - case $host in - *-*-darwin*) - newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` - new_inherited_linker_flags=`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` - deplibs=`$ECHO "X $deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` - ;; +relink_command=\"$relink_command\" + +# This environment variable determines our operation mode. +if test \"\$libtool_install_magic\" = \"$magic\"; then + # install mode needs the following variable: + notinst_deplibs='$notinst_deplibs' +else + # When we are sourced in execute mode, \$file and \$echo are already set. + if test \"\$libtool_execute_magic\" != \"$magic\"; then + echo=\"$qecho\" + file=\"\$0\" + # Make sure echo works. + if test \"X\$1\" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift + elif test \"X\`(\$echo '\t') 2>/dev/null\`\" = 'X\t'; then + # Yippee, \$echo works! + : + else + # Restart under the correct shell, and then maybe \$echo will work. + exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"} + fi + fi\ +" + $echo >> $output "\ + + # Find the directory that this script lives in. + thisdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\` + test \"x\$thisdir\" = \"x\$file\" && thisdir=. + + # Follow symbolic links until we get to the real thisdir. + file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\` + while test -n \"\$file\"; do + destdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\` + + # If there was a directory component, then change thisdir. + if test \"x\$destdir\" != \"x\$file\"; then + case \"\$destdir\" in + [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; + *) thisdir=\"\$thisdir/\$destdir\" ;; esac + fi - # move library search paths that coincide with paths to not yet - # installed libraries to the beginning of the library search list - new_libs= - for path in $notinst_path; do - case " $new_libs " in - *" -L$path/$objdir "*) ;; - *) - case " $deplibs " in - *" -L$path/$objdir "*) - new_libs="$new_libs -L$path/$objdir" ;; - esac - ;; - esac - done - for deplib in $deplibs; do - case $deplib in - -L*) - case " $new_libs " in - *" $deplib "*) ;; - *) new_libs="$new_libs $deplib" ;; - esac - ;; - *) new_libs="$new_libs $deplib" ;; - esac - done - deplibs="$new_libs" + file=\`\$echo \"X\$file\" | \$Xsed -e 's%^.*/%%'\` + file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\` + done - # All the library-specific variables (install_libdir is set above). - library_names= - old_library= - dlname= + # Try to get the absolute directory name. + absdir=\`cd \"\$thisdir\" && pwd\` + test -n \"\$absdir\" && thisdir=\"\$absdir\" +" - # Test again, we may have decided not to build it any more - if test "$build_libtool_libs" = yes; then - if test "$hardcode_into_libs" = yes; then - # Hardcode the library paths - hardcode_libdirs= - dep_rpath= - rpath="$finalize_rpath" - test "$mode" != relink && rpath="$compile_rpath$rpath" - for libdir in $rpath; do - if test -n "$hardcode_libdir_flag_spec"; then - if test -n "$hardcode_libdir_separator"; then - if test -z "$hardcode_libdirs"; then - hardcode_libdirs="$libdir" - else - # Just accumulate the unique libdirs. - case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in - *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) - ;; - *) - hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" - ;; - esac - fi - else - eval flag=\"$hardcode_libdir_flag_spec\" - dep_rpath="$dep_rpath $flag" - fi - elif test -n "$runpath_var"; then - case "$perm_rpath " in - *" $libdir "*) ;; - *) perm_rpath="$perm_rpath $libdir" ;; - esac - fi - done - # Substitute the hardcoded libdirs into the rpath. - if test -n "$hardcode_libdir_separator" && - test -n "$hardcode_libdirs"; then - libdir="$hardcode_libdirs" - if test -n "$hardcode_libdir_flag_spec_ld"; then - eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\" - else - eval dep_rpath=\"$hardcode_libdir_flag_spec\" - fi - fi - if test -n "$runpath_var" && test -n "$perm_rpath"; then - # We should set the runpath_var. - rpath= - for dir in $perm_rpath; do - rpath="$rpath$dir:" - done - eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" - fi - test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" - fi + if test "$fast_install" = yes; then + $echo >> $output "\ + program=lt-'$outputname'$exeext + progdir=\"\$thisdir/$objdir\" - shlibpath="$finalize_shlibpath" - test "$mode" != relink && shlibpath="$compile_shlibpath$shlibpath" - if test -n "$shlibpath"; then - eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" - fi + if test ! -f \"\$progdir/\$program\" || \\ + { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\ + test \"X\$file\" != \"X\$progdir/\$program\"; }; then - # Get the real and link names of the library. - eval shared_ext=\"$shrext_cmds\" - eval library_names=\"$library_names_spec\" - set dummy $library_names - shift - realname="$1" - shift + file=\"\$\$-\$program\" - if test -n "$soname_spec"; then - eval soname=\"$soname_spec\" + if test ! -d \"\$progdir\"; then + $mkdir \"\$progdir\" + else + $rm \"\$progdir/\$file\" + fi" + + $echo >> $output "\ + + # relink executable if necessary + if test -n \"\$relink_command\"; then + if relink_command_output=\`eval \$relink_command 2>&1\`; then : + else + $echo \"\$relink_command_output\" >&2 + $rm \"\$progdir/\$file\" + exit $EXIT_FAILURE + fi + fi + + $mv \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || + { $rm \"\$progdir/\$program\"; + $mv \"\$progdir/\$file\" \"\$progdir/\$program\"; } + $rm \"\$progdir/\$file\" + fi" else - soname="$realname" + $echo >> $output "\ + program='$outputname' + progdir=\"\$thisdir/$objdir\" +" fi - if test -z "$dlname"; then - dlname=$soname + + $echo >> $output "\ + + if test -f \"\$progdir/\$program\"; then" + + # Export our shlibpath_var if we have one. + if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then + $echo >> $output "\ + # Add our own library path to $shlibpath_var + $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" + + # Some systems cannot cope with colon-terminated $shlibpath_var + # The second colon is a workaround for a bug in BeOS R4 sed + $shlibpath_var=\`\$echo \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\` + + export $shlibpath_var +" fi - lib="$output_objdir/$realname" - linknames= - for link - do - linknames="$linknames $link" - done + # fixup the dll searchpath if we need to. + if test -n "$dllsearchpath"; then + $echo >> $output "\ + # Add the dll search path components to the executable PATH + PATH=$dllsearchpath:\$PATH +" + fi - # Use standard objects if they are pic - test -z "$pic_flag" && libobjs=`$ECHO "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` - test "X$libobjs" = "X " && libobjs= + $echo >> $output "\ + if test \"\$libtool_execute_magic\" != \"$magic\"; then + # Run the actual program with our arguments. +" + case $host in + # Backslashes separate directories on plain windows + *-*-mingw | *-*-os2*) + $echo >> $output "\ + exec \$progdir\\\\\$program \${1+\"\$@\"} +" + ;; - delfiles= - if test -n "$export_symbols" && test -n "$include_expsyms"; then - $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" - export_symbols="$output_objdir/$libname.uexp" - delfiles="$delfiles $export_symbols" - fi - - orig_export_symbols= - case $host_os in - cygwin* | mingw* | cegcc*) - if test -n "$export_symbols" && test -z "$export_symbols_regex"; then - # exporting using user supplied symfile - if test "x`$SED 1q $export_symbols`" != xEXPORTS; then - # and it's NOT already a .def file. Must figure out - # which of the given symbols are data symbols and tag - # them as such. So, trigger use of export_symbols_cmds. - # export_symbols gets reassigned inside the "prepare - # the list of exported symbols" if statement, so the - # include_expsyms logic still works. - orig_export_symbols="$export_symbols" - export_symbols= - always_export_symbols=yes - fi - fi + *) + $echo >> $output "\ + exec \$progdir/\$program \${1+\"\$@\"} +" ;; esac + $echo >> $output "\ + \$echo \"\$0: cannot exec \$program \${1+\"\$@\"}\" + exit $EXIT_FAILURE + fi + else + # The program doesn't exist. + \$echo \"\$0: error: \$progdir/\$program does not exist\" 1>&2 + \$echo \"This script is just a wrapper for \$program.\" 1>&2 + $echo \"See the $PACKAGE documentation for more information.\" 1>&2 + exit $EXIT_FAILURE + fi +fi\ +" + chmod +x $output + fi + exit $EXIT_SUCCESS + ;; + esac - # Prepare the list of exported symbols - if test -z "$export_symbols"; then - if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then - func_verbose "generating symbol list for \`$libname.la'" - export_symbols="$output_objdir/$libname.exp" - $opt_dry_run || $RM $export_symbols - cmds=$export_symbols_cmds - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - IFS="$save_ifs" - eval cmd=\"$cmd\" - func_len " $cmd" - len=$func_len_result - if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then - func_show_eval "$cmd" 'exit $?' - skipped_export=false - else - # The command line is too long to execute in one step. - func_verbose "using reloadable object file for export list..." - skipped_export=: - # Break out early, otherwise skipped_export may be - # set to false by a later but shorter cmd. - break - fi - done - IFS="$save_ifs" - if test -n "$export_symbols_regex" && test "X$skipped_export" != "X:"; then - func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' - func_show_eval '$MV "${export_symbols}T" "$export_symbols"' - fi - fi + # See if we need to build an old-fashioned archive. + for oldlib in $oldlibs; do + + if test "$build_libtool_libs" = convenience; then + oldobjs="$libobjs_save" + addlibs="$convenience" + build_libtool_libs=no + else + if test "$build_libtool_libs" = module; then + oldobjs="$libobjs_save" + build_libtool_libs=no + else + oldobjs="$old_deplibs $non_pic_objects" fi + addlibs="$old_convenience" + fi - if test -n "$export_symbols" && test -n "$include_expsyms"; then - tmp_export_symbols="$export_symbols" - test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols" - $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"' - fi - - if test "X$skipped_export" != "X:" && test -n "$orig_export_symbols"; then - # The given exports_symbols file has to be filtered, so filter it. - func_verbose "filter symbol list for \`$libname.la' to tag DATA exports" - # FIXME: $output_objdir/$libname.filter potentially contains lots of - # 's' commands which not all seds can handle. GNU sed should be fine - # though. Also, the filter scales superlinearly with the number of - # global variables. join(1) would be nice here, but unfortunately - # isn't a blessed tool. - $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter - delfiles="$delfiles $export_symbols $output_objdir/$libname.filter" - export_symbols=$output_objdir/$libname.def - $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols + if test -n "$addlibs"; then + gentop="$output_objdir/${outputname}x" + $show "${rm}r $gentop" + $run ${rm}r "$gentop" + $show "$mkdir $gentop" + $run $mkdir "$gentop" + status=$? + if test "$status" -ne 0 && test ! -d "$gentop"; then + exit $status fi + generated="$generated $gentop" - tmp_deplibs= - for test_deplib in $deplibs; do - case " $convenience " in - *" $test_deplib "*) ;; - *) - tmp_deplibs="$tmp_deplibs $test_deplib" - ;; + # Add in members from convenience archives. + for xlib in $addlibs; do + # Extract the objects. + case $xlib in + [\\/]* | [A-Za-z]:[\\/]*) xabs="$xlib" ;; + *) xabs=`pwd`"/$xlib" ;; esac - done - deplibs="$tmp_deplibs" + xlib=`$echo "X$xlib" | $Xsed -e 's%^.*/%%'` + xdir="$gentop/$xlib" - if test -n "$convenience"; then - if test -n "$whole_archive_flag_spec" && - test "$compiler_needs_object" = yes && - test -z "$libobjs"; then - # extract the archives, so we have objects to list. - # TODO: could optimize this to just extract one archive. - whole_archive_flag_spec= - fi - if test -n "$whole_archive_flag_spec"; then - save_libobjs=$libobjs - eval libobjs=\"\$libobjs $whole_archive_flag_spec\" - test "X$libobjs" = "X " && libobjs= + $show "${rm}r $xdir" + $run ${rm}r "$xdir" + $show "$mkdir $xdir" + $run $mkdir "$xdir" + status=$? + if test "$status" -ne 0 && test ! -d "$xdir"; then + exit $status + fi + # We will extract separately just the conflicting names and we will no + # longer touch any unique names. It is faster to leave these extract + # automatically by $AR in one run. + $show "(cd $xdir && $AR x $xabs)" + $run eval "(cd \$xdir && $AR x \$xabs)" || exit $? + if ($AR t "$xabs" | sort | sort -uc >/dev/null 2>&1); then + : else - gentop="$output_objdir/${outputname}x" - generated="$generated $gentop" - - func_extract_archives $gentop $convenience - libobjs="$libobjs $func_extract_archives_result" - test "X$libobjs" = "X " && libobjs= + $echo "$modename: warning: object name conflicts; renaming object files" 1>&2 + $echo "$modename: warning: to ensure that they will not overwrite" 1>&2 + $AR t "$xabs" | sort | uniq -cd | while read -r count name + do + i=1 + while test "$i" -le "$count" + do + # Put our $i before any first dot (extension) + # Never overwrite any file + name_to="$name" + while test "X$name_to" = "X$name" || test -f "$xdir/$name_to" + do + name_to=`$echo "X$name_to" | $Xsed -e "s/\([^.]*\)/\1-$i/"` + done + $show "(cd $xdir && $AR xN $i $xabs '$name' && $mv '$name' '$name_to')" + $run eval "(cd \$xdir && $AR xN $i \$xabs '$name' && $mv '$name' '$name_to')" || exit $? + i=`expr $i + 1` + done + done fi - fi - if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then - eval flag=\"$thread_safe_flag_spec\" - linker_flags="$linker_flags $flag" - fi + oldobjs="$oldobjs "`find $xdir -name \*.${objext} -print -o -name \*.lo -print | $NL2SP` + done + fi - # Make a backup of the uninstalled library when relinking - if test "$mode" = relink; then - $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? - fi + # Do each command in the archive commands. + if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then + cmds=$old_archive_from_new_cmds + else + eval cmds=\"$old_archive_cmds\" - # Do each of the archive commands. - if test "$module" = yes && test -n "$module_cmds" ; then - if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then - eval test_cmds=\"$module_expsym_cmds\" - cmds=$module_expsym_cmds + if len=`expr "X$cmds" : ".*"` && + test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then + cmds=$old_archive_cmds + else + # the command line is too long to link in one step, link in parts + $echo "using piecewise archive linking..." + save_RANLIB=$RANLIB + RANLIB=: + objlist= + concat_cmds= + save_oldobjs=$oldobjs + # GNU ar 2.10+ was changed to match POSIX; thus no paths are + # encoded into archives. This makes 'ar r' malfunction in + # this piecewise linking case whenever conflicting object + # names appear in distinct ar calls; check, warn and compensate. + if (for obj in $save_oldobjs + do + $echo "X$obj" | $Xsed -e 's%^.*/%%' + done | sort | sort -uc >/dev/null 2>&1); then + : else - eval test_cmds=\"$module_cmds\" - cmds=$module_cmds + $echo "$modename: warning: object name conflicts; overriding AR_FLAGS to 'cq'" 1>&2 + $echo "$modename: warning: to ensure that POSIX-compatible ar will work" 1>&2 + AR_FLAGS=cq fi - else - if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then - eval test_cmds=\"$archive_expsym_cmds\" - cmds=$archive_expsym_cmds + # Is there a better way of finding the last object in the list? + for obj in $save_oldobjs + do + last_oldobj=$obj + done + for obj in $save_oldobjs + do + oldobjs="$objlist $obj" + objlist="$objlist $obj" + eval test_cmds=\"$old_archive_cmds\" + if len=`expr "X$test_cmds" : ".*"` && + test "$len" -le "$max_cmd_len"; then + : + else + # the above command should be used before it gets too long + oldobjs=$objlist + if test "$obj" = "$last_oldobj" ; then + RANLIB=$save_RANLIB + fi + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\" + objlist= + fi + done + RANLIB=$save_RANLIB + oldobjs=$objlist + if test "X$oldobjs" = "X" ; then + eval cmds=\"\$concat_cmds\" else - eval test_cmds=\"$archive_cmds\" - cmds=$archive_cmds + eval cmds=\"\$concat_cmds~\$old_archive_cmds\" fi fi + fi + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + eval cmd=\"$cmd\" + IFS="$save_ifs" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + done - if test "X$skipped_export" != "X:" && - func_len " $test_cmds" && - len=$func_len_result && - test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then - : - else - # The command line is too long to link in one step, link piecewise - # or, if using GNU ld and skipped_export is not :, use a linker - # script. + if test -n "$generated"; then + $show "${rm}r$generated" + $run ${rm}r$generated + fi - # Save the value of $output and $libobjs because we want to - # use them later. If we have whole_archive_flag_spec, we - # want to use save_libobjs as it was before - # whole_archive_flag_spec was expanded, because we can't - # assume the linker understands whole_archive_flag_spec. - # This may have to be revisited, in case too many - # convenience libraries get linked in and end up exceeding - # the spec. - if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then - save_libobjs=$libobjs - fi - save_output=$output - output_la=`$ECHO "X$output" | $Xsed -e "$basename"` + # Now create the libtool archive. + case $output in + *.la) + old_library= + test "$build_old_libs" = yes && old_library="$libname.$libext" + $show "creating $output" - # Clear the reloadable object creation command queue and - # initialize k to one. - test_cmds= - concat_cmds= - objlist= - last_robj= - k=1 + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"` + relink_command="$var=\"$var_value\"; export $var; $relink_command" + fi + done + # Quote the link command for shipping. + relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" + relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"` + if test "$hardcode_automatic" = yes ; then + relink_command= + fi - if test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "$with_gnu_ld" = yes; then - output=${output_objdir}/${output_la}.lnkscript - func_verbose "creating GNU ld script: $output" - $ECHO 'INPUT (' > $output - for obj in $save_libobjs - do - $ECHO "$obj" >> $output - done - $ECHO ')' >> $output - delfiles="$delfiles $output" - elif test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "X$file_list_spec" != X; then - output=${output_objdir}/${output_la}.lnk - func_verbose "creating linker input file list: $output" - : > $output - set x $save_libobjs - shift - firstobj= - if test "$compiler_needs_object" = yes; then - firstobj="$1 " - shift - fi - for obj - do - $ECHO "$obj" >> $output - done - delfiles="$delfiles $output" - output=$firstobj\"$file_list_spec$output\" - else - if test -n "$save_libobjs"; then - func_verbose "creating reloadable object files..." - output=$output_objdir/$output_la-${k}.$objext - eval test_cmds=\"$reload_cmds\" - func_len " $test_cmds" - len0=$func_len_result - len=$len0 - # Loop over the list of objects to be linked. - for obj in $save_libobjs - do - func_len " $obj" - func_arith $len + $func_len_result - len=$func_arith_result - if test "X$objlist" = X || - test "$len" -lt "$max_cmd_len"; then - func_append objlist " $obj" - else - # The command $test_cmds is almost too long, add a - # command to the queue. - if test "$k" -eq 1 ; then - # The first file doesn't have a previous command to add. - eval concat_cmds=\"$reload_cmds $objlist $last_robj\" - else - # All subsequent reloadable object files will link in - # the last one created. - eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj~\$RM $last_robj\" - fi - last_robj=$output_objdir/$output_la-${k}.$objext - func_arith $k + 1 - k=$func_arith_result - output=$output_objdir/$output_la-${k}.$objext - objlist=$obj - func_len " $last_robj" - func_arith $len0 + $func_len_result - len=$func_arith_result + # Only create the output if not a dry run. + if test -z "$run"; then + for installed in no yes; do + if test "$installed" = yes; then + if test -z "$install_libdir"; then + break + fi + output="$output_objdir/$outputname"i + # Replace all uninstalled libtool libraries with the installed ones + newdependency_libs= + for deplib in $dependency_libs; do + case $deplib in + *.la) + name=`$echo "X$deplib" | $Xsed -e 's%^.*/%%'` + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` + if test -z "$libdir"; then + $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE fi - done - # Handle the remaining objects by creating one last - # reloadable object file. All subsequent reloadable object - # files will link in the last one created. - test -z "$concat_cmds" || concat_cmds=$concat_cmds~ - eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\" - if test -n "$last_robj"; then - eval concat_cmds=\"\${concat_cmds}~\$RM $last_robj\" + newdependency_libs="$newdependency_libs $libdir/$name" + ;; + *) newdependency_libs="$newdependency_libs $deplib" ;; + esac + done + dependency_libs="$newdependency_libs" + newdlfiles= + for lib in $dlfiles; do + name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + if test -z "$libdir"; then + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE fi - delfiles="$delfiles $output" - - else - output= - fi - - if ${skipped_export-false}; then - func_verbose "generating symbol list for \`$libname.la'" - export_symbols="$output_objdir/$libname.exp" - $opt_dry_run || $RM $export_symbols - libobjs=$output - # Append the command to create the export file. - test -z "$concat_cmds" || concat_cmds=$concat_cmds~ - eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" - if test -n "$last_robj"; then - eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" + newdlfiles="$newdlfiles $libdir/$name" + done + dlfiles="$newdlfiles" + newdlprefiles= + for lib in $dlprefiles; do + name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + if test -z "$libdir"; then + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE fi - fi - - test -n "$save_libobjs" && - func_verbose "creating a temporary reloadable object file: $output" - - # Loop through the commands generated above and execute them. - save_ifs="$IFS"; IFS='~' - for cmd in $concat_cmds; do - IFS="$save_ifs" - $opt_silent || { - func_quote_for_expand "$cmd" - eval "func_echo $func_quote_for_expand_result" - } - $opt_dry_run || eval "$cmd" || { - lt_exit=$? - - # Restore the uninstalled library and exit - if test "$mode" = relink; then - ( cd "$output_objdir" && \ - $RM "${realname}T" && \ - $MV "${realname}U" "$realname" ) - fi - - exit $lt_exit - } + newdlprefiles="$newdlprefiles $libdir/$name" done - IFS="$save_ifs" - - if test -n "$export_symbols_regex" && ${skipped_export-false}; then - func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' - func_show_eval '$MV "${export_symbols}T" "$export_symbols"' - fi - fi - - if ${skipped_export-false}; then - if test -n "$export_symbols" && test -n "$include_expsyms"; then - tmp_export_symbols="$export_symbols" - test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols" - $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"' - fi - - if test -n "$orig_export_symbols"; then - # The given exports_symbols file has to be filtered, so filter it. - func_verbose "filter symbol list for \`$libname.la' to tag DATA exports" - # FIXME: $output_objdir/$libname.filter potentially contains lots of - # 's' commands which not all seds can handle. GNU sed should be fine - # though. Also, the filter scales superlinearly with the number of - # global variables. join(1) would be nice here, but unfortunately - # isn't a blessed tool. - $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter - delfiles="$delfiles $export_symbols $output_objdir/$libname.filter" - export_symbols=$output_objdir/$libname.def - $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols - fi - fi - - libobjs=$output - # Restore the value of output. - output=$save_output - - if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then - eval libobjs=\"\$libobjs $whole_archive_flag_spec\" - test "X$libobjs" = "X " && libobjs= - fi - # Expand the library linking commands again to reset the - # value of $libobjs for piecewise linking. - - # Do each of the archive commands. - if test "$module" = yes && test -n "$module_cmds" ; then - if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then - cmds=$module_expsym_cmds - else - cmds=$module_cmds - fi + dlprefiles="$newdlprefiles" else - if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then - cmds=$archive_expsym_cmds - else - cmds=$archive_cmds - fi + newdlfiles= + for lib in $dlfiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; + *) abs=`pwd`"/$lib" ;; + esac + newdlfiles="$newdlfiles $abs" + done + dlfiles="$newdlfiles" + newdlprefiles= + for lib in $dlprefiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; + *) abs=`pwd`"/$lib" ;; + esac + newdlprefiles="$newdlprefiles $abs" + done + dlprefiles="$newdlprefiles" fi - fi + $rm $output + # place dlname in correct position for cygwin + tdlname=$dlname + case $host,$output,$installed,$module,$dlname in + *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;; + esac + $echo > $output "\ +# $outputname - a libtool library file +# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP +# +# Please DO NOT delete this file! +# It is necessary for linking the library. - if test -n "$delfiles"; then - # Append the command to remove temporary files to $cmds. - eval cmds=\"\$cmds~\$RM $delfiles\" - fi +# The name that we can dlopen(3). +dlname='$tdlname' - # Add any objects from preloaded convenience libraries - if test -n "$dlprefiles"; then - gentop="$output_objdir/${outputname}x" - generated="$generated $gentop" +# Names of this library. +library_names='$library_names' - func_extract_archives $gentop $dlprefiles - libobjs="$libobjs $func_extract_archives_result" - test "X$libobjs" = "X " && libobjs= - fi +# The name of the static archive. +old_library='$old_library' - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - IFS="$save_ifs" - eval cmd=\"$cmd\" - $opt_silent || { - func_quote_for_expand "$cmd" - eval "func_echo $func_quote_for_expand_result" - } - $opt_dry_run || eval "$cmd" || { - lt_exit=$? - - # Restore the uninstalled library and exit - if test "$mode" = relink; then - ( cd "$output_objdir" && \ - $RM "${realname}T" && \ - $MV "${realname}U" "$realname" ) - fi +# Libraries that this one depends upon. +dependency_libs='$dependency_libs' - exit $lt_exit - } - done - IFS="$save_ifs" +# Version information for $libname. +current=$current +age=$age +revision=$revision - # Restore the uninstalled library and exit - if test "$mode" = relink; then - $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? +# Is this an already installed library? +installed=$installed - if test -n "$convenience"; then - if test -z "$whole_archive_flag_spec"; then - func_show_eval '${RM}r "$gentop"' - fi - fi +# Should we warn about portability when linking against -modules? +shouldnotlink=$module - exit $EXIT_SUCCESS - fi +# Files to dlopen/dlpreopen +dlopen='$dlfiles' +dlpreopen='$dlprefiles' - # Create links to the real library. - for linkname in $linknames; do - if test "$realname" != "$linkname"; then - func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' +# Directory that this library needs to be installed in: +libdir='$install_libdir'" + if test "$installed" = no && test "$need_relink" = yes; then + $echo >> $output "\ +relink_command=\"$relink_command\"" fi done - - # If -module or -export-dynamic was specified, set the dlname. - if test "$module" = yes || test "$export_dynamic" = yes; then - # On all known operating systems, these are identical. - dlname="$soname" - fi fi + + # Do a symbolic link so that the libtool archive can be found in + # LD_LIBRARY_PATH before the program is installed. + $show "(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)" + $run eval '(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)' || exit $? ;; + esac + exit $EXIT_SUCCESS + ;; - obj) - if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then - func_warning "\`-dlopen' is ignored for objects" - fi + # libtool install mode + install) + modename="$modename: install" - case " $deplibs" in - *\ -l* | *\ -L*) - func_warning "\`-l' and \`-L' are ignored for objects" ;; + # There may be an optional sh(1) argument at the beginning of + # install_prog (especially on Windows NT). + if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh || + # Allow the use of GNU shtool's install command. + $echo "X$nonopt" | $Xsed | grep shtool > /dev/null; then + # Aesthetically quote it. + arg=`$echo "X$nonopt" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*) + arg="\"$arg\"" + ;; esac + install_prog="$arg " + arg="$1" + shift + else + install_prog= + arg="$nonopt" + fi - test -n "$rpath" && \ - func_warning "\`-rpath' is ignored for objects" - - test -n "$xrpath" && \ - func_warning "\`-R' is ignored for objects" - - test -n "$vinfo" && \ - func_warning "\`-version-info' is ignored for objects" - - test -n "$release" && \ - func_warning "\`-release' is ignored for objects" + # The real first argument should be the name of the installation program. + # Aesthetically quote it. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*) + arg="\"$arg\"" + ;; + esac + install_prog="$install_prog$arg" - case $output in - *.lo) - test -n "$objs$old_deplibs" && \ - func_fatal_error "cannot build library object \`$output' from non-libtool objects" + # We need to accept at least all the BSD install flags. + dest= + files= + opts= + prev= + install_type= + isdir=no + stripme= + for arg + do + if test -n "$dest"; then + files="$files $dest" + dest="$arg" + continue + fi - libobj=$output - func_lo2o "$libobj" - obj=$func_lo2o_result - ;; - *) - libobj= - obj="$output" + case $arg in + -d) isdir=yes ;; + -f) prev="-f" ;; + -g) prev="-g" ;; + -m) prev="-m" ;; + -o) prev="-o" ;; + -s) + stripme=" -s" + continue ;; - esac - - # Delete the old objects. - $opt_dry_run || $RM $obj $libobj - - # Objects from convenience libraries. This assumes - # single-version convenience libraries. Whenever we create - # different ones for PIC/non-PIC, this we'll have to duplicate - # the extraction. - reload_conv_objs= - gentop= - # reload_cmds runs $LD directly, so let us get rid of - # -Wl from whole_archive_flag_spec and hope we can get by with - # turning comma into space.. - wl= + -*) ;; - if test -n "$convenience"; then - if test -n "$whole_archive_flag_spec"; then - eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" - reload_conv_objs=$reload_objs\ `$ECHO "X$tmp_whole_archive_flags" | $Xsed -e 's|,| |g'` + *) + # If the previous option needed an argument, then skip it. + if test -n "$prev"; then + prev= else - gentop="$output_objdir/${obj}x" - generated="$generated $gentop" - - func_extract_archives $gentop $convenience - reload_conv_objs="$reload_objs $func_extract_archives_result" + dest="$arg" + continue fi - fi + ;; + esac - # Create the old-style object. - reload_objs="$objs$old_deplibs "`$ECHO "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test + # Aesthetically quote the argument. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*) + arg="\"$arg\"" + ;; + esac + install_prog="$install_prog $arg" + done - output="$obj" - func_execute_cmds "$reload_cmds" 'exit $?' + if test -z "$install_prog"; then + $echo "$modename: you must specify an install program" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi - # Exit if we aren't doing a library object file. - if test -z "$libobj"; then - if test -n "$gentop"; then - func_show_eval '${RM}r "$gentop"' - fi + if test -n "$prev"; then + $echo "$modename: the \`$prev' option requires an argument" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi - exit $EXIT_SUCCESS + if test -z "$files"; then + if test -z "$dest"; then + $echo "$modename: no file or destination specified" 1>&2 + else + $echo "$modename: you must specify a destination" 1>&2 fi + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi - if test "$build_libtool_libs" != yes; then - if test -n "$gentop"; then - func_show_eval '${RM}r "$gentop"' - fi - - # Create an invalid libtool object if no PIC, so that we don't - # accidentally link it into a program. - # $show "echo timestamp > $libobj" - # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? - exit $EXIT_SUCCESS - fi + # Strip any trailing slash from the destination. + dest=`$echo "X$dest" | $Xsed -e 's%/$%%'` - if test -n "$pic_flag" || test "$pic_mode" != default; then - # Only do commands if we really have different PIC objects. - reload_objs="$libobjs $reload_conv_objs" - output="$libobj" - func_execute_cmds "$reload_cmds" 'exit $?' - fi + # Check to see that the destination is a directory. + test -d "$dest" && isdir=yes + if test "$isdir" = yes; then + destdir="$dest" + destname= + else + destdir=`$echo "X$dest" | $Xsed -e 's%/[^/]*$%%'` + test "X$destdir" = "X$dest" && destdir=. + destname=`$echo "X$dest" | $Xsed -e 's%^.*/%%'` - if test -n "$gentop"; then - func_show_eval '${RM}r "$gentop"' + # Not a directory, so check to see that there is only one file specified. + set dummy $files + if test "$#" -gt 2; then + $echo "$modename: \`$dest' is not a directory" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE fi - - exit $EXIT_SUCCESS + fi + case $destdir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + for file in $files; do + case $file in + *.lo) ;; + *) + $echo "$modename: \`$destdir' must be an absolute directory name" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; + esac + done ;; + esac - prog) - case $host in - *cygwin*) func_stripname '' '.exe' "$output" - output=$func_stripname_result.exe;; - esac - test -n "$vinfo" && \ - func_warning "\`-version-info' is ignored for programs" - - test -n "$release" && \ - func_warning "\`-release' is ignored for programs" + # This variable tells wrapper scripts just to set variables rather + # than running their programs. + libtool_install_magic="$magic" - test "$preload" = yes \ - && test "$dlopen_support" = unknown \ - && test "$dlopen_self" = unknown \ - && test "$dlopen_self_static" = unknown && \ - func_warning "\`LT_INIT([dlopen])' not used. Assuming no dlopen support." + staticlibs= + future_libdirs= + current_libdirs= + for file in $files; do - case $host in - *-*-rhapsody* | *-*-darwin1.[012]) - # On Rhapsody replace the C library is the System framework - compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'` - finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'` + # Do each installation. + case $file in + *.$libext) + # Do the static libraries later. + staticlibs="$staticlibs $file" ;; - esac - case $host in - *-*-darwin*) - # Don't allow lazy linking, it breaks C++ global constructors - # But is supposedly fixed on 10.4 or later (yay!). - if test "$tagname" = CXX ; then - case ${MACOSX_DEPLOYMENT_TARGET-10.0} in - 10.[0123]) - compile_command="$compile_command ${wl}-bind_at_load" - finalize_command="$finalize_command ${wl}-bind_at_load" - ;; - esac + *.la) + # Check to see that this really is a libtool archive. + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then : + else + $echo "$modename: \`$file' is not a valid libtool archive" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE fi - # Time to change all our "foo.ltframework" stuff back to "-framework foo" - compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` - finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` - ;; - esac - - # move library search paths that coincide with paths to not yet - # installed libraries to the beginning of the library search list - new_libs= - for path in $notinst_path; do - case " $new_libs " in - *" -L$path/$objdir "*) ;; - *) - case " $compile_deplibs " in - *" -L$path/$objdir "*) - new_libs="$new_libs -L$path/$objdir" ;; - esac - ;; - esac - done - for deplib in $compile_deplibs; do - case $deplib in - -L*) - case " $new_libs " in - *" $deplib "*) ;; - *) new_libs="$new_libs $deplib" ;; - esac - ;; - *) new_libs="$new_libs $deplib" ;; + library_names= + old_library= + relink_command= + # If there is no directory component, then add one. + case $file in + */* | *\\*) . $file ;; + *) . ./$file ;; esac - done - compile_deplibs="$new_libs" - - compile_command="$compile_command $compile_deplibs" - finalize_command="$finalize_command $finalize_deplibs" - - if test -n "$rpath$xrpath"; then - # If the user specified any rpath flags, then add them. - for libdir in $rpath $xrpath; do - # This is the magic to use -rpath. - case "$finalize_rpath " in - *" $libdir "*) ;; - *) finalize_rpath="$finalize_rpath $libdir" ;; - esac - done - fi - - # Now hardcode the library paths - rpath= - hardcode_libdirs= - for libdir in $compile_rpath $finalize_rpath; do - if test -n "$hardcode_libdir_flag_spec"; then - if test -n "$hardcode_libdir_separator"; then - if test -z "$hardcode_libdirs"; then - hardcode_libdirs="$libdir" - else - # Just accumulate the unique libdirs. - case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in - *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) - ;; - *) - hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" - ;; - esac - fi - else - eval flag=\"$hardcode_libdir_flag_spec\" - rpath="$rpath $flag" - fi - elif test -n "$runpath_var"; then - case "$perm_rpath " in + # Add the libdir to current_libdirs if it is the destination. + if test "X$destdir" = "X$libdir"; then + case "$current_libdirs " in *" $libdir "*) ;; - *) perm_rpath="$perm_rpath $libdir" ;; - esac - fi - case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) - testbindir=`${ECHO} "$libdir" | ${SED} -e 's*/lib$*/bin*'` - case :$dllsearchpath: in - *":$libdir:"*) ;; - ::) dllsearchpath=$libdir;; - *) dllsearchpath="$dllsearchpath:$libdir";; + *) current_libdirs="$current_libdirs $libdir" ;; esac - case :$dllsearchpath: in - *":$testbindir:"*) ;; - ::) dllsearchpath=$testbindir;; - *) dllsearchpath="$dllsearchpath:$testbindir";; + else + # Note the libdir as a future libdir. + case "$future_libdirs " in + *" $libdir "*) ;; + *) future_libdirs="$future_libdirs $libdir" ;; esac - ;; - esac - done - # Substitute the hardcoded libdirs into the rpath. - if test -n "$hardcode_libdir_separator" && - test -n "$hardcode_libdirs"; then - libdir="$hardcode_libdirs" - eval rpath=\" $hardcode_libdir_flag_spec\" - fi - compile_rpath="$rpath" + fi - rpath= - hardcode_libdirs= - for libdir in $finalize_rpath; do - if test -n "$hardcode_libdir_flag_spec"; then - if test -n "$hardcode_libdir_separator"; then - if test -z "$hardcode_libdirs"; then - hardcode_libdirs="$libdir" - else - # Just accumulate the unique libdirs. - case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in - *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) - ;; - *) - hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" - ;; - esac - fi + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`/ + test "X$dir" = "X$file/" && dir= + dir="$dir$objdir" + + if test -n "$relink_command"; then + # Determine the prefix the user has applied to our future dir. + inst_prefix_dir=`$echo "$destdir" | $SED "s%$libdir\$%%"` + + # Don't allow the user to place us outside of our expected + # location b/c this prevents finding dependent libraries that + # are installed to the same prefix. + # At present, this check doesn't affect windows .dll's that + # are installed into $libdir/../bin (currently, that works fine) + # but it's something to keep an eye on. + if test "$inst_prefix_dir" = "$destdir"; then + $echo "$modename: error: cannot install \`$file' to a directory not ending in $libdir" 1>&2 + exit $EXIT_FAILURE + fi + + if test -n "$inst_prefix_dir"; then + # Stick the inst_prefix_dir data into the link command. + relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` else - eval flag=\"$hardcode_libdir_flag_spec\" - rpath="$rpath $flag" + relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%%"` fi - elif test -n "$runpath_var"; then - case "$finalize_perm_rpath " in - *" $libdir "*) ;; - *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;; - esac - fi - done - # Substitute the hardcoded libdirs into the rpath. - if test -n "$hardcode_libdir_separator" && - test -n "$hardcode_libdirs"; then - libdir="$hardcode_libdirs" - eval rpath=\" $hardcode_libdir_flag_spec\" - fi - finalize_rpath="$rpath" - if test -n "$libobjs" && test "$build_old_libs" = yes; then - # Transform all the library objects into standard objects. - compile_command=`$ECHO "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` - finalize_command=`$ECHO "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` - fi + $echo "$modename: warning: relinking \`$file'" 1>&2 + $show "$relink_command" + if $run eval "$relink_command"; then : + else + $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2 + exit $EXIT_FAILURE + fi + fi - func_generate_dlsyms "$outputname" "@PROGRAM@" "no" + # See the names of the shared library. + set dummy $library_names + if test -n "$2"; then + realname="$2" + shift + shift - # template prelinking step - if test -n "$prelink_cmds"; then - func_execute_cmds "$prelink_cmds" 'exit $?' - fi + srcname="$realname" + test -n "$relink_command" && srcname="$realname"T - wrappers_required=yes - case $host in - *cygwin* | *mingw* ) - if test "$build_libtool_libs" != yes; then - wrappers_required=no - fi - ;; - *cegcc) - # Disable wrappers for cegcc, we are cross compiling anyway. - wrappers_required=no - ;; - *) - if test "$need_relink" = no || test "$build_libtool_libs" != yes; then - wrappers_required=no - fi - ;; - esac - if test "$wrappers_required" = no; then - # Replace the output file specification. - compile_command=`$ECHO "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` - link_command="$compile_command$compile_rpath" + # Install the shared library and build the symlinks. + $show "$install_prog $dir/$srcname $destdir/$realname" + $run eval "$install_prog $dir/$srcname $destdir/$realname" || exit $? + if test -n "$stripme" && test -n "$striplib"; then + $show "$striplib $destdir/$realname" + $run eval "$striplib $destdir/$realname" || exit $? + fi - # We have no uninstalled library dependencies, so finalize right now. - exit_status=0 - func_show_eval "$link_command" 'exit_status=$?' + if test "$#" -gt 0; then + # Delete the old symlinks, and create new ones. + for linkname + do + if test "$linkname" != "$realname"; then + $show "(cd $destdir && $rm $linkname && $LN_S $realname $linkname)" + $run eval "(cd $destdir && $rm $linkname && $LN_S $realname $linkname)" + fi + done + fi - # Delete the generated files. - if test -f "$output_objdir/${outputname}S.${objext}"; then - func_show_eval '$RM "$output_objdir/${outputname}S.${objext}"' + # Do each command in the postinstall commands. + lib="$destdir/$realname" + cmds=$postinstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" fi - exit $exit_status - fi + # Install the pseudo-library for information purposes. + name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + instname="$dir/$name"i + $show "$install_prog $instname $destdir/$name" + $run eval "$install_prog $instname $destdir/$name" || exit $? - if test -n "$compile_shlibpath$finalize_shlibpath"; then - compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" - fi - if test -n "$finalize_shlibpath"; then - finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" - fi + # Maybe install the static library, too. + test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library" + ;; - compile_var= - finalize_var= - if test -n "$runpath_var"; then - if test -n "$perm_rpath"; then - # We should set the runpath_var. - rpath= - for dir in $perm_rpath; do - rpath="$rpath$dir:" - done - compile_var="$runpath_var=\"$rpath\$$runpath_var\" " + *.lo) + # Install (i.e. copy) a libtool object. + + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile="$destdir/$destname" + else + destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + destfile="$destdir/$destfile" fi - if test -n "$finalize_perm_rpath"; then - # We should set the runpath_var. - rpath= - for dir in $finalize_perm_rpath; do - rpath="$rpath$dir:" - done - finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " + + # Deduce the name of the destination old-style object file. + case $destfile in + *.lo) + staticdest=`$echo "X$destfile" | $Xsed -e "$lo2o"` + ;; + *.$objext) + staticdest="$destfile" + destfile= + ;; + *) + $echo "$modename: cannot copy a libtool object to \`$destfile'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + # Install the libtool object if requested. + if test -n "$destfile"; then + $show "$install_prog $file $destfile" + $run eval "$install_prog $file $destfile" || exit $? fi - fi - if test "$no_install" = yes; then - # We don't need to create a wrapper script. - link_command="$compile_var$compile_command$compile_rpath" - # Replace the output file specification. - link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` - # Delete the old output file. - $opt_dry_run || $RM $output - # Link the executable and exit - func_show_eval "$link_command" 'exit $?' - exit $EXIT_SUCCESS - fi + # Install the old object if enabled. + if test "$build_old_libs" = yes; then + # Deduce the name of the old-style object file. + staticobj=`$echo "X$file" | $Xsed -e "$lo2o"` - if test "$hardcode_action" = relink; then - # Fast installation is not supported - link_command="$compile_var$compile_command$compile_rpath" - relink_command="$finalize_var$finalize_command$finalize_rpath" + $show "$install_prog $staticobj $staticdest" + $run eval "$install_prog \$staticobj \$staticdest" || exit $? + fi + exit $EXIT_SUCCESS + ;; - func_warning "this platform does not like uninstalled shared libraries" - func_warning "\`$output' will be relinked during installation" - else - if test "$fast_install" != no; then - link_command="$finalize_var$compile_command$finalize_rpath" - if test "$fast_install" = yes; then - relink_command=`$ECHO "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'` - else - # fast_install is set to needless - relink_command= - fi + *) + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile="$destdir/$destname" else - link_command="$compile_var$compile_command$compile_rpath" - relink_command="$finalize_var$finalize_command$finalize_rpath" + destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + destfile="$destdir/$destfile" fi - fi - - # Replace the output file specification. - link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` - # Delete the old output files. - $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname + # If the file is missing, and there is a .exe on the end, strip it + # because it is most likely a libtool script we actually want to + # install + stripped_ext="" + case $file in + *.exe) + if test ! -f "$file"; then + file=`$echo $file|${SED} 's,.exe$,,'` + stripped_ext=".exe" + fi + ;; + esac - func_show_eval "$link_command" 'exit $?' + # Do a test to see if this is really a libtool program. + case $host in + *cygwin*|*mingw*) + wrapper=`$echo $file | ${SED} -e 's,.exe$,,'` + ;; + *) + wrapper=$file + ;; + esac + if (${SED} -e '4q' $wrapper | grep "^# Generated by .*$PACKAGE")>/dev/null 2>&1; then + notinst_deplibs= + relink_command= - # Now create the wrapper script. - func_verbose "creating $output" + # To insure that "foo" is sourced, and not "foo.exe", + # finese the cygwin/MSYS system by explicitly sourcing "foo." + # which disallows the automatic-append-.exe behavior. + case $build in + *cygwin* | *mingw*) wrapperdot=${wrapper}. ;; + *) wrapperdot=${wrapper} ;; + esac + # If there is no directory component, then add one. + case $file in + */* | *\\*) . ${wrapperdot} ;; + *) . ./${wrapperdot} ;; + esac - # Quote the relink command for shipping. - if test -n "$relink_command"; then - # Preserve any variables that may affect compiler behavior - for var in $variables_saved_for_relink; do - if eval test -z \"\${$var+set}\"; then - relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" - elif eval var_value=\$$var; test -z "$var_value"; then - relink_command="$var=; export $var; $relink_command" - else - func_quote_for_eval "$var_value" - relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" + # Check the variables that should have been set. + if test -z "$notinst_deplibs"; then + $echo "$modename: invalid libtool wrapper script \`$wrapper'" 1>&2 + exit $EXIT_FAILURE fi - done - relink_command="(cd `pwd`; $relink_command)" - relink_command=`$ECHO "X$relink_command" | $Xsed -e "$sed_quote_subst"` - fi - # Quote $ECHO for shipping. - if test "X$ECHO" = "X$SHELL $progpath --fallback-echo"; then - case $progpath in - [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";; - *) qecho="$SHELL `pwd`/$progpath --fallback-echo";; - esac - qecho=`$ECHO "X$qecho" | $Xsed -e "$sed_quote_subst"` - else - qecho=`$ECHO "X$ECHO" | $Xsed -e "$sed_quote_subst"` - fi + finalize=yes + for lib in $notinst_deplibs; do + # Check to see that each library is installed. + libdir= + if test -f "$lib"; then + # If there is no directory component, then add one. + case $lib in + */* | *\\*) . $lib ;; + *) . ./$lib ;; + esac + fi + libfile="$libdir/"`$echo "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test + if test -n "$libdir" && test ! -f "$libfile"; then + $echo "$modename: warning: \`$lib' has not been installed in \`$libdir'" 1>&2 + finalize=no + fi + done + + relink_command= + # To insure that "foo" is sourced, and not "foo.exe", + # finese the cygwin/MSYS system by explicitly sourcing "foo." + # which disallows the automatic-append-.exe behavior. + case $build in + *cygwin* | *mingw*) wrapperdot=${wrapper}. ;; + *) wrapperdot=${wrapper} ;; + esac + # If there is no directory component, then add one. + case $file in + */* | *\\*) . ${wrapperdot} ;; + *) . ./${wrapperdot} ;; + esac + + outputname= + if test "$fast_install" = no && test -n "$relink_command"; then + if test "$finalize" = yes && test -z "$run"; then + tmpdir="/tmp" + test -n "$TMPDIR" && tmpdir="$TMPDIR" + tmpdir="$tmpdir/libtool-$$" + save_umask=`umask` + umask 0077 + if $mkdir "$tmpdir"; then + umask $save_umask + else + umask $save_umask + $echo "$modename: error: cannot create temporary directory \`$tmpdir'" 1>&2 + continue + fi + file=`$echo "X$file$stripped_ext" | $Xsed -e 's%^.*/%%'` + outputname="$tmpdir/$file" + # Replace the output file specification. + relink_command=`$echo "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'` - # Only actually do things if not in dry run mode. - $opt_dry_run || { - # win32 will think the script is a binary if it has - # a .exe suffix, so we strip it off here. - case $output in - *.exe) func_stripname '' '.exe' "$output" - output=$func_stripname_result ;; - esac - # test for cygwin because mv fails w/o .exe extensions - case $host in - *cygwin*) - exeext=.exe - func_stripname '' '.exe' "$outputname" - outputname=$func_stripname_result ;; - *) exeext= ;; - esac - case $host in - *cygwin* | *mingw* ) - func_dirname_and_basename "$output" "" "." - output_name=$func_basename_result - output_path=$func_dirname_result - cwrappersource="$output_path/$objdir/lt-$output_name.c" - cwrapper="$output_path/$output_name.exe" - $RM $cwrappersource $cwrapper - trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 - - func_emit_cwrapperexe_src > $cwrappersource - - # The wrapper executable is built using the $host compiler, - # because it contains $host paths and files. If cross- - # compiling, it, like the target executable, must be - # executed on the $host or under an emulation environment. - $opt_dry_run || { - $LTCC $LTCFLAGS -o $cwrapper $cwrappersource - $STRIP $cwrapper - } - - # Now, create the wrapper script for func_source use: - func_ltwrapper_scriptname $cwrapper - $RM $func_ltwrapper_scriptname_result - trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 - $opt_dry_run || { - # note: this script will not be executed, so do not chmod. - if test "x$build" = "x$host" ; then - $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result + $show "$relink_command" + if $run eval "$relink_command"; then : else - func_emit_wrapper no > $func_ltwrapper_scriptname_result + $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2 + ${rm}r "$tmpdir" + continue fi - } - ;; - * ) - $RM $output - trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 + file="$outputname" + else + $echo "$modename: warning: cannot relink \`$file'" 1>&2 + fi + else + # Install the binary that we compiled earlier. + file=`$echo "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"` + fi + fi - func_emit_wrapper no > $output - chmod +x $output + # remove .exe since cygwin /usr/bin/install will append another + # one anyways + case $install_prog,$host in + */usr/bin/install*,*cygwin*) + case $file:$destfile in + *.exe:*.exe) + # this is ok + ;; + *.exe:*) + destfile=$destfile.exe + ;; + *:*.exe) + destfile=`$echo $destfile | ${SED} -e 's,.exe$,,'` + ;; + esac ;; esac - } - exit $EXIT_SUCCESS - ;; - esac + $show "$install_prog$stripme $file $destfile" + $run eval "$install_prog\$stripme \$file \$destfile" || exit $? + test -n "$outputname" && ${rm}r "$tmpdir" + ;; + esac + done - # See if we need to build an old-fashioned archive. - for oldlib in $oldlibs; do + for file in $staticlibs; do + name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` - if test "$build_libtool_libs" = convenience; then - oldobjs="$libobjs_save $symfileobj" - addlibs="$convenience" - build_libtool_libs=no - else - if test "$build_libtool_libs" = module; then - oldobjs="$libobjs_save" - build_libtool_libs=no - else - oldobjs="$old_deplibs $non_pic_objects" - if test "$preload" = yes && test -f "$symfileobj"; then - oldobjs="$oldobjs $symfileobj" - fi - fi - addlibs="$old_convenience" - fi + # Set up the ranlib parameters. + oldlib="$destdir/$name" - if test -n "$addlibs"; then - gentop="$output_objdir/${outputname}x" - generated="$generated $gentop" + $show "$install_prog $file $oldlib" + $run eval "$install_prog \$file \$oldlib" || exit $? - func_extract_archives $gentop $addlibs - oldobjs="$oldobjs $func_extract_archives_result" + if test -n "$stripme" && test -n "$old_striplib"; then + $show "$old_striplib $oldlib" + $run eval "$old_striplib $oldlib" || exit $? fi - # Do each command in the archive commands. - if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then - cmds=$old_archive_from_new_cmds - else + # Do each command in the postinstall commands. + cmds=$old_postinstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + done - # Add any objects from preloaded convenience libraries - if test -n "$dlprefiles"; then - gentop="$output_objdir/${outputname}x" - generated="$generated $gentop" + if test -n "$future_libdirs"; then + $echo "$modename: warning: remember to run \`$progname --finish$future_libdirs'" 1>&2 + fi - func_extract_archives $gentop $dlprefiles - oldobjs="$oldobjs $func_extract_archives_result" - fi + if test -n "$current_libdirs"; then + # Maybe just do a dry run. + test -n "$run" && current_libdirs=" -n$current_libdirs" + exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs' + else + exit $EXIT_SUCCESS + fi + ;; - # POSIX demands no paths to be encoded in archives. We have - # to avoid creating archives with duplicate basenames if we - # might have to extract them afterwards, e.g., when creating a - # static archive out of a convenience library, or when linking - # the entirety of a libtool archive into another (currently - # not supported by libtool). - if (for obj in $oldobjs - do - func_basename "$obj" - $ECHO "$func_basename_result" - done | sort | sort -uc >/dev/null 2>&1); then - : - else - $ECHO "copying selected object files to avoid basename conflicts..." - gentop="$output_objdir/${outputname}x" - generated="$generated $gentop" - func_mkdir_p "$gentop" - save_oldobjs=$oldobjs - oldobjs= - counter=1 - for obj in $save_oldobjs - do - func_basename "$obj" - objbase="$func_basename_result" - case " $oldobjs " in - " ") oldobjs=$obj ;; - *[\ /]"$objbase "*) - while :; do - # Make sure we don't pick an alternate name that also - # overlaps. - newobj=lt$counter-$objbase - func_arith $counter + 1 - counter=$func_arith_result - case " $oldobjs " in - *[\ /]"$newobj "*) ;; - *) if test ! -f "$gentop/$newobj"; then break; fi ;; - esac - done - func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" - oldobjs="$oldobjs $gentop/$newobj" - ;; - *) oldobjs="$oldobjs $obj" ;; - esac - done - fi - eval cmds=\"$old_archive_cmds\" + # libtool finish mode + finish) + modename="$modename: finish" + libdirs="$nonopt" + admincmds= - func_len " $cmds" - len=$func_len_result - if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then - cmds=$old_archive_cmds - else - # the command line is too long to link in one step, link in parts - func_verbose "using piecewise archive linking..." - save_RANLIB=$RANLIB - RANLIB=: - objlist= - concat_cmds= - save_oldobjs=$oldobjs - oldobjs= - # Is there a better way of finding the last object in the list? - for obj in $save_oldobjs - do - last_oldobj=$obj - done - eval test_cmds=\"$old_archive_cmds\" - func_len " $test_cmds" - len0=$func_len_result - len=$len0 - for obj in $save_oldobjs - do - func_len " $obj" - func_arith $len + $func_len_result - len=$func_arith_result - func_append objlist " $obj" - if test "$len" -lt "$max_cmd_len"; then - : - else - # the above command should be used before it gets too long - oldobjs=$objlist - if test "$obj" = "$last_oldobj" ; then - RANLIB=$save_RANLIB - fi - test -z "$concat_cmds" || concat_cmds=$concat_cmds~ - eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\" - objlist= - len=$len0 - fi + if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then + for dir + do + libdirs="$libdirs $dir" + done + + for libdir in $libdirs; do + if test -n "$finish_cmds"; then + # Do each command in the finish commands. + cmds=$finish_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || admincmds="$admincmds + $cmd" done - RANLIB=$save_RANLIB - oldobjs=$objlist - if test "X$oldobjs" = "X" ; then - eval cmds=\"\$concat_cmds\" - else - eval cmds=\"\$concat_cmds~\$old_archive_cmds\" - fi + IFS="$save_ifs" fi - fi - func_execute_cmds "$cmds" 'exit $?' - done + if test -n "$finish_eval"; then + # Do the single finish_eval. + eval cmds=\"$finish_eval\" + $run eval "$cmds" || admincmds="$admincmds + $cmds" + fi + done + fi - test -n "$generated" && \ - func_show_eval "${RM}r$generated" + # Exit here if they wanted silent mode. + test "$show" = : && exit $EXIT_SUCCESS - # Now create the libtool archive. - case $output in - *.la) - old_library= - test "$build_old_libs" = yes && old_library="$libname.$libext" - func_verbose "creating $output" + $echo "----------------------------------------------------------------------" + $echo "Libraries have been installed in:" + for libdir in $libdirs; do + $echo " $libdir" + done + $echo + $echo "If you ever happen to want to link against installed libraries" + $echo "in a given directory, LIBDIR, you must either use libtool, and" + $echo "specify the full pathname of the library, or use the \`-LLIBDIR'" + $echo "flag during linking and do at least one of the following:" + if test -n "$shlibpath_var"; then + $echo " - add LIBDIR to the \`$shlibpath_var' environment variable" + $echo " during execution" + fi + if test -n "$runpath_var"; then + $echo " - add LIBDIR to the \`$runpath_var' environment variable" + $echo " during linking" + fi + if test -n "$hardcode_libdir_flag_spec"; then + libdir=LIBDIR + eval flag=\"$hardcode_libdir_flag_spec\" - # Preserve any variables that may affect compiler behavior - for var in $variables_saved_for_relink; do - if eval test -z \"\${$var+set}\"; then - relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" - elif eval var_value=\$$var; test -z "$var_value"; then - relink_command="$var=; export $var; $relink_command" - else - func_quote_for_eval "$var_value" - relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" - fi - done - # Quote the link command for shipping. - relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" - relink_command=`$ECHO "X$relink_command" | $Xsed -e "$sed_quote_subst"` - if test "$hardcode_automatic" = yes ; then - relink_command= - fi + $echo " - use the \`$flag' linker flag" + fi + if test -n "$admincmds"; then + $echo " - have your system administrator run these commands:$admincmds" + fi + if test -f /etc/ld.so.conf; then + $echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'" + fi + $echo + $echo "See any operating system documentation about shared libraries for" + $echo "more information, such as the ld(1) and ld.so(8) manual pages." + $echo "----------------------------------------------------------------------" + exit $EXIT_SUCCESS + ;; - # Only create the output if not a dry run. - $opt_dry_run || { - for installed in no yes; do - if test "$installed" = yes; then - if test -z "$install_libdir"; then - break - fi - output="$output_objdir/$outputname"i - # Replace all uninstalled libtool libraries with the installed ones - newdependency_libs= - for deplib in $dependency_libs; do - case $deplib in - *.la) - func_basename "$deplib" - name="$func_basename_result" - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` - test -z "$libdir" && \ - func_fatal_error "\`$deplib' is not a valid libtool archive" - newdependency_libs="$newdependency_libs $libdir/$name" - ;; - *) newdependency_libs="$newdependency_libs $deplib" ;; - esac - done - dependency_libs="$newdependency_libs" - newdlfiles= + # libtool execute mode + execute) + modename="$modename: execute" - for lib in $dlfiles; do - case $lib in - *.la) - func_basename "$lib" - name="$func_basename_result" - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` - test -z "$libdir" && \ - func_fatal_error "\`$lib' is not a valid libtool archive" - newdlfiles="$newdlfiles $libdir/$name" - ;; - *) newdlfiles="$newdlfiles $lib" ;; - esac - done - dlfiles="$newdlfiles" - newdlprefiles= - for lib in $dlprefiles; do - case $lib in - *.la) - # Only pass preopened files to the pseudo-archive (for - # eventual linking with the app. that links it) if we - # didn't already link the preopened objects directly into - # the library: - func_basename "$lib" - name="$func_basename_result" - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` - test -z "$libdir" && \ - func_fatal_error "\`$lib' is not a valid libtool archive" - newdlprefiles="$newdlprefiles $libdir/$name" - ;; - esac - done - dlprefiles="$newdlprefiles" - else - newdlfiles= - for lib in $dlfiles; do - case $lib in - [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; - *) abs=`pwd`"/$lib" ;; - esac - newdlfiles="$newdlfiles $abs" - done - dlfiles="$newdlfiles" - newdlprefiles= - for lib in $dlprefiles; do - case $lib in - [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; - *) abs=`pwd`"/$lib" ;; - esac - newdlprefiles="$newdlprefiles $abs" - done - dlprefiles="$newdlprefiles" - fi - $RM $output - # place dlname in correct position for cygwin - tdlname=$dlname - case $host,$output,$installed,$module,$dlname in - *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;; - esac - $ECHO > $output "\ -# $outputname - a libtool library file -# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION -# -# Please DO NOT delete this file! -# It is necessary for linking the library. + # The first argument is the command name. + cmd="$nonopt" + if test -z "$cmd"; then + $echo "$modename: you must specify a COMMAND" 1>&2 + $echo "$help" + exit $EXIT_FAILURE + fi + + # Handle -dlopen flags immediately. + for file in $execute_dlfiles; do + if test ! -f "$file"; then + $echo "$modename: \`$file' is not a file" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi -# The name that we can dlopen(3). -dlname='$tdlname' + dir= + case $file in + *.la) + # Check to see that this really is a libtool archive. + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then : + else + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi -# Names of this library. -library_names='$library_names' + # Read the libtool library. + dlname= + library_names= -# The name of the static archive. -old_library='$old_library' + # If there is no directory component, then add one. + case $file in + */* | *\\*) . $file ;; + *) . ./$file ;; + esac -# Linker flags that can not go in dependency_libs. -inherited_linker_flags='$new_inherited_linker_flags' + # Skip this library if it cannot be dlopened. + if test -z "$dlname"; then + # Warn if it was a shared library. + test -n "$library_names" && $echo "$modename: warning: \`$file' was not linked with \`-export-dynamic'" + continue + fi -# Libraries that this one depends upon. -dependency_libs='$dependency_libs' + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'` + test "X$dir" = "X$file" && dir=. -# Names of additional weak libraries provided by this library -weak_library_names='$weak_libs' + if test -f "$dir/$objdir/$dlname"; then + dir="$dir/$objdir" + else + $echo "$modename: cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" 1>&2 + exit $EXIT_FAILURE + fi + ;; -# Version information for $libname. -current=$current -age=$age -revision=$revision + *.lo) + # Just add the directory containing the .lo file. + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'` + test "X$dir" = "X$file" && dir=. + ;; -# Is this an already installed library? -installed=$installed + *) + $echo "$modename: warning \`-dlopen' is ignored for non-libtool libraries and objects" 1>&2 + continue + ;; + esac -# Should we warn about portability when linking against -modules? -shouldnotlink=$module + # Get the absolute pathname. + absdir=`cd "$dir" && pwd` + test -n "$absdir" && dir="$absdir" -# Files to dlopen/dlpreopen -dlopen='$dlfiles' -dlpreopen='$dlprefiles' + # Now add the directory to shlibpath_var. + if eval "test -z \"\$$shlibpath_var\""; then + eval "$shlibpath_var=\"\$dir\"" + else + eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" + fi + done -# Directory that this library needs to be installed in: -libdir='$install_libdir'" - if test "$installed" = no && test "$need_relink" = yes; then - $ECHO >> $output "\ -relink_command=\"$relink_command\"" - fi - done - } + # This variable tells wrapper scripts just to set shlibpath_var + # rather than running their programs. + libtool_execute_magic="$magic" - # Do a symbolic link so that the libtool archive can be found in - # LD_LIBRARY_PATH before the program is installed. - func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' - ;; - esac - exit $EXIT_SUCCESS -} + # Check if any of the arguments is a wrapper script. + args= + for file + do + case $file in + -*) ;; + *) + # Do a test to see if this is really a libtool program. + if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + # If there is no directory component, then add one. + case $file in + */* | *\\*) . $file ;; + *) . ./$file ;; + esac -{ test "$mode" = link || test "$mode" = relink; } && - func_mode_link ${1+"$@"} + # Transform arg to wrapped name. + file="$progdir/$program" + fi + ;; + esac + # Quote arguments (to preserve shell metacharacters). + file=`$echo "X$file" | $Xsed -e "$sed_quote_subst"` + args="$args \"$file\"" + done + if test -z "$run"; then + if test -n "$shlibpath_var"; then + # Export the shlibpath_var. + eval "export $shlibpath_var" + fi -# func_mode_uninstall arg... -func_mode_uninstall () -{ - $opt_debug - RM="$nonopt" + # Restore saved environment variables + if test "${save_LC_ALL+set}" = set; then + LC_ALL="$save_LC_ALL"; export LC_ALL + fi + if test "${save_LANG+set}" = set; then + LANG="$save_LANG"; export LANG + fi + + # Now prepare to actually exec the command. + 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 + ;; + + # libtool clean and uninstall mode + clean | uninstall) + modename="$modename: $mode" + rm="$nonopt" files= rmforce= exit_status=0 @@ -8209,28 +6018,30 @@ for arg do case $arg in - -f) RM="$RM $arg"; rmforce=yes ;; - -*) RM="$RM $arg" ;; + -f) rm="$rm $arg"; rmforce=yes ;; + -*) rm="$rm $arg" ;; *) files="$files $arg" ;; esac done - test -z "$RM" && \ - func_fatal_help "you must specify an RM program" + if test -z "$rm"; then + $echo "$modename: you must specify an RM program" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi rmdirs= origobjdir="$objdir" for file in $files; do - func_dirname "$file" "" "." - dir="$func_dirname_result" - if test "X$dir" = X.; then + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'` + if test "X$dir" = "X$file"; then + dir=. objdir="$origobjdir" else objdir="$dir/$origobjdir" fi - func_basename "$file" - name="$func_basename_result" + name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` test "$mode" = uninstall && objdir="$dir" # Remember objdir for removal later, being careful to avoid duplicates @@ -8242,9 +6053,9 @@ fi # Don't error if the file doesn't exist and rm -f was used. - if { test -L "$file"; } >/dev/null 2>&1 || - { test -h "$file"; } >/dev/null 2>&1 || - test -f "$file"; then + if (test -L "$file") >/dev/null 2>&1 \ + || (test -h "$file") >/dev/null 2>&1 \ + || test -f "$file"; then : elif test -d "$file"; then exit_status=1 @@ -8258,56 +6069,69 @@ case $name in *.la) # Possibly a libtool archive, so verify it. - if func_lalib_p "$file"; then - func_source $dir/$name + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + . $dir/$name # Delete the libtool libraries and symlinks. for n in $library_names; do rmfiles="$rmfiles $objdir/$n" done test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library" + test "$mode" = clean && rmfiles="$rmfiles $objdir/$name $objdir/${name}i" - case "$mode" in - clean) - case " $library_names " in - # " " in the beginning catches empty $dlname - *" $dlname "*) ;; - *) rmfiles="$rmfiles $objdir/$dlname" ;; - esac - test -n "$libdir" && rmfiles="$rmfiles $objdir/$name $objdir/${name}i" - ;; - uninstall) + if test "$mode" = uninstall; then if test -n "$library_names"; then # Do each command in the postuninstall commands. - func_execute_cmds "$postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1' + cmds=$postuninstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" + if test "$?" -ne 0 && test "$rmforce" != yes; then + exit_status=1 + fi + done + IFS="$save_ifs" fi if test -n "$old_library"; then # Do each command in the old_postuninstall commands. - func_execute_cmds "$old_postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1' + cmds=$old_postuninstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" + if test "$?" -ne 0 && test "$rmforce" != yes; then + exit_status=1 + fi + done + IFS="$save_ifs" fi # FIXME: should reinstall the best remaining shared library. - ;; - esac + fi fi ;; *.lo) # Possibly a libtool object, so verify it. - if func_lalib_p "$file"; then + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then # Read the .lo file - func_source $dir/$name + . $dir/$name # Add PIC object to the list of files to remove. - if test -n "$pic_object" && - test "$pic_object" != none; then + if test -n "$pic_object" \ + && test "$pic_object" != none; then rmfiles="$rmfiles $dir/$pic_object" fi # Add non-PIC object to the list of files to remove. - if test -n "$non_pic_object" && - test "$non_pic_object" != none; then + if test -n "$non_pic_object" \ + && test "$non_pic_object" != none; then rmfiles="$rmfiles $dir/$non_pic_object" fi fi @@ -8318,26 +6142,17 @@ noexename=$name case $file in *.exe) - func_stripname '' '.exe' "$file" - file=$func_stripname_result - func_stripname '' '.exe' "$name" - noexename=$func_stripname_result + file=`$echo $file|${SED} 's,.exe$,,'` + noexename=`$echo $name|${SED} 's,.exe$,,'` # $file with .exe has already been added to rmfiles, # add $file without .exe rmfiles="$rmfiles $file" ;; esac # Do a test to see if this is a libtool program. - if func_ltwrapper_p "$file"; then - if func_ltwrapper_executable_p "$file"; then - func_ltwrapper_scriptname "$file" - relink_command= - func_source $func_ltwrapper_scriptname_result - rmfiles="$rmfiles $func_ltwrapper_scriptname_result" - else - relink_command= - func_source $dir/$noexename - fi + if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + relink_command= + . $dir/$noexename # note $name still contains .exe if it was in $file originally # as does the version of $file that was added into $rmfiles @@ -8352,38 +6167,237 @@ fi ;; esac - func_show_eval "$RM $rmfiles" 'exit_status=1' + $show "$rm $rmfiles" + $run $rm $rmfiles || exit_status=1 done objdir="$origobjdir" # Try to remove the ${objdir}s in the directories where we deleted files for dir in $rmdirs; do if test -d "$dir"; then - func_show_eval "rmdir $dir >/dev/null 2>&1" + $show "rmdir $dir" + $run rmdir $dir >/dev/null 2>&1 fi done exit $exit_status -} - -{ test "$mode" = uninstall || test "$mode" = clean; } && - func_mode_uninstall ${1+"$@"} + ;; -test -z "$mode" && { - help="$generic_help" - func_fatal_help "you must specify a MODE" -} + "") + $echo "$modename: you must specify a MODE" 1>&2 + $echo "$generic_help" 1>&2 + exit $EXIT_FAILURE + ;; + esac -test -z "$exec_cmd" && \ - func_fatal_help "invalid operation mode \`$mode'" + if test -z "$exec_cmd"; then + $echo "$modename: invalid operation mode \`$mode'" 1>&2 + $echo "$generic_help" 1>&2 + exit $EXIT_FAILURE + fi +fi # test -z "$show_help" if test -n "$exec_cmd"; then - eval exec "$exec_cmd" + eval exec $exec_cmd exit $EXIT_FAILURE fi -exit $exit_status +# We need to display help for each of the modes. +case $mode in +"") $echo \ +"Usage: $modename [OPTION]... [MODE-ARG]... + +Provide generalized library-building support services. + + --config show all configuration variables + --debug enable verbose shell tracing +-n, --dry-run display commands without modifying any files + --features display basic configuration information and exit + --finish same as \`--mode=finish' + --help display this help message and exit + --mode=MODE use operation mode MODE [default=inferred from MODE-ARGS] + --quiet same as \`--silent' + --silent don't print informational messages + --tag=TAG use configuration variables from tag TAG + --version print version information + +MODE must be one of the following: + + 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. Try \`$modename --help --mode=MODE' for +a more detailed description of MODE. + +Report bugs to ." + exit $EXIT_SUCCESS + ;; + +clean) + $echo \ +"Usage: $modename [OPTION]... --mode=clean RM [RM-OPTION]... FILE... + +Remove files from the build directory. + +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 +to RM. + +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." + ;; + +compile) + $echo \ +"Usage: $modename [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE + +Compile a source file into a libtool library object. + +This mode accepts the following additional options: + + -o OUTPUT-FILE set the output file name to OUTPUT-FILE + -prefer-pic try to building PIC objects only + -prefer-non-pic try to building non-PIC objects only + -static always build a \`.o' file suitable for static linking + +COMPILE-COMMAND is a command to be used in creating a \`standard' object file +from the given SOURCEFILE. + +The output file name is determined by removing the directory component from +SOURCEFILE, then substituting the C source code suffix \`.c' with the +library object suffix, \`.lo'." + ;; + +execute) + $echo \ +"Usage: $modename [OPTION]... --mode=execute COMMAND [ARGS]... + +Automatically set library path, then run a program. + +This mode accepts the following additional options: + + -dlopen FILE add the directory containing FILE to the library path + +This mode sets the library path environment variable according to \`-dlopen' +flags. + +If any of the ARGS are libtool executable wrappers, then they are translated +into their corresponding uninstalled binary, and any of their required library +directories are added to the library path. + +Then, COMMAND is executed, with ARGS as arguments." + ;; + +finish) + $echo \ +"Usage: $modename [OPTION]... --mode=finish [LIBDIR]... + +Complete the installation of libtool libraries. + +Each LIBDIR is a directory that contains libtool libraries. + +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." + ;; + +install) + $echo \ +"Usage: $modename [OPTION]... --mode=install INSTALL-COMMAND... + +Install executables or libraries. + +INSTALL-COMMAND is the installation command. The first component should be +either the \`install' or \`cp' program. + +The rest of the components are interpreted as arguments to that command (only +BSD-compatible install options are recognized)." + ;; + +link) + $echo \ +"Usage: $modename [OPTION]... --mode=link LINK-COMMAND... + +Link object files or libraries together to form another library, or to +create an executable program. + +LINK-COMMAND is a command using the C compiler that you would use to create +a program from several object files. + +The following components of LINK-COMMAND are treated specially: + + -all-static do not do any dynamic linking at all + -avoid-version do not add a version suffix if possible + -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime + -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols + -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) + -export-symbols SYMFILE + try to export only the symbols listed in SYMFILE + -export-symbols-regex REGEX + try to export only the symbols matching REGEX + -LLIBDIR search LIBDIR for required installed libraries + -lNAME OUTPUT-FILE requires the installed library libNAME + -module build a library that can dlopened + -no-fast-install disable the fast-install mode + -no-install link a not-installable executable + -no-undefined declare that a library does not refer to external symbols + -o OUTPUT-FILE create OUTPUT-FILE from the specified objects + -objectlist FILE Use a list of object files found in FILE to specify objects + -precious-files-regex REGEX + don't remove output files matching REGEX + -release RELEASE specify package release information + -rpath LIBDIR the created library will eventually be installed in LIBDIR + -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries + -static do not do any dynamic linking of libtool libraries + -version-info CURRENT[:REVISION[:AGE]] + specify library version info [each variable defaults to 0] + +All other options (arguments beginning with \`-') are ignored. + +Every other argument is treated as a filename. Files ending in \`.la' are +treated as uninstalled libtool libraries, other files are standard or library +object files. + +If the OUTPUT-FILE ends in \`.la', then a libtool library is created, +only library objects (\`.lo' files) may be specified, and \`-rpath' is +required, except when creating a convenience library. + +If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created +using \`ar' and \`ranlib', or on Windows using \`lib'. + +If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file +is created, otherwise an executable program is created." + ;; + +uninstall) + $echo \ +"Usage: $modename [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... + +Remove libraries from an installation directory. + +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 +to RM. +If FILE is a libtool library, all the files associated with it are deleted. +Otherwise, only FILE itself is deleted using RM." + ;; + +*) + $echo "$modename: invalid operation mode \`$mode'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; +esac + +$echo +$echo "Try \`$modename --help' for more information about other modes." + +exit $EXIT_SUCCESS # The TAGs below are defined such that we never get into a situation # in which we disable both kinds of libraries. Given conflicting @@ -8402,12 +6416,10 @@ # ### END LIBTOOL TAG CONFIG: disable-shared # ### BEGIN LIBTOOL TAG CONFIG: disable-static -build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` +build_old_libs=`case $build_libtool_libs in yes) $echo no;; *) $echo yes;; esac` # ### END LIBTOOL TAG CONFIG: disable-static # Local Variables: # mode:shell-script # sh-indentation:2 # End: -# vi:sw=2 - debian/patches/02-fix-spelling-add-de.po.diff0000644000000000000000000011346212067076776016051 0ustar # Add german translation and fix spelling of "display". --- po/de.po | 1674 +++++++++++++++++++++++++++++++++++++++++++++++++++++ po/en_GB.gmo |binary po/en_GB.po | 2 po/stamp-po | 1 po/swh-plugins.pot | 2 5 files changed, 1677 insertions(+), 2 deletions(-) --- /dev/null +++ swh-plugins/po/de.po @@ -0,0 +1,1674 @@ +# translation of swh-plugins 0.4.15-1 to German +# Copyright (C) 2009 Steve Harris +# This file is distributed under the same license as the swh-plugins package. +# Chris Leick , 2009. +# +msgid "" +msgstr "" +"Project-Id-Version: swh-plugins 0.4.15-1\n" +"POT-Creation-Date: 2003-03-09 16:06+0000\n" +"PO-Revision-Date: 2009-04-01 12:02+0100\n" +"Last-Translator: Chris Leick \n" +"Language-Team: German \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +#: alias_1407.xml:51 +msgid "Aliasing" +msgstr "Aliasing" + +#: alias_1407.xml:76 +msgid "Aliasing level" +msgstr "Aliasing-Stufe" + +#: alias_1407.xml:86 amp_1181.xml:83 am_pitchshift_1433.xml:177 +#: bode_shifter_1431.xml:193 bode_shifter_cv_1432.xml:195 +#: chebstortion_1430.xml:187 comb_1190.xml:132 comb_splitter_1411.xml:126 +#: crossover_dist_1404.xml:103 dc_remove_1207.xml:80 debug_1184.xml:113 +#: decimator_1202.xml:127 declip_1195.xml:84 delayorama_1402.xml:355 +#: diode_1185.xml:98 divider_1186.xml:119 dj_flanger_1438.xml:189 +#: dyson_compress_1403.xml:406 fad_delay_1192.xml:154 flanger_1191.xml:234 +#: foldover_1213.xml:94 foverdrive_1196.xml:82 freq_tracker_1418.xml:111 +#: gate_1410.xml:248 giant_flange_1437.xml:278 gong_1424.xml:425 +#: gong_beater_1439.xml:151 gsm_1215.xml:194 gverb_1216.xml:196 +#: hard_limiter_1413.xml:110 harmonic_gen_1220.xml:248 +#: hermes_filter_1200.xml:991 imp_1199.xml:290 inv_1429.xml:70 +#: mbeq_1197.xml:380 mod_delay_1419.xml:123 multivoice_chorus_1201.xml:281 +#: phasers_1217.xml:247 phasers_1217.xml:381 phasers_1217.xml:485 +#: pitch_scale_1193.xml:91 pitch_scale_1194.xml:90 plate_1423.xml:160 +#: rate_shifter_1417.xml:125 retro_flange_1208.xml:238 ringmod_1188.xml:109 +#: ringmod_1188.xml:233 satan_maximiser_1408.xml:141 sc1_1425.xml:198 +#: sc2_1426.xml:202 shaper_1187.xml:93 sifter_1210.xml:203 +#: single_para_1203.xml:119 sinus_wavewrapper_1198.xml:84 +#: smooth_decimate_1414.xml:120 split_1406.xml:72 svf_1214.xml:167 +#: tape_delay_1211.xml:262 transient_1206.xml:177 triple_para_1204.xml:255 +#: valve_1209.xml:128 valve_rect_1405.xml:156 zm1_1428.xml:80 +msgid "Input" +msgstr "Eingang" + +#: alias_1407.xml:93 amp_1181.xml:90 am_pitchshift_1433.xml:184 +#: analogue_osc_1416.xml:168 chebstortion_1430.xml:197 comb_1190.xml:139 +#: crossover_dist_1404.xml:110 dc_remove_1207.xml:87 debug_1184.xml:120 +#: decimator_1202.xml:137 declip_1195.xml:94 delayorama_1402.xml:362 +#: diode_1185.xml:105 divider_1186.xml:126 dj_flanger_1438.xml:196 +#: dyson_compress_1403.xml:413 fad_delay_1192.xml:161 flanger_1191.xml:241 +#: fm_osc_1415.xml:102 foldover_1213.xml:101 foverdrive_1196.xml:89 +#: gate_1410.xml:255 giant_flange_1437.xml:285 gong_1424.xml:432 +#: gong_beater_1439.xml:158 gsm_1215.xml:201 hard_limiter_1413.xml:117 +#: harmonic_gen_1220.xml:258 hermes_filter_1200.xml:1001 imp_1199.xml:297 +#: inv_1429.xml:77 mbeq_1197.xml:387 mod_delay_1419.xml:130 +#: multivoice_chorus_1201.xml:288 phasers_1217.xml:254 phasers_1217.xml:388 +#: phasers_1217.xml:492 pitch_scale_1193.xml:98 pitch_scale_1194.xml:97 +#: rate_shifter_1417.xml:132 retro_flange_1208.xml:245 ringmod_1188.xml:126 +#: ringmod_1188.xml:240 satan_maximiser_1408.xml:148 sc1_1425.xml:205 +#: sc2_1426.xml:209 shaper_1187.xml:103 sifter_1210.xml:210 +#: single_para_1203.xml:129 sinus_wavewrapper_1198.xml:94 +#: smooth_decimate_1414.xml:127 step_muxer_1212.xml:222 svf_1214.xml:177 +#: tape_delay_1211.xml:269 transient_1206.xml:187 triple_para_1204.xml:265 +#: valve_1209.xml:135 valve_rect_1405.xml:163 zm1_1428.xml:87 +msgid "Output" +msgstr "Ausgang" + +#: amp_1181.xml:48 +msgid "Simple amplifier" +msgstr "Einfacher Verstärker" + +#: amp_1181.xml:73 +msgid "Amps gain (dB)" +msgstr "Verstärkung (dB)" + +#: am_pitchshift_1433.xml:132 +msgid "AM pitchshifter" +msgstr "AM-Tonhöhenschieber" + +#: am_pitchshift_1433.xml:157 +msgid "Pitch shift" +msgstr "Tonhöhenschieber" + +#: am_pitchshift_1433.xml:167 +msgid "Buffer size" +msgstr "Puffergröße" + +#: analogue_osc_1416.xml:103 +msgid "Analogue Oscillator" +msgstr "Analoger Oszillator" + +#: analogue_osc_1416.xml:128 fm_osc_1415.xml:82 +msgid "Waveform (1=sin, 2=tri, 3=squ, 4=saw)" +msgstr "" +"Wellenform (1=sinusförmig, 2=dreieckig, 3=quadratisch, 4=sägezahnförmig)" + +#: analogue_osc_1416.xml:138 fm_osc_1415.xml:92 freq_tracker_1418.xml:118 +#: ringmod_1188.xml:183 single_para_1203.xml:99 +msgid "Frequency (Hz)" +msgstr "Frequenz (Hz)" + +#: analogue_osc_1416.xml:148 +msgid "Warmth" +msgstr "Wärme" + +#: analogue_osc_1416.xml:158 +msgid "Instability" +msgstr "Instabilität" + +#: bode_shifter_1431.xml:158 +msgid "Bode frequency shifter" +msgstr "Bode-Frequenzschieber" + +#: bode_shifter_1431.xml:183 +msgid "Frequency shift" +msgstr "Frequenzverschiebung" + +#: bode_shifter_1431.xml:200 bode_shifter_cv_1432.xml:222 +msgid "Down out" +msgstr "Unten heraus" + +#: bode_shifter_1431.xml:207 bode_shifter_cv_1432.xml:229 +msgid "Up out" +msgstr "Oben heraus" + +#: bode_shifter_cv_1432.xml:150 +# CV ist ein »kapazitiver Teiler«. +# Siehe auch: http://www.guitar-letter.de/Knowledge/Grundlagen/DieLautstaer +# keeinstellunginderElektrogitarre.htm +msgid "Bode frequency shifter (CV)" +msgstr "Bode-Frequenzschieber (CV)" + +#: bode_shifter_cv_1432.xml:175 +msgid "Base shift" +msgstr "Grundverschiebung" + +#: bode_shifter_cv_1432.xml:185 +msgid "Mix (-1=down, +1=up)" +msgstr "Mix (-1=ab, +1=auf)" + +#: bode_shifter_cv_1432.xml:202 +msgid "CV Attenuation" +msgstr "CV-Dämpfung" + +#: bode_shifter_cv_1432.xml:212 +msgid "Shift CV" +msgstr "CV verschieben" + +#: bode_shifter_cv_1432.xml:236 +msgid "Mix out" +msgstr "Mixen" + +#: chebstortion_1430.xml:152 +msgid "Chebyshev distortion" +msgstr "Tschebyscheff-Amplitudenverzerrung" + +#: chebstortion_1430.xml:177 valve_rect_1405.xml:146 +msgid "Distortion" +msgstr "Verzerrung" + +#: comb_1190.xml:87 +msgid "Comb Filter" +msgstr "Kammfilter" + +#: comb_1190.xml:112 comb_splitter_1411.xml:116 +msgid "Band separation (Hz)" +msgstr "Bandtrennung (Hz)" + +#: comb_1190.xml:122 flanger_1191.xml:224 giant_flange_1437.xml:258 +#: lcr_delay_1436.xml:241 phasers_1217.xml:227 phasers_1217.xml:465 +msgid "Feedback" +msgstr "Feedback" + +#: comb_splitter_1411.xml:91 +msgid "Comb Splitter" +msgstr "Kammspalter" + +#: comb_splitter_1411.xml:133 lookahead_limiter_1435.xml:200 split_1406.xml:82 +msgid "Output 1" +msgstr "Ausgang 1" + +#: comb_splitter_1411.xml:140 lookahead_limiter_1435.xml:207 split_1406.xml:92 +msgid "Output 2" +msgstr "Ausgang 2" + +#: crossover_dist_1404.xml:58 +msgid "Crossover distortion" +msgstr "Übergangs-Amplitudenverzerrung" + +#: crossover_dist_1404.xml:83 +msgid "Crossover amplitude" +msgstr "Übergangs-Amplitude" + +#: crossover_dist_1404.xml:93 smooth_decimate_1414.xml:110 +msgid "Smoothing" +msgstr "Glätten" + +#: dc_remove_1207.xml:55 +msgid "DC Offset Remover" +msgstr "DC-Versatz-Entferner" + +#: debug_1184.xml:68 +msgid "Debug Plugin" +msgstr "Fehlersuch-Erweiterung" + +#: debug_1184.xml:93 +msgid "Display all values?" +msgstr "Alle Werte anzeigen?" + +#: debug_1184.xml:103 +msgid "Reset counters?" +msgstr "Zähler zurücksetzen?" + +#: decimator_1202.xml:82 +msgid "Decimator" +msgstr "Dezimierer" + +#: decimator_1202.xml:107 +msgid "Bit depth" +msgstr "Bit-Tiefe" + +#: decimator_1202.xml:117 +msgid "Sample rate (Hz)" +msgstr "Abtastrate (Hz)" + +#: declip_1195.xml:59 +msgid "Declipper" +msgstr "Begrenzungsentferner" + +#: delayorama_1402.xml:220 +msgid "Delayorama" +msgstr "" + +#: delayorama_1402.xml:245 +msgid "Random seed" +msgstr "Anfangswert für Zufallsgenerator" + +#: delayorama_1402.xml:255 hermes_filter_1200.xml:621 +msgid "Input gain (dB)" +msgstr "Eingangsverstärkung (dB)" + +#: delayorama_1402.xml:265 dj_flanger_1438.xml:179 +msgid "Feedback (%)" +msgstr "Feedback (%)" + +#: delayorama_1402.xml:275 +msgid "Number of taps" +msgstr "Anzahl der Taps" + +#: delayorama_1402.xml:285 +msgid "First delay (s)" +msgstr "Erste Verzögerung (s)" + +#: delayorama_1402.xml:295 +msgid "Delay range (s)" +msgstr "Verzögerungsbereich (s)" + +#: delayorama_1402.xml:305 +msgid "Delay change" +msgstr "Verzögerungsänderung" + +#: delayorama_1402.xml:315 +msgid "Delay random (%)" +msgstr "Zufällige Verzögerung (%)" + +#: delayorama_1402.xml:325 +msgid "Amplitude change" +msgstr "Amplitudenänderung" + +#: delayorama_1402.xml:335 +msgid "Amplitude random (%)" +msgstr "Zufallsamplitude (%)" + +#: delayorama_1402.xml:345 gsm_1215.xml:164 plate_1423.xml:150 +msgid "Dry/wet mix" +msgstr "Trockener/nasser Mix" + +#: diode_1185.xml:63 +msgid "Diode Processor" +msgstr "Diodenprozessor" + +#: diode_1185.xml:88 +msgid "Mode (0 for none, 1 for half wave, 2 for full wave)" +msgstr "Modus (0 für keine, 1 für halbe Welle, 2 für ganze Welle)" + +#: divider_1186.xml:84 +msgid "Audio Divider (Suboctave Generator)" +msgstr "Audio-Teiler (Unteroktaven-Generator)" + +#: divider_1186.xml:109 +msgid "Denominator" +msgstr "Nenner" + +#: dj_flanger_1438.xml:124 +msgid "DJ flanger" +msgstr "" + +#: dj_flanger_1438.xml:149 +msgid "LFO sync" +msgstr "" + +#: dj_flanger_1438.xml:159 +msgid "LFO period (s)" +msgstr "LFO-Periode (s)" + +#: dj_flanger_1438.xml:169 +msgid "LFO depth (ms)" +msgstr "LFO-Tiefe (ms)" + +#: dyson_compress_1403.xml:341 +msgid "Dyson compressor" +msgstr "Dyson-Kompressor" + +#: dyson_compress_1403.xml:366 +msgid "Peak limit (dB)" +msgstr "Spitzenbegrenzung (dB)" + +#: dyson_compress_1403.xml:376 +msgid "Release time (s)" +msgstr "Abklingzeit (s)" + +#: dyson_compress_1403.xml:386 +msgid "Fast compression ratio" +msgstr "Schnelles Verdichtungsverhältnis" + +#: dyson_compress_1403.xml:396 +msgid "Compression ratio" +msgstr "Verdichtungsverhältnis" + +#: fad_delay_1192.xml:109 +msgid "Fractionally Addressed Delay Line" +msgstr "Unterbrochen adressierte Verzögerungslinie" + +#: fad_delay_1192.xml:134 +msgid "Delay (seconds)" +msgstr "Verzögerung (Sekunden)" + +#: fad_delay_1192.xml:144 +msgid "Feedback (dB)" +msgstr "Feedback (dB)" + +#: flanger_1191.xml:169 +msgid "Flanger" +msgstr "" + +#: flanger_1191.xml:194 multivoice_chorus_1201.xml:231 +msgid "Delay base (ms)" +msgstr "Verzögerungsbasis (ms)" + +#: flanger_1191.xml:204 +msgid "Max slowdown (ms)" +msgstr "Maximale Verzögerung (ms)" + +#: flanger_1191.xml:214 multivoice_chorus_1201.xml:261 +msgid "LFO frequency (Hz)" +msgstr "LFO-Frequenz (Hz)" + +#: fm_osc_1415.xml:57 +msgid "FM Oscillator" +msgstr "FM-Oszillator" + +#: foldover_1213.xml:49 +msgid "Foldover distortion" +msgstr "" + +#: foldover_1213.xml:74 +msgid "Drive" +msgstr "" + +#: foldover_1213.xml:84 +msgid "Skew" +msgstr "Schräge" + +#: foverdrive_1196.xml:47 +msgid "Fast overdrive" +msgstr "Schnell übersteuern" + +#: foverdrive_1196.xml:72 +msgid "Drive level" +msgstr "" + +#: freq_tracker_1418.xml:76 +msgid "Frequency tracker" +msgstr "Frequenz-Verfolger" + +#: freq_tracker_1418.xml:101 +msgid "Tracking speed" +msgstr "Verfolgungsgeschwindigkeit" + +#: gate_1410.xml:143 +msgid "Gate" +msgstr "Tor" + +#: gate_1410.xml:168 +msgid "LF key filter (Hz)" +msgstr "LF-Schlüsselfilter (Hz)" + +#: gate_1410.xml:178 +msgid "HF key filter (Hz)" +msgstr "HF-Schlüsselfilter (Hz)" + +#: gate_1410.xml:188 +msgid "Threshold (dB)" +msgstr "Schwelle (dB)" + +#: gate_1410.xml:198 +msgid "Attack (ms)" +msgstr "Anschlag (ms)" + +#: gate_1410.xml:208 +msgid "Hold (ms)" +msgstr "Halten (ms)" + +#: gate_1410.xml:218 +msgid "Decay (ms)" +msgstr "Ausklingen (ms)" + +#: gate_1410.xml:228 +msgid "Range (dB)" +msgstr "Bereich (dB)" + +#: gate_1410.xml:238 +msgid "Output select (-1 = key listen, 0 = gate, 1 = bypass)" +msgstr "" + +#: giant_flange_1437.xml:183 +msgid "Giant flange" +msgstr "" + +#: giant_flange_1437.xml:208 +msgid "Double delay" +msgstr "Doppelte Verzögerung" + +#: giant_flange_1437.xml:218 +msgid "LFO frequency 1 (Hz)" +msgstr "LFO-Frequenz 1 (Hz)" + +#: giant_flange_1437.xml:228 +msgid "Delay 1 range (s)" +msgstr "Verzögerung-1-Bereich (s)" + +#: giant_flange_1437.xml:238 +msgid "LFO frequency 2 (Hz)" +msgstr "LFO-Frequenz 2 (Hz)" + +#: giant_flange_1437.xml:248 +msgid "Delay 2 range (s)" +msgstr "Verzögerung-2-Bereich (s)" + +#: giant_flange_1437.xml:268 lcr_delay_1436.xml:281 +msgid "Dry/Wet level" +msgstr "Trocken-/Nass-Stufe" + +#: gong_1424.xml:130 +msgid "Gong model" +msgstr "Gongmodell" + +#: gong_1424.xml:155 +msgid "Inner damping" +msgstr "Innere Dämpfung" + +#: gong_1424.xml:165 +msgid "Outer damping" +msgstr "Äußere Dämpfung" + +#: gong_1424.xml:175 +msgid "Mic position" +msgstr "Micro-Position" + +#: gong_1424.xml:185 +msgid "Inner size 1" +msgstr "Innere Größe 1" + +#: gong_1424.xml:195 +msgid "Inner stiffness 1 +" +msgstr "Innere Starre 1 +" + +#: gong_1424.xml:205 +msgid "Inner stiffness 1 -" +msgstr "Innere Starre 1 -" + +#: gong_1424.xml:215 +msgid "Inner size 2" +msgstr "Innere Größe 2" + +#: gong_1424.xml:225 +msgid "Inner stiffness 2 +" +msgstr "Innere Starre 2 +" + +#: gong_1424.xml:235 +msgid "Inner stiffness 2 -" +msgstr "Innere Starre 2 -" + +#: gong_1424.xml:245 +msgid "Inner size 3" +msgstr "Innere Größe 3" + +#: gong_1424.xml:255 +msgid "Inner stiffness 3 +" +msgstr "Innere Starre 3 +" + +#: gong_1424.xml:265 +msgid "Inner stiffness 3 -" +msgstr "Innere Starre 3 -" + +#: gong_1424.xml:275 +msgid "Inner size 4" +msgstr "Innere Größe 4" + +#: gong_1424.xml:285 +msgid "Inner stiffness 4 +" +msgstr "Innere Starre 4 +" + +#: gong_1424.xml:295 +msgid "Inner stiffness 4 -" +msgstr "Innere Starre 4 -" + +#: gong_1424.xml:305 +msgid "Outer size 1" +msgstr "Äußere Größe 1" + +#: gong_1424.xml:315 +msgid "Outer stiffness 1 +" +msgstr "Äußere Starre 1 +" + +#: gong_1424.xml:325 +msgid "Outer stiffness 1 -" +msgstr "Äußere Starre 1 -" + +#: gong_1424.xml:335 +msgid "Outer size 2" +msgstr "Äußere Größe 2" + +#: gong_1424.xml:345 +msgid "Outer stiffness 2 +" +msgstr "Äußere Starre 2 +" + +#: gong_1424.xml:355 +msgid "Outer stiffness 2 -" +msgstr "Äußere Starre 2 -" + +#: gong_1424.xml:365 +msgid "Outer size 3" +msgstr "Äußere Größe 3" + +#: gong_1424.xml:375 +msgid "Outer stiffness 3 +" +msgstr "Äußere Starre 3 +" + +#: gong_1424.xml:385 +msgid "Outer stiffness 3 -" +msgstr "Äußere Starre 3 -" + +#: gong_1424.xml:395 +msgid "Outer size 4" +msgstr "Äußere Größe 4" + +#: gong_1424.xml:405 +msgid "Outer stiffness 4 +" +msgstr "Äußere Starre 4 +" + +#: gong_1424.xml:415 +msgid "Outer stiffness 4 -" +msgstr "Äußere Starre 4 -" + +#: gong_beater_1439.xml:96 +msgid "Gong beater" +msgstr "Gongschläger" + +#: gong_beater_1439.xml:121 +msgid "Impulse gain (dB)" +msgstr "Impuls-Zunahme" + +#: gong_beater_1439.xml:131 +msgid "Strike gain (dB)" +msgstr "Schlag-Zunahme (dB)" + +#: gong_beater_1439.xml:141 +msgid "Strike duration (s)" +msgstr "Schlagdauer (s)" + +#: gsm_1215.xml:139 +msgid "GSM simulator" +msgstr "GSM-Simulator" + +#: gsm_1215.xml:174 +msgid "Number of passes" +msgstr "Anzahl der Durchgänge" + +#: gsm_1215.xml:184 +msgid "Error rate (bits/block)" +msgstr "Fehlerquote (Bits/Block)" + +#: gverb_1216.xml:101 +msgid "GVerb" +msgstr "GVerb" + +#: gverb_1216.xml:126 +msgid "Roomsize (m)" +msgstr "Raumgröße (m)" + +#: gverb_1216.xml:136 +msgid "Reverb time (s)" +msgstr "Hallzeit (s)" + +#: gverb_1216.xml:146 plate_1423.xml:140 +msgid "Damping" +msgstr "Dämpfung" + +#: gverb_1216.xml:156 +msgid "Input bandwidth" +msgstr "Eingangsbandbreite" + +#: gverb_1216.xml:166 +msgid "Dry signal level (dB)" +msgstr "Trockene Sognalstufe (dB)" + +#: gverb_1216.xml:176 +msgid "Early reflection level (dB)" +msgstr "Anfängliche Spiegelungsstufe (dB)" + +#: gverb_1216.xml:186 +msgid "Tail level (dB)" +msgstr "Endstufe (dB)" + +#: gverb_1216.xml:203 plate_1423.xml:167 sc3_1427.xml:233 sc4_1434.xml:238 +msgid "Left output" +msgstr "Linker Ausgang" + +#: gverb_1216.xml:210 plate_1423.xml:174 sc3_1427.xml:240 sc4_1434.xml:245 +msgid "Right output" +msgstr "Rechter Ausgang" + +#: hard_limiter_1413.xml:55 +msgid "Hard Limiter" +msgstr "Harter Begrenzer" + +#: hard_limiter_1413.xml:80 +msgid "dB limit" +msgstr "dB-Begrenzung" + +#: hard_limiter_1413.xml:90 +msgid "Wet level" +msgstr "Trockene Stufe" + +#: hard_limiter_1413.xml:100 +msgid "Residue level" +msgstr "Reststufe" + +#: harmonic_gen_1220.xml:123 +msgid "Harmonic generator" +msgstr "Obertongenerator" + +#: harmonic_gen_1220.xml:148 +msgid "Fundamental magnitude" +msgstr "Grundlegende Größenordnung" + +#: harmonic_gen_1220.xml:158 +msgid "2nd harmonic magnitude" +msgstr "2. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:168 +msgid "3rd harmonic magnitude" +msgstr "3. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:178 +msgid "4th harmonic magnitude" +msgstr "4. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:188 +msgid "5th harmonic magnitude" +msgstr "5. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:198 +msgid "6th harmonic magnitude" +msgstr "6. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:208 +msgid "7th harmonic magnitude" +msgstr "7. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:218 +msgid "8th harmonic magnitude" +msgstr "8. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:228 +msgid "9th harmonic magnitude" +msgstr "9. Oberton-Größenordnung" + +#: harmonic_gen_1220.xml:238 +msgid "10th harmonic magnitude" +msgstr "10. Oberton-Größenordnung" + +#: hermes_filter_1200.xml:446 +msgid "Hermes Filter" +msgstr "Hermes-Filter" + +#: hermes_filter_1200.xml:471 +msgid "LFO1 freq (Hz)" +msgstr "LFO1-Freq. (Hz)" + +#: hermes_filter_1200.xml:481 +msgid "LFO1 wave (0 = sin, 1 = tri, 2 = saw, 3 = squ, 4 = s&h)" +msgstr "" +"LFO1-Welle (0 = sinusförmig, 1 = dreieckig, 2 = sägezahnförmig, " +"3 = quadratisch, 4 = s&h)" + +#: hermes_filter_1200.xml:491 +msgid "LFO2 freq (Hz)" +msgstr "LFO2-Freq. (Hz)" + +#: hermes_filter_1200.xml:501 +msgid "LFO2 wave (0 = sin, 1 = tri, 2 = saw, 3 = squ, 4 = s&h)" +msgstr "" +"LFO2-Welle (0 = sinusförmig, 1 = dreieckig, 2 = sägezahnförmig, " +"3 = quadratisch, 4 = s&h)" + +#: hermes_filter_1200.xml:511 +msgid "Osc1 freq (Hz)" +msgstr "Osz1-Freq. (Hz)" + +#: hermes_filter_1200.xml:521 +msgid "Osc1 wave (0 = sin, 1 = tri, 2 = saw, 3 = squ, 4 = noise)" +msgstr "" +"Osz1-Welle (0 = sinusförmig, 1 = dreieckig, 2 = sägezahnförmig, " +"3 = quadratisch, 4 = Rauschen)" + +#: hermes_filter_1200.xml:531 +msgid "Osc2 freq (Hz)" +msgstr "Osz2-Freq. (Hz)" + +#: hermes_filter_1200.xml:541 +msgid "Osc2 wave (0 = sin, 1 = tri, 2 = saw, 3 = squ, 4 = noise)" +msgstr "" +"Osz2-Welle (0 = sinusförmig, 1 = dreieckig, 2 = sägezahnförmig, " +"3 = quadratisch, 4 = Rauschen)" + +#: hermes_filter_1200.xml:551 +msgid "Ringmod 1 depth (0=none, 1=AM, 2=RM)" +msgstr "Ringmod-1-Tiefe (0=keine, 1=AM, 2=RM)" + +#: hermes_filter_1200.xml:561 +msgid "Ringmod 2 depth (0=none, 1=AM, 2=RM)" +msgstr "Ringmod-2-Tiefe (0=keine, 1=AM, 2=RM)" + +#: hermes_filter_1200.xml:571 +msgid "Ringmod 3 depth (0=none, 1=AM, 2=RM)" +msgstr "Ringmod-3-Tiefe (0=keine, 1=AM, 2=RM)" + +#: hermes_filter_1200.xml:581 +msgid "Osc1 gain (dB)" +msgstr "Osz1-Zunahme (dB)" + +#: hermes_filter_1200.xml:591 +msgid "RM1 gain (dB)" +msgstr "RM1-Zunahme (dB)" + +#: hermes_filter_1200.xml:601 +msgid "Osc2 gain (dB)" +msgstr "Osz2-Zunahme (dB)" + +#: hermes_filter_1200.xml:611 +msgid "RM2 gain (dB)" +msgstr "RM2-Zunahme (dB)" + +#: hermes_filter_1200.xml:631 +msgid "RM3 gain (dB)" +msgstr "RM3-Zunahme (dB)" + +#: hermes_filter_1200.xml:641 +msgid "Xover lower freq" +msgstr "Xover niedrigere Freq." + +#: hermes_filter_1200.xml:651 +msgid "Xover upper freq" +msgstr "Xover höhere Freq." + +#: hermes_filter_1200.xml:661 +msgid "Dist1 drive" +msgstr "Dist1-Schwung" + +#: hermes_filter_1200.xml:671 +msgid "Dist2 drive" +msgstr "Dist2-Schwung" + +#: hermes_filter_1200.xml:681 +msgid "Dist3 drive" +msgstr "Dist3-Schwung" + +#: hermes_filter_1200.xml:691 +msgid "Filt1 type (0=none, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" +msgstr "Filt1-Typ (0=kein, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" + +#: hermes_filter_1200.xml:701 +msgid "Filt1 freq" +msgstr "Filt1-Freq." + +#: hermes_filter_1200.xml:711 +msgid "Filt1 q" +msgstr "Filt1 q" + +#: hermes_filter_1200.xml:721 +msgid "Filt1 resonance" +msgstr "Filt1 Resonanz" + +#: hermes_filter_1200.xml:731 +msgid "Filt1 LFO1 level" +msgstr "Filt1-LFO1-Stufe" + +#: hermes_filter_1200.xml:741 +msgid "Filt1 LFO2 level" +msgstr "Filt1-LFO2-Stufe" + +#: hermes_filter_1200.xml:751 +msgid "Filt2 type (0=none, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" +msgstr "Filt2-Typ (0=kein, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" + +#: hermes_filter_1200.xml:761 +msgid "Filt2 freq" +msgstr "Filt2-Freq." + +#: hermes_filter_1200.xml:771 +msgid "Filt2 q" +msgstr "Filt2 q" + +#: hermes_filter_1200.xml:781 +msgid "Filt2 resonance" +msgstr "Filt2 Resonanz" + +#: hermes_filter_1200.xml:791 +msgid "Filt2 LFO1 level" +msgstr "Filt2-LFO1-Stufe" + +#: hermes_filter_1200.xml:801 +msgid "Filt2 LFO2 level" +msgstr "Filt2-LFO2-Stufe" + +#: hermes_filter_1200.xml:811 +msgid "Filt3 type (0=none, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" +msgstr "Filt3-Typ (0=kein, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" + +#: hermes_filter_1200.xml:821 +msgid "Filt3 freq" +msgstr "Filt3-Freq." + +#: hermes_filter_1200.xml:831 +msgid "Filt3 q" +msgstr "Filt3 q" + +#: hermes_filter_1200.xml:841 +msgid "Filt3 resonance" +msgstr "Filt3 Resonanz" + +#: hermes_filter_1200.xml:851 +msgid "Filt3 LFO1 level" +msgstr "Filt3-LFO1-Stufe" + +#: hermes_filter_1200.xml:861 +msgid "Filt3 LFO2 level" +msgstr "Filt3-LFO2-Stufe" + +#: hermes_filter_1200.xml:871 +msgid "Delay1 length (s)" +msgstr "Verzögerung1-Länge (s)" + +#: hermes_filter_1200.xml:881 +msgid "Delay1 feedback" +msgstr "Verzögerung1-Feedback" + +#: hermes_filter_1200.xml:891 +msgid "Delay1 wetness" +msgstr "Verzögerung1-Nässe" + +#: hermes_filter_1200.xml:901 +msgid "Delay2 length (s)" +msgstr "Verzögerung2-Länge (s)" + +#: hermes_filter_1200.xml:911 +msgid "Delay2 feedback" +msgstr "Verzögerung2-Feedback" + +#: hermes_filter_1200.xml:921 +msgid "Delay2 wetness" +msgstr "Verzögerung2-Nässe" + +#: hermes_filter_1200.xml:931 +msgid "Delay3 length (s)" +msgstr "Verzögerung3-Länge (s)" + +#: hermes_filter_1200.xml:941 +msgid "Delay3 feedback" +msgstr "Verzögerung3-Feedback" + +#: hermes_filter_1200.xml:951 +msgid "Delay3 wetness" +msgstr "Verzögerung3-Nässe" + +#: hermes_filter_1200.xml:961 triple_para_1204.xml:135 +msgid "Band 1 gain (dB)" +msgstr "Band-1-Zunahme (dB)" + +#: hermes_filter_1200.xml:971 triple_para_1204.xml:165 +msgid "Band 2 gain (dB)" +msgstr "Band-2-Zunahme (dB)" + +#: hermes_filter_1200.xml:981 triple_para_1204.xml:195 +msgid "Band 3 gain (dB)" +msgstr "Band-3-Zunahme (dB)" + +#: imp_1199.xml:235 +msgid "Impulse convolver" +msgstr "Impuls-Zusammenroller" + +#: imp_1199.xml:260 +msgid "Impulse ID" +msgstr "Impuls-ID" + +#: imp_1199.xml:270 +msgid "High latency mode" +msgstr "Modus mit hoher Wartezeit" + +#: imp_1199.xml:280 single_para_1203.xml:89 +msgid "Gain (dB)" +msgstr "Zunahme (dB)" + +#: inv_1429.xml:45 +msgid "Inverter" +msgstr "Wechselrichter" + +#: karaoke_1409.xml:50 +msgid "Karaoke" +msgstr "Karaoke" + +#: karaoke_1409.xml:75 +msgid "Vocal volume (dB)" +msgstr "Stimmenlautstärke" + +#: karaoke_1409.xml:85 +msgid "Left in" +msgstr "Links ein" + +#: karaoke_1409.xml:92 +msgid "Right in" +msgstr "Rechts ein" + +#: karaoke_1409.xml:99 +msgid "Left out" +msgstr "Links aus" + +#: karaoke_1409.xml:106 +msgid "Right out" +msgstr "Rechts aus" + +#: lcr_delay_1436.xml:156 +msgid "L/C/R Delay" +msgstr "L/C/R-Verzögerung" + +#: lcr_delay_1436.xml:181 +msgid "L delay (ms)" +msgstr "L-Verzögerung (ms)" + +#: lcr_delay_1436.xml:191 +msgid "L level" +msgstr "L-Stufe" + +#: lcr_delay_1436.xml:201 +msgid "C delay (ms)" +msgstr "C-Verzögerung (ms)" + +#: lcr_delay_1436.xml:211 +msgid "C level" +msgstr "C-Stufe" + +#: lcr_delay_1436.xml:221 +msgid "R delay (ms)" +msgstr "R-Verzögerung (ms)" + +#: lcr_delay_1436.xml:231 +msgid "R level" +msgstr "R-Stufe" + +#: lcr_delay_1436.xml:251 +msgid "High damp (%)" +msgstr "Hohe Feuchtigkeit (%)" + +#: lcr_delay_1436.xml:261 +msgid "Low damp (%)" +msgstr "Niedrige Feuchtigkeit (%)" + +#: lcr_delay_1436.xml:271 +msgid "Spread" +msgstr "Ausbreitung" + +#: lcr_delay_1436.xml:291 +msgid "L input" +msgstr "L-Eingang" + +#: lcr_delay_1436.xml:298 +msgid "R input" +msgstr "R-Eingang" + +#: lcr_delay_1436.xml:305 +msgid "L output" +msgstr "L-Ausgang" + +#: lcr_delay_1436.xml:312 +msgid "R output" +msgstr "R-Ausgang" + +#: lookahead_limiter_1435.xml:131 +msgid "Lookahead limiter" +msgstr "Vorgriff-Begrenzer" + +#: lookahead_limiter_1435.xml:156 +msgid "Limit (dB)" +msgstr "Begrenzung (dB)" + +#: lookahead_limiter_1435.xml:166 +msgid "Lookahead delay" +msgstr "Vorgriff-Verzögerung" + +#: lookahead_limiter_1435.xml:176 +msgid "Attenuation (dB)" +msgstr "Dämpfung (dB)" + +#: lookahead_limiter_1435.xml:186 step_muxer_1212.xml:166 +msgid "Input 1" +msgstr "Eingang 1" + +#: lookahead_limiter_1435.xml:193 step_muxer_1212.xml:173 +msgid "Input 2" +msgstr "Eingang 2" + +#: matrix_ms_st_1421.xml:45 +msgid "Matrix: MS to Stereo" +msgstr "Matrix: MS zu Stereo" + +#: matrix_ms_st_1421.xml:70 matrix_spatialiser_1422.xml:205 +msgid "Width" +msgstr "Breite" + +#: matrix_ms_st_1421.xml:80 matrix_st_ms_1420.xml:84 +msgid "Mid" +msgstr "Mittlere" + +#: matrix_ms_st_1421.xml:87 matrix_st_ms_1420.xml:91 +msgid "Side" +msgstr "Seite" + +#: matrix_ms_st_1421.xml:94 matrix_st_ms_1420.xml:70 +msgid "Left" +msgstr "Links" + +#: matrix_ms_st_1421.xml:101 matrix_st_ms_1420.xml:77 +msgid "Right" +msgstr "Rechts" + +#: matrix_spatialiser_1422.xml:166 +msgid "Matrix Spatialiser" +msgstr "" + +#: matrix_spatialiser_1422.xml:191 +msgid "Input L" +msgstr "Eingang L" + +#: matrix_spatialiser_1422.xml:198 +msgid "Input R" +msgstr "Eingang R" + +#: matrix_spatialiser_1422.xml:215 +msgid "Output L" +msgstr "Ausgang L" + +#: matrix_spatialiser_1422.xml:222 +msgid "Output R" +msgstr "Ausgang R" + +#: matrix_st_ms_1420.xml:45 +msgid "Matrix: Stereo to MS" +msgstr "Matrix: Stereo zu MS" + +#: mbeq_1197.xml:205 +msgid "Multiband EQ" +msgstr "Multiband EQ" + +#: mbeq_1197.xml:230 +msgid "50Hz gain (low shelving)" +msgstr "50Hz Zunahme (niedrige Aufstellung)" + +#: mbeq_1197.xml:240 +msgid "100Hz gain" +msgstr "100Hz Zunahme" + +#: mbeq_1197.xml:250 +msgid "156Hz gain" +msgstr "156Hz Zunahme" + +#: mbeq_1197.xml:260 +msgid "220Hz gain" +msgstr "220Hz Zunahme" + +#: mbeq_1197.xml:270 +msgid "311Hz gain" +msgstr "311Hz Zunahme" + +#: mbeq_1197.xml:280 +msgid "440Hz gain" +msgstr "440Hz Zunahme" + +#: mbeq_1197.xml:290 +msgid "622Hz gain" +msgstr "622Hz Zunahme" + +#: mbeq_1197.xml:300 +msgid "880Hz gain" +msgstr "880Hz Zunahme" + +#: mbeq_1197.xml:310 +msgid "1250Hz gain" +msgstr "1250Hz Zunahme" + +#: mbeq_1197.xml:320 +msgid "1750Hz gain" +msgstr "1750Hz Zunahme" + +#: mbeq_1197.xml:330 +msgid "2500Hz gain" +msgstr "2500Hz Zunahme" + +#: mbeq_1197.xml:340 +msgid "3500Hz gain" +msgstr "3500Hz Zunahme" + +#: mbeq_1197.xml:350 +msgid "5000Hz gain" +msgstr "5000Hz Zunahme" + +#: mbeq_1197.xml:360 +msgid "10000Hz gain" +msgstr "10000Hz Zunahme" + +#: mbeq_1197.xml:370 +msgid "20000Hz gain" +msgstr "20000Hz Zunahme" + +#: mod_delay_1419.xml:78 +msgid "Modulatable delay" +msgstr "Regelbare Verzögerung" + +#: mod_delay_1419.xml:103 +msgid "Base delay (s)" +msgstr "Grundverzögerung (s)" + +#: mod_delay_1419.xml:113 +msgid "Delay (s)" +msgstr "Verzögerung (s)" + +#: multivoice_chorus_1201.xml:196 +msgid "Multivoice Chorus" +msgstr "Mehrstimmiger Chor" + +#: multivoice_chorus_1201.xml:221 +msgid "Number of voices" +msgstr "Anzahl der Stimmen" + +#: multivoice_chorus_1201.xml:241 +msgid "Voice separation (ms)" +msgstr "Stimmentrennung (ms)" + +#: multivoice_chorus_1201.xml:251 +msgid "Detune (%)" +msgstr "Verstimmung (%)" + +#: multivoice_chorus_1201.xml:271 +msgid "Output attenuation (dB)" +msgstr "Ausgangsdämpfung (dB)" + +#: phasers_1217.xml:182 +msgid "LFO Phaser" +msgstr "" + +#: phasers_1217.xml:207 +msgid "LFO rate (Hz)" +msgstr "LFO-Rate (Hz)" + +#: phasers_1217.xml:217 +msgid "LFO depth" +msgstr "LFO-Tiefe" + +#: phasers_1217.xml:237 phasers_1217.xml:475 +msgid "Spread (octaves)" +msgstr "Ausbreitung (Oktaven)" + +#: phasers_1217.xml:276 +msgid "4 x 4 pole allpass" +msgstr "4 x 4 Pol-Allpass" + +#: phasers_1217.xml:301 +msgid "Frequency 1" +msgstr "Frequenz 1" + +#: phasers_1217.xml:311 +msgid "Feedback 1" +msgstr "Feedback 1" + +#: phasers_1217.xml:321 +msgid "Frequency 2" +msgstr "Frequenz 2" + +#: phasers_1217.xml:331 +msgid "Feedback 2" +msgstr "Feedback 2" + +#: phasers_1217.xml:341 +msgid "Frequency 3" +msgstr "Frequenz 3" + +#: phasers_1217.xml:351 +msgid "Feedback 3" +msgstr "Feedback 3" + +#: phasers_1217.xml:361 +msgid "Frequency 4" +msgstr "Frequenz 4" + +#: phasers_1217.xml:371 +msgid "Feedback 4" +msgstr "Feedback 4" + +#: phasers_1217.xml:410 +msgid "Auto phaser" +msgstr "" + +#: phasers_1217.xml:435 +msgid "Attack time (s)" +msgstr "Anschlagzeit (s)" + +#: phasers_1217.xml:445 +msgid "Decay time (s)" +msgstr "Abklingzeit (s)" + +#: phasers_1217.xml:455 +msgid "Modulation depth" +msgstr "Regeltiefe" + +#: pitch_scale_1193.xml:56 +msgid "Pitch Scaler" +msgstr "" + +#: pitch_scale_1193.xml:81 pitch_scale_1194.xml:80 +msgid "Pitch co-efficient" +msgstr "" + +#: pitch_scale_1194.xml:55 +msgid "Higher Quality Pitch Scaler" +msgstr "" + +#: plate_1423.xml:105 +msgid "Plate reverb" +msgstr "Blech-Hall" + +#: plate_1423.xml:130 +msgid "Reverb time" +msgstr "Hallzeit" + +#: rate_shifter_1417.xml:90 +msgid "Rate shifter" +msgstr "Anteil-Schieber" + +#: rate_shifter_1417.xml:115 +msgid "Rate" +msgstr "Anteil" + +#: retro_flange_1208.xml:193 +msgid "Retro Flanger" +msgstr "" + +#: retro_flange_1208.xml:218 +msgid "Average stall (ms)" +msgstr "" + +#: retro_flange_1208.xml:228 +msgid "Flange frequency (Hz)" +msgstr "" + +#: ringmod_1188.xml:74 +msgid "Ringmod with two inputs" +msgstr "Ringmod mit zwei Eingängen" + +#: ringmod_1188.xml:99 ringmod_1188.xml:173 +msgid "Modulation depth (0=none, 1=AM, 2=RM)" +msgstr "Regeltiefe (0=keine, 1=AM, 2=RM)" + +#: ringmod_1188.xml:116 +msgid "Modulator" +msgstr "Regler" + +#: ringmod_1188.xml:148 +msgid "Ringmod with LFO" +msgstr "Ringmod mit LFO" + +#: ringmod_1188.xml:193 +msgid "Sine level" +msgstr "Sinus-Stufe" + +#: ringmod_1188.xml:203 +msgid "Triangle level" +msgstr "Triangelstufe" + +#: ringmod_1188.xml:213 +msgid "Sawtooth level" +msgstr "Sägezahnstufe" + +#: ringmod_1188.xml:223 +msgid "Square level" +msgstr "Quadratstufe" + +#: satan_maximiser_1408.xml:96 +msgid "Barry's Satan Maximiser" +msgstr "Barrys Satan-Maximierer" + +#: satan_maximiser_1408.xml:121 +msgid "Decay time (samples)" +msgstr "Ausklingzeit (Muster)" + +#: satan_maximiser_1408.xml:131 +msgid "Knee point (dB)" +msgstr "Kniepunkt (dB)" + +#: sc1_1425.xml:113 +msgid "SC1" +msgstr "SC1" + +#: sc1_1425.xml:138 sc2_1426.xml:135 sc3_1427.xml:142 sc4_1434.xml:144 +msgid "Attack time (ms)" +msgstr "Anschlagzeit (ms)" + +#: sc1_1425.xml:148 sc2_1426.xml:145 sc3_1427.xml:152 sc4_1434.xml:154 +msgid "Release time (ms)" +msgstr "Freigabezeit (ms)" + +#: sc1_1425.xml:158 sc2_1426.xml:155 sc3_1427.xml:162 sc4_1434.xml:164 +msgid "Threshold level (dB)" +msgstr "Schwellenstufe (dB)" + +#: sc1_1425.xml:168 sc2_1426.xml:165 sc3_1427.xml:172 sc4_1434.xml:174 +msgid "Ratio (1:n)" +msgstr "Verhältnis (1:n)" + +#: sc1_1425.xml:178 sc2_1426.xml:175 sc3_1427.xml:182 sc4_1434.xml:184 +msgid "Knee radius (dB)" +msgstr "Knieradius (dB)" + +#: sc1_1425.xml:188 sc2_1426.xml:185 sc3_1427.xml:192 sc4_1434.xml:194 +msgid "Makeup gain (dB)" +msgstr "Aufbauzunahme (dB)" + +#: sc2_1426.xml:110 +msgid "SC2" +msgstr "SC2" + +#: sc2_1426.xml:195 sc3_1427.xml:212 +msgid "Sidechain" +msgstr "" + +#: sc3_1427.xml:117 +msgid "SC3" +msgstr "SC3" + +#: sc3_1427.xml:202 +msgid "Chain balance" +msgstr "" + +#: sc3_1427.xml:219 sc4_1434.xml:224 +msgid "Left input" +msgstr "Linker Eingang" + +#: sc3_1427.xml:226 sc4_1434.xml:231 +msgid "Right input" +msgstr "Rechter Eingang" + +#: sc4_1434.xml:119 +msgid "SC4" +msgstr "SC4" + +#: sc4_1434.xml:204 +msgid "Amplitude (dB)" +msgstr "Amplitude (dB)" + +#: sc4_1434.xml:214 +msgid "Gain reduction (dB)" +msgstr "Zunahmeverminderung (dB)" + +#: shaper_1187.xml:58 +msgid "Wave shaper" +msgstr "Wellenformer" + +#: shaper_1187.xml:83 +msgid "Waveshape" +msgstr "Wellenform" + +#: sifter_1210.xml:168 +msgid "Signal sifter" +msgstr "Signal-Schieber" + +#: sifter_1210.xml:193 +msgid "Sift size" +msgstr "Schiebegröße" + +#: single_para_1203.xml:64 +msgid "Single band parametric" +msgstr "Einzelband parametrisch" + +#: single_para_1203.xml:109 +msgid "Bandwidth (octaves)" +msgstr "Bandbreite (Oktaven)" + +#: sinus_wavewrapper_1198.xml:49 +msgid "Sinus wavewrapper" +msgstr "Sinuswellen-Hülle" + +#: sinus_wavewrapper_1198.xml:74 +msgid "Wrap degree" +msgstr "Verhüllungsgrad" + +#: smooth_decimate_1414.xml:75 +msgid "Smooth Decimator" +msgstr "Glatter Verminderer" + +#: smooth_decimate_1414.xml:100 +msgid "Resample rate" +msgstr "Wiederabtast-Rate" + +#: split_1406.xml:47 +msgid "Mono to Stereo splitter" +msgstr "Mono-zu-Stereo-Spalter" + +#: step_muxer_1212.xml:124 +msgid "Step Demuxer" +msgstr "" + +#: step_muxer_1212.xml:149 +msgid "Crossfade time (in ms)" +msgstr "" + +#: step_muxer_1212.xml:159 +msgid "Clock" +msgstr "Takt" + +#: step_muxer_1212.xml:180 +msgid "Input 3" +msgstr "Eingang 3" + +#: step_muxer_1212.xml:187 +msgid "Input 4" +msgstr "Eingang 4" + +#: step_muxer_1212.xml:194 +msgid "Input 5" +msgstr "Eingang 5" + +#: step_muxer_1212.xml:201 +msgid "Input 6" +msgstr "Eingang 6" + +#: step_muxer_1212.xml:208 +msgid "Input 7" +msgstr "Eingang 7" + +#: step_muxer_1212.xml:215 +msgid "Input 8" +msgstr "Eingang 8" + +#: surround_encoder_1401.xml:97 +msgid "Surround matrix encoder" +msgstr "Umgebungsmatrix-Geber" + +#: surround_encoder_1401.xml:122 +msgid "L" +msgstr "L" + +#: surround_encoder_1401.xml:129 +msgid "R" +msgstr "R" + +#: surround_encoder_1401.xml:136 +msgid "C" +msgstr "C" + +#: surround_encoder_1401.xml:143 +msgid "S" +msgstr "S" + +#: surround_encoder_1401.xml:150 +msgid "Lt" +msgstr "Lt" + +#: surround_encoder_1401.xml:157 +msgid "Rt" +msgstr "Rt" + +#: svf_1214.xml:142 +msgid "State Variable Filter" +msgstr "Statusvariablenfilter" + +#: svf_1214.xml:187 +msgid "Filter type (0=none, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" +msgstr "Filtertyp (0=kein, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)" + +#: svf_1214.xml:197 +msgid "Filter freq" +msgstr "Filter Freq." + +#: svf_1214.xml:207 +msgid "Filter Q" +msgstr "Filter Q" + +#: svf_1214.xml:217 +msgid "Filter resonance" +msgstr "Filterresonanz" + +#: tape_delay_1211.xml:137 +msgid "Tape Delay Simulation" +msgstr "Bandverzögerungs-Simulation" + +#: tape_delay_1211.xml:162 +msgid "Tape speed (inches/sec, 1=normal)" +msgstr "Bandgeschwindigkeit (Inch/Sek, 1=Normal)" + +#: tape_delay_1211.xml:172 +msgid "Dry level (dB)" +msgstr "Trockenstufe (dB)" + +#: tape_delay_1211.xml:182 +msgid "Tap 1 distance (inches)" +msgstr "Tap-1-Entfernung (Inch)" + +#: tape_delay_1211.xml:192 +msgid "Tap 1 level (dB)" +msgstr "Tap-1-Stufe (dB)" + +#: tape_delay_1211.xml:202 +msgid "Tap 2 distance (inches)" +msgstr "Tap-2-Entfernung (Inch)" + +#: tape_delay_1211.xml:212 +msgid "Tap 2 level (dB)" +msgstr "Tap-2-Stufe (dB)" + +#: tape_delay_1211.xml:222 +msgid "Tap 3 distance (inches)" +msgstr "Tap-3-Entfernung (Inch)" + +#: tape_delay_1211.xml:232 +msgid "Tap 3 level (dB)" +msgstr "Tap-3-Stufe (dB)" + +#: tape_delay_1211.xml:242 +msgid "Tap 4 distance (inches)" +msgstr "Tap-4-Entfernung (Inch)" + +#: tape_delay_1211.xml:252 +msgid "Tap 4 level (dB)" +msgstr "Tap-4-Stufe (dB)" + +#: transient_1206.xml:132 +msgid "Transient mangler" +msgstr "" + +#: transient_1206.xml:157 +msgid "Attack speed" +msgstr "Anschlaggeschwindigkeit" + +#: transient_1206.xml:167 +msgid "Sustain time" +msgstr "Ausklingzeit" + +#: triple_para_1204.xml:80 +msgid "Triple band parametric with shelves" +msgstr "" + +#: triple_para_1204.xml:105 +msgid "Low-shelving gain (dB)" +msgstr "" + +#: triple_para_1204.xml:115 +msgid "Low-shelving frequency (Hz)" +msgstr "" + +#: triple_para_1204.xml:125 +msgid "Low-shelving slope" +msgstr "" + +#: triple_para_1204.xml:145 +msgid "Band 1 frequency (Hz)" +msgstr "Band-1-Frequenz (Hz)" + +#: triple_para_1204.xml:155 +msgid "Band 1 bandwidth (octaves)" +msgstr "Band-1-Bandbreite (Oktaven)" + +#: triple_para_1204.xml:175 +msgid "Band 2 frequency (Hz)" +msgstr "Band-2-Frequenz (Hz)" + +#: triple_para_1204.xml:185 +msgid "Band 2 bandwidth (octaves)" +msgstr "Band-2-Bandbreite (Oktaven)" + +#: triple_para_1204.xml:205 +msgid "Band 3 frequency (Hz)" +msgstr "Band-3-Frequenz (Hz)" + +#: triple_para_1204.xml:215 +msgid "Band 3 bandwidth (octaves)" +msgstr "Band-3-Bandbreite (Oktaven)" + +#: triple_para_1204.xml:225 +msgid "High-shelving gain (dB)" +msgstr "" + +#: triple_para_1204.xml:235 +msgid "High-shelving frequency (Hz)" +msgstr "" + +#: triple_para_1204.xml:245 +msgid "High-shelving slope" +msgstr "" + +#: valve_1209.xml:83 +msgid "Valve saturation" +msgstr "Ventilsättigung" + +#: valve_1209.xml:108 +msgid "Distortion level" +msgstr "Amplitudenverzerrungsstufe" + +#: valve_1209.xml:118 +msgid "Distortion character" +msgstr "Amplitudenverzerrungscharakter" + +#: valve_rect_1405.xml:111 +msgid "Valve rectifier" +msgstr "Ventilgleichrichter" + +#: valve_rect_1405.xml:136 +msgid "Sag level" +msgstr "Durchhangstufe" + +#: wave_terrain_1412.xml:49 +msgid "Wave Terrain Oscillator" +msgstr "Wellenbodenoszillator" + +#: wave_terrain_1412.xml:74 +msgid "x" +msgstr "x" + +#: wave_terrain_1412.xml:81 +msgid "y" +msgstr "y" + +#: wave_terrain_1412.xml:88 +msgid "z" +msgstr "z" + +#: zm1_1428.xml:55 +msgid "z-1" +msgstr "z-1" Binary files /dev/null and swh-plugins/po/en_GB.gmo differ --- swh-plugins.orig/po/en_GB.po +++ swh-plugins/po/en_GB.po @@ -206,7 +206,7 @@ msgid "Debug Plugin" msgstr "" #: debug_1184.xml:93 -msgid "Diplay all values?" +msgid "Display all values?" msgstr "" #: debug_1184.xml:103 --- swh-plugins.orig/po/swh-plugins.pot +++ swh-plugins/po/swh-plugins.pot @@ -206,7 +206,7 @@ msgid "Debug Plugin" msgstr "" #: debug_1184.xml:93 -msgid "Diplay all values?" +msgid "Display all values?" msgstr "" #: debug_1184.xml:103 debian/patches/series0000644000000000000000000000017112067076342012040 0ustar 01-dont-use-march.diff 02-fix-spelling-add-de.po.diff 03-uptodate-ltmain.diff 04-nosetlocale.diff 05-mbeq_crash_fix.diff debian/patches/04-nosetlocale.diff0000644000000000000000000016201212067074742014213 0ustar Subject: Do not call setlocale(). Author: Daniel Gibson Bug-Debian: http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=672705 Forwarded: Steve Harris --- alias_1407.c | 1 - alias_1407.so.c | 1 - allpass_1895.c | 1 - allpass_1895.so.c | 1 - am_pitchshift_1433.c | 1 - am_pitchshift_1433.so.c | 1 - amp_1181.c | 1 - amp_1181.so.c | 1 - analogue_osc_1416.c | 1 - analogue_osc_1416.so.c | 1 - bandpass_a_iir_1893.c | 1 - bandpass_a_iir_1893.so.c | 1 - bandpass_iir_1892.c | 1 - bandpass_iir_1892.so.c | 1 - bode_shifter_1431.c | 1 - bode_shifter_1431.so.c | 1 - bode_shifter_cv_1432.c | 1 - bode_shifter_cv_1432.so.c | 1 - butterworth_1902.c | 1 - butterworth_1902.so.c | 1 - chebstortion_1430.c | 1 - chebstortion_1430.so.c | 1 - comb_1190.c | 1 - comb_1190.so.c | 1 - comb_1887.c | 1 - comb_1887.so.c | 1 - comb_splitter_1411.c | 1 - comb_splitter_1411.so.c | 1 - const_1909.c | 1 - crossover_dist_1404.c | 1 - crossover_dist_1404.so.c | 1 - dc_remove_1207.c | 1 - dc_remove_1207.so.c | 1 - debug_1184.so.c | 1 - decay_1886.c | 1 - decay_1886.so.c | 1 - decimator_1202.c | 1 - decimator_1202.so.c | 1 - declip_1195.c | 1 - declip_1195.so.c | 1 - delay_1898.c | 1 - delay_1898.so.c | 1 - delayorama_1402.c | 1 - delayorama_1402.so.c | 1 - diode_1185.c | 1 - diode_1185.so.c | 1 - divider_1186.c | 1 - divider_1186.so.c | 1 - dj_eq_1901.c | 1 - dj_eq_1901.so.c | 1 - dj_flanger_1438.c | 1 - dj_flanger_1438.so.c | 1 - dyson_compress_1403.c | 1 - dyson_compress_1403.so.c | 1 - fad_delay_1192.c | 1 - fad_delay_1192.so.c | 1 - fast_lookahead_limiter_1913.c | 1 - flanger_1191.c | 1 - flanger_1191.so.c | 1 - fm_osc_1415.c | 1 - fm_osc_1415.so.c | 1 - foldover_1213.c | 1 - foldover_1213.so.c | 1 - foverdrive_1196.c | 1 - foverdrive_1196.so.c | 1 - freq_tracker_1418.c | 1 - freq_tracker_1418.so.c | 1 - gate_1410.c | 1 - gate_1410.so.c | 1 - gate_1921.so.c | 1 - giant_flange_1437.c | 1 - giant_flange_1437.so.c | 1 - gong_1424.c | 1 - gong_1424.so.c | 1 - gong_beater_1439.c | 1 - gong_beater_1439.so.c | 1 - gsm_1215.c | 1 - gsm_1215.so.c | 1 - gverb_1216.c | 1 - gverb_1216.so.c | 1 - hard_limiter_1413.c | 1 - hard_limiter_1413.so.c | 1 - harmonic_gen_1220.c | 1 - hermes_filter_1200.c | 1 - hermes_filter_1200.so.c | 1 - highpass_iir_1890.c | 1 - highpass_iir_1890.so.c | 1 - hilbert_1440.c | 1 - hilbert_1440.so.c | 1 - imp_1199.c | 1 - imp_1199.so.c | 1 - impulse_1885.c | 1 - impulse_1885.so.c | 1 - inv_1429.c | 1 - inv_1429.so.c | 1 - karaoke_1409.c | 1 - karaoke_1409.so.c | 1 - latency_1914.c | 1 - lcr_delay_1436.c | 1 - lcr_delay_1436.so.c | 1 - lookahead_limiter_1435.so.c | 1 - lookahead_limiter_const_1906.so.c | 1 - lowpass_iir_1891.c | 1 - lowpass_iir_1891.so.c | 1 - ls_filter_1908.c | 1 - ls_filter_1908.so.c | 1 - makestub.pl | 1 - matrix_ms_st_1421.c | 1 - matrix_ms_st_1421.so.c | 1 - matrix_spatialiser_1422.c | 1 - matrix_spatialiser_1422.so.c | 1 - matrix_st_ms_1420.c | 1 - matrix_st_ms_1420.so.c | 1 - mbeq_1197.c | 1 - mbeq_1197.so.c | 1 - mod_delay_1419.c | 1 - mod_delay_1419.so.c | 1 - multivoice_chorus_1201.c | 1 - multivoice_chorus_1201.so.c | 1 - notch_iir_1894.c | 1 - notch_iir_1894.so.c | 1 - phasers_1217.c | 1 - phasers_1217.so.c | 1 - pitch_scale_1193.c | 1 - pitch_scale_1193.so.c | 1 - pitch_scale_1194.c | 1 - pitch_scale_1194.so.c | 1 - plate_1423.c | 1 - plate_1423.so.c | 1 - pointer_cast_1910.c | 1 - rate_shifter_1417.c | 1 - rate_shifter_1417.so.c | 1 - retro_flange_1208.c | 1 - retro_flange_1208.so.c | 1 - revdelay_1605.c | 1 - revdelay_1605.so.c | 1 - ringmod_1188.c | 1 - ringmod_1188.so.c | 1 - satan_maximiser_1408.c | 1 - satan_maximiser_1408.so.c | 1 - sc1_1425.c | 1 - sc1_1425.so.c | 1 - sc2_1426.c | 1 - sc2_1426.so.c | 1 - sc3_1427.c | 1 - sc3_1427.so.c | 1 - sc4_1434.so.c | 1 - sc4_1882.c | 1 - sc4_1882.so.c | 1 - sc4m_1916.c | 1 - se4_1883.c | 1 - se4_1883.so.c | 1 - shaper_1187.c | 1 - shaper_1187.so.c | 1 - sifter_1210.c | 1 - sifter_1210.so.c | 1 - sin_cos_1881.c | 1 - sin_cos_1881.so.c | 1 - single_para_1203.c | 1 - single_para_1203.so.c | 1 - sinus_wavewrapper_1198.c | 1 - sinus_wavewrapper_1198.so.c | 1 - smooth_decimate_1414.c | 1 - smooth_decimate_1414.so.c | 1 - split_1406.c | 1 - split_1406.so.c | 1 - step_muxer_1212.c | 1 - step_muxer_1212.so.c | 1 - surround_encoder_1401.c | 1 - surround_encoder_1401.so.c | 1 - svf_1214.c | 1 - svf_1214.so.c | 1 - tape_delay_1211.c | 1 - tape_delay_1211.so.c | 1 - transient_1206.c | 1 - transient_1206.so.c | 1 - triple_para_1204.c | 1 - triple_para_1204.so.c | 1 - valve_1209.c | 1 - valve_1209.so.c | 1 - valve_rect_1405.c | 1 - valve_rect_1405.so.c | 1 - vynil_1905.c | 1 - vynil_1905.so.c | 1 - wave_terrain_1412.c | 1 - wave_terrain_1412.so.c | 1 - xfade_1915.c | 1 - zm1_1428.c | 1 - zm1_1428.so.c | 1 - 189 files changed, 189 deletions(-) --- swh-plugins.orig/alias_1407.c +++ swh-plugins/alias_1407.c @@ -168,7 +168,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/alias_1407.so.c +++ swh-plugins/alias_1407.so.c @@ -168,7 +168,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/allpass_1895.c +++ swh-plugins/allpass_1895.c @@ -1124,7 +1124,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/allpass_1895.so.c +++ swh-plugins/allpass_1895.so.c @@ -1124,7 +1124,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/amp_1181.c +++ swh-plugins/amp_1181.c @@ -161,7 +161,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/amp_1181.so.c +++ swh-plugins/amp_1181.so.c @@ -161,7 +161,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/am_pitchshift_1433.c +++ swh-plugins/am_pitchshift_1433.c @@ -366,7 +366,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/am_pitchshift_1433.so.c +++ swh-plugins/am_pitchshift_1433.so.c @@ -366,7 +366,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/analogue_osc_1416.c +++ swh-plugins/analogue_osc_1416.c @@ -304,7 +304,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/analogue_osc_1416.so.c +++ swh-plugins/analogue_osc_1416.so.c @@ -304,7 +304,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bandpass_a_iir_1893.c +++ swh-plugins/bandpass_a_iir_1893.c @@ -203,7 +203,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bandpass_a_iir_1893.so.c +++ swh-plugins/bandpass_a_iir_1893.so.c @@ -203,7 +203,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bandpass_iir_1892.c +++ swh-plugins/bandpass_iir_1892.c @@ -258,7 +258,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bandpass_iir_1892.so.c +++ swh-plugins/bandpass_iir_1892.so.c @@ -258,7 +258,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bode_shifter_1431.c +++ swh-plugins/bode_shifter_1431.c @@ -372,7 +372,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bode_shifter_1431.so.c +++ swh-plugins/bode_shifter_1431.so.c @@ -372,7 +372,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bode_shifter_cv_1432.c +++ swh-plugins/bode_shifter_cv_1432.c @@ -400,7 +400,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/bode_shifter_cv_1432.so.c +++ swh-plugins/bode_shifter_cv_1432.so.c @@ -400,7 +400,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/butterworth_1902.c +++ swh-plugins/butterworth_1902.c @@ -523,7 +523,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/butterworth_1902.so.c +++ swh-plugins/butterworth_1902.so.c @@ -523,7 +523,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/chebstortion_1430.c +++ swh-plugins/chebstortion_1430.c @@ -321,7 +321,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/chebstortion_1430.so.c +++ swh-plugins/chebstortion_1430.so.c @@ -321,7 +321,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/comb_1190.c +++ swh-plugins/comb_1190.c @@ -258,7 +258,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/comb_1190.so.c +++ swh-plugins/comb_1190.so.c @@ -258,7 +258,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/comb_1887.c +++ swh-plugins/comb_1887.c @@ -1117,7 +1117,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/comb_1887.so.c +++ swh-plugins/comb_1887.so.c @@ -1117,7 +1117,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/comb_splitter_1411.c +++ swh-plugins/comb_splitter_1411.c @@ -262,7 +262,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/comb_splitter_1411.so.c +++ swh-plugins/comb_splitter_1411.so.c @@ -262,7 +262,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/const_1909.c +++ swh-plugins/const_1909.c @@ -178,7 +178,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/crossover_dist_1404.c +++ swh-plugins/crossover_dist_1404.c @@ -194,7 +194,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/crossover_dist_1404.so.c +++ swh-plugins/crossover_dist_1404.so.c @@ -191,7 +191,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dc_remove_1207.c +++ swh-plugins/dc_remove_1207.c @@ -173,7 +173,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dc_remove_1207.so.c +++ swh-plugins/dc_remove_1207.so.c @@ -173,7 +173,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/debug_1184.so.c +++ swh-plugins/debug_1184.so.c @@ -207,7 +207,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/decay_1886.c +++ swh-plugins/decay_1886.c @@ -259,7 +259,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/decay_1886.so.c +++ swh-plugins/decay_1886.so.c @@ -259,7 +259,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/decimator_1202.c +++ swh-plugins/decimator_1202.c @@ -247,7 +247,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/decimator_1202.so.c +++ swh-plugins/decimator_1202.so.c @@ -247,7 +247,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/declip_1195.c +++ swh-plugins/declip_1195.c @@ -167,7 +167,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/declip_1195.so.c +++ swh-plugins/declip_1195.so.c @@ -167,7 +167,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/delay_1898.c +++ swh-plugins/delay_1898.c @@ -903,7 +903,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/delay_1898.so.c +++ swh-plugins/delay_1898.so.c @@ -903,7 +903,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/delayorama_1402.c +++ swh-plugins/delayorama_1402.c @@ -675,7 +675,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/delayorama_1402.so.c +++ swh-plugins/delayorama_1402.so.c @@ -675,7 +675,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/diode_1185.c +++ swh-plugins/diode_1185.c @@ -192,7 +192,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/diode_1185.so.c +++ swh-plugins/diode_1185.so.c @@ -192,7 +192,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/divider_1186.c +++ swh-plugins/divider_1186.c @@ -256,7 +256,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/divider_1186.so.c +++ swh-plugins/divider_1186.so.c @@ -256,7 +256,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dj_eq_1901.c +++ swh-plugins/dj_eq_1901.c @@ -470,7 +470,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dj_eq_1901.so.c +++ swh-plugins/dj_eq_1901.so.c @@ -470,7 +470,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dj_flanger_1438.c +++ swh-plugins/dj_flanger_1438.c @@ -373,7 +373,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dj_flanger_1438.so.c +++ swh-plugins/dj_flanger_1438.so.c @@ -373,7 +373,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dyson_compress_1403.c +++ swh-plugins/dyson_compress_1403.c @@ -783,7 +783,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/dyson_compress_1403.so.c +++ swh-plugins/dyson_compress_1403.so.c @@ -783,7 +783,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/fad_delay_1192.c +++ swh-plugins/fad_delay_1192.c @@ -312,7 +312,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/fad_delay_1192.so.c +++ swh-plugins/fad_delay_1192.so.c @@ -312,7 +312,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/fast_lookahead_limiter_1913.c +++ swh-plugins/fast_lookahead_limiter_1913.c @@ -580,7 +580,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/flanger_1191.c +++ swh-plugins/flanger_1191.c @@ -442,7 +442,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/flanger_1191.so.c +++ swh-plugins/flanger_1191.so.c @@ -428,7 +428,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/fm_osc_1415.c +++ swh-plugins/fm_osc_1415.c @@ -186,7 +186,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/fm_osc_1415.so.c +++ swh-plugins/fm_osc_1415.so.c @@ -186,7 +186,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/foldover_1213.c +++ swh-plugins/foldover_1213.c @@ -173,7 +173,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/foldover_1213.so.c +++ swh-plugins/foldover_1213.so.c @@ -173,7 +173,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/foverdrive_1196.c +++ swh-plugins/foverdrive_1196.c @@ -162,7 +162,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/foverdrive_1196.so.c +++ swh-plugins/foverdrive_1196.so.c @@ -162,7 +162,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/freq_tracker_1418.c +++ swh-plugins/freq_tracker_1418.c @@ -247,7 +247,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/freq_tracker_1418.so.c +++ swh-plugins/freq_tracker_1418.so.c @@ -247,7 +247,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gate_1410.c +++ swh-plugins/gate_1410.c @@ -440,7 +440,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gate_1410.so.c +++ swh-plugins/gate_1410.so.c @@ -440,7 +440,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gate_1921.so.c +++ swh-plugins/gate_1921.so.c @@ -858,7 +858,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/giant_flange_1437.c +++ swh-plugins/giant_flange_1437.c @@ -508,7 +508,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/giant_flange_1437.so.c +++ swh-plugins/giant_flange_1437.so.c @@ -508,7 +508,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gong_1424.c +++ swh-plugins/gong_1424.c @@ -615,7 +615,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gong_1424.so.c +++ swh-plugins/gong_1424.so.c @@ -615,7 +615,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gong_beater_1439.c +++ swh-plugins/gong_beater_1439.c @@ -308,7 +308,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gong_beater_1439.so.c +++ swh-plugins/gong_beater_1439.so.c @@ -308,7 +308,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gsm_1215.c +++ swh-plugins/gsm_1215.c @@ -394,7 +394,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gsm_1215.so.c +++ swh-plugins/gsm_1215.so.c @@ -394,7 +394,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gverb_1216.c +++ swh-plugins/gverb_1216.c @@ -290,7 +290,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/gverb_1216.so.c +++ swh-plugins/gverb_1216.so.c @@ -290,7 +290,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/hard_limiter_1413.c +++ swh-plugins/hard_limiter_1413.c @@ -194,7 +194,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/hard_limiter_1413.so.c +++ swh-plugins/hard_limiter_1413.so.c @@ -194,7 +194,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/harmonic_gen_1220.c +++ swh-plugins/harmonic_gen_1220.c @@ -374,7 +374,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/hermes_filter_1200.c +++ swh-plugins/hermes_filter_1200.c @@ -1410,7 +1410,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/hermes_filter_1200.so.c +++ swh-plugins/hermes_filter_1200.so.c @@ -1410,7 +1410,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/highpass_iir_1890.c +++ swh-plugins/highpass_iir_1890.c @@ -203,7 +203,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/highpass_iir_1890.so.c +++ swh-plugins/highpass_iir_1890.so.c @@ -203,7 +203,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/hilbert_1440.c +++ swh-plugins/hilbert_1440.c @@ -240,7 +240,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/hilbert_1440.so.c +++ swh-plugins/hilbert_1440.so.c @@ -240,7 +240,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/imp_1199.c +++ swh-plugins/imp_1199.c @@ -527,7 +527,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/imp_1199.so.c +++ swh-plugins/imp_1199.so.c @@ -525,7 +525,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/impulse_1885.c +++ swh-plugins/impulse_1885.c @@ -193,7 +193,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/impulse_1885.so.c +++ swh-plugins/impulse_1885.so.c @@ -193,7 +193,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/inv_1429.c +++ swh-plugins/inv_1429.c @@ -145,7 +145,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/inv_1429.so.c +++ swh-plugins/inv_1429.so.c @@ -145,7 +145,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/karaoke_1409.c +++ swh-plugins/karaoke_1409.c @@ -188,7 +188,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/karaoke_1409.so.c +++ swh-plugins/karaoke_1409.so.c @@ -188,7 +188,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/latency_1914.c +++ swh-plugins/latency_1914.c @@ -180,7 +180,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/lcr_delay_1436.c +++ swh-plugins/lcr_delay_1436.c @@ -547,7 +547,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/lcr_delay_1436.so.c +++ swh-plugins/lcr_delay_1436.so.c @@ -547,7 +547,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/lookahead_limiter_1435.so.c +++ swh-plugins/lookahead_limiter_1435.so.c @@ -400,7 +400,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/lookahead_limiter_const_1906.so.c +++ swh-plugins/lookahead_limiter_const_1906.so.c @@ -456,7 +456,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/lowpass_iir_1891.c +++ swh-plugins/lowpass_iir_1891.c @@ -205,7 +205,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/lowpass_iir_1891.so.c +++ swh-plugins/lowpass_iir_1891.so.c @@ -205,7 +205,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/ls_filter_1908.c +++ swh-plugins/ls_filter_1908.c @@ -216,7 +216,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/ls_filter_1908.so.c +++ swh-plugins/ls_filter_1908.so.c @@ -216,7 +216,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/makestub.pl +++ swh-plugins/makestub.pl @@ -146,7 +146,6 @@ void _init() { \#ifdef ENABLE_NLS \#define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); \#else \#define D_(s) (s) --- swh-plugins.orig/matrix_ms_st_1421.c +++ swh-plugins/matrix_ms_st_1421.c @@ -180,7 +180,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/matrix_ms_st_1421.so.c +++ swh-plugins/matrix_ms_st_1421.so.c @@ -180,7 +180,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/matrix_spatialiser_1422.c +++ swh-plugins/matrix_spatialiser_1422.c @@ -338,7 +338,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/matrix_spatialiser_1422.so.c +++ swh-plugins/matrix_spatialiser_1422.so.c @@ -338,7 +338,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/matrix_st_ms_1420.c +++ swh-plugins/matrix_st_ms_1420.c @@ -169,7 +169,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/matrix_st_ms_1420.so.c +++ swh-plugins/matrix_st_ms_1420.so.c @@ -169,7 +169,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/mbeq_1197.c +++ swh-plugins/mbeq_1197.c @@ -664,7 +664,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/mbeq_1197.so.c +++ swh-plugins/mbeq_1197.so.c @@ -654,7 +654,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/mod_delay_1419.c +++ swh-plugins/mod_delay_1419.c @@ -236,7 +236,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/mod_delay_1419.so.c +++ swh-plugins/mod_delay_1419.so.c @@ -236,7 +236,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/multivoice_chorus_1201.c +++ swh-plugins/multivoice_chorus_1201.c @@ -534,7 +534,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/multivoice_chorus_1201.so.c +++ swh-plugins/multivoice_chorus_1201.so.c @@ -534,7 +534,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/notch_iir_1894.c +++ swh-plugins/notch_iir_1894.c @@ -258,7 +258,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/notch_iir_1894.so.c +++ swh-plugins/notch_iir_1894.so.c @@ -258,7 +258,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/phasers_1217.c +++ swh-plugins/phasers_1217.c @@ -1037,7 +1037,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/phasers_1217.so.c +++ swh-plugins/phasers_1217.so.c @@ -1037,7 +1037,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/pitch_scale_1193.c +++ swh-plugins/pitch_scale_1193.c @@ -248,7 +248,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/pitch_scale_1193.so.c +++ swh-plugins/pitch_scale_1193.so.c @@ -248,7 +248,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/pitch_scale_1194.c +++ swh-plugins/pitch_scale_1194.c @@ -232,7 +232,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/pitch_scale_1194.so.c +++ swh-plugins/pitch_scale_1194.so.c @@ -232,7 +232,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/plate_1423.c +++ swh-plugins/plate_1423.c @@ -302,7 +302,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/plate_1423.so.c +++ swh-plugins/plate_1423.so.c @@ -302,7 +302,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/pointer_cast_1910.c +++ swh-plugins/pointer_cast_1910.c @@ -228,7 +228,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/rate_shifter_1417.c +++ swh-plugins/rate_shifter_1417.c @@ -242,7 +242,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/rate_shifter_1417.so.c +++ swh-plugins/rate_shifter_1417.so.c @@ -242,7 +242,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/retro_flange_1208.c +++ swh-plugins/retro_flange_1208.c @@ -499,7 +499,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/retro_flange_1208.so.c +++ swh-plugins/retro_flange_1208.so.c @@ -499,7 +499,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/revdelay_1605.c +++ swh-plugins/revdelay_1605.c @@ -436,7 +436,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/revdelay_1605.so.c +++ swh-plugins/revdelay_1605.so.c @@ -432,7 +432,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/ringmod_1188.c +++ swh-plugins/ringmod_1188.c @@ -436,7 +436,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/ringmod_1188.so.c +++ swh-plugins/ringmod_1188.so.c @@ -436,7 +436,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/satan_maximiser_1408.c +++ swh-plugins/satan_maximiser_1408.c @@ -262,7 +262,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/satan_maximiser_1408.so.c +++ swh-plugins/satan_maximiser_1408.so.c @@ -262,7 +262,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc1_1425.c +++ swh-plugins/sc1_1425.c @@ -351,7 +351,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc1_1425.so.c +++ swh-plugins/sc1_1425.so.c @@ -351,7 +351,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc2_1426.c +++ swh-plugins/sc2_1426.c @@ -362,7 +362,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc2_1426.so.c +++ swh-plugins/sc2_1426.so.c @@ -362,7 +362,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc3_1427.c +++ swh-plugins/sc3_1427.c @@ -409,7 +409,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc3_1427.so.c +++ swh-plugins/sc3_1427.so.c @@ -409,7 +409,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc4_1434.so.c +++ swh-plugins/sc4_1434.so.c @@ -429,7 +429,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc4_1882.c +++ swh-plugins/sc4_1882.c @@ -452,7 +452,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc4_1882.so.c +++ swh-plugins/sc4_1882.so.c @@ -448,7 +448,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sc4m_1916.c +++ swh-plugins/sc4m_1916.c @@ -416,7 +416,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/se4_1883.c +++ swh-plugins/se4_1883.c @@ -448,7 +448,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/se4_1883.so.c +++ swh-plugins/se4_1883.so.c @@ -448,7 +448,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/shaper_1187.c +++ swh-plugins/shaper_1187.c @@ -182,7 +182,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/shaper_1187.so.c +++ swh-plugins/shaper_1187.so.c @@ -182,7 +182,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sifter_1210.c +++ swh-plugins/sifter_1210.c @@ -362,7 +362,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sifter_1210.so.c +++ swh-plugins/sifter_1210.so.c @@ -362,7 +362,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sin_cos_1881.c +++ swh-plugins/sin_cos_1881.c @@ -214,7 +214,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sin_cos_1881.so.c +++ swh-plugins/sin_cos_1881.so.c @@ -214,7 +214,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/single_para_1203.c +++ swh-plugins/single_para_1203.c @@ -214,7 +214,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/single_para_1203.so.c +++ swh-plugins/single_para_1203.so.c @@ -214,7 +214,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sinus_wavewrapper_1198.c +++ swh-plugins/sinus_wavewrapper_1198.c @@ -166,7 +166,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/sinus_wavewrapper_1198.so.c +++ swh-plugins/sinus_wavewrapper_1198.so.c @@ -166,7 +166,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/smooth_decimate_1414.c +++ swh-plugins/smooth_decimate_1414.c @@ -247,7 +247,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/smooth_decimate_1414.so.c +++ swh-plugins/smooth_decimate_1414.so.c @@ -247,7 +247,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/split_1406.c +++ swh-plugins/split_1406.c @@ -162,7 +162,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/split_1406.so.c +++ swh-plugins/split_1406.so.c @@ -162,7 +162,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/step_muxer_1212.c +++ swh-plugins/step_muxer_1212.c @@ -404,7 +404,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/step_muxer_1212.so.c +++ swh-plugins/step_muxer_1212.so.c @@ -404,7 +404,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/surround_encoder_1401.c +++ swh-plugins/surround_encoder_1401.c @@ -324,7 +324,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/surround_encoder_1401.so.c +++ swh-plugins/surround_encoder_1401.so.c @@ -278,7 +278,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/svf_1214.c +++ swh-plugins/svf_1214.c @@ -300,7 +300,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/svf_1214.so.c +++ swh-plugins/svf_1214.so.c @@ -303,7 +303,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/tape_delay_1211.c +++ swh-plugins/tape_delay_1211.c @@ -483,7 +483,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/tape_delay_1211.so.c +++ swh-plugins/tape_delay_1211.so.c @@ -483,7 +483,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/transient_1206.c +++ swh-plugins/transient_1206.c @@ -377,7 +377,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/transient_1206.so.c +++ swh-plugins/transient_1206.so.c @@ -377,7 +377,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/triple_para_1204.c +++ swh-plugins/triple_para_1204.c @@ -375,7 +375,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/triple_para_1204.so.c +++ swh-plugins/triple_para_1204.so.c @@ -375,7 +375,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/valve_1209.c +++ swh-plugins/valve_1209.c @@ -250,7 +250,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/valve_1209.so.c +++ swh-plugins/valve_1209.so.c @@ -246,7 +246,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/valve_rect_1405.c +++ swh-plugins/valve_rect_1405.c @@ -319,7 +319,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/valve_rect_1405.so.c +++ swh-plugins/valve_rect_1405.so.c @@ -319,7 +319,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/vynil_1905.c +++ swh-plugins/vynil_1905.c @@ -586,7 +586,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/vynil_1905.so.c +++ swh-plugins/vynil_1905.so.c @@ -584,7 +584,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/wave_terrain_1412.c +++ swh-plugins/wave_terrain_1412.c @@ -162,7 +162,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/wave_terrain_1412.so.c +++ swh-plugins/wave_terrain_1412.so.c @@ -162,7 +162,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/xfade_1915.c +++ swh-plugins/xfade_1915.c @@ -392,7 +392,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/zm1_1428.c +++ swh-plugins/zm1_1428.c @@ -170,7 +170,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) --- swh-plugins.orig/zm1_1428.so.c +++ swh-plugins/zm1_1428.so.c @@ -170,7 +170,6 @@ void _init() { #ifdef ENABLE_NLS #define D_(s) dgettext(PACKAGE, s) - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, PACKAGE_LOCALE_DIR); #else #define D_(s) (s) debian/patches/05-mbeq_crash_fix.diff0000644000000000000000000000324212067075422014651 0ustar Description: Fix buffer overrun that causes explosions on little endian 64bit platforms. Origin: https://github.com/swh/ladspa/commit/3b61bb945c5e09ac Applied-Upstream: yes Bug-Debian: http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=629263 --- mbeq_1197.c | 3 ++- mbeq_1197.so.c | 3 ++- mbeq_1197.xml | 3 ++- 3 files changed, 6 insertions(+), 3 deletions(-) --- swh-plugins.orig/mbeq_1197.c +++ swh-plugins/mbeq_1197.c @@ -457,7 +457,8 @@ static void runMbeq(LADSPA_Handle instan #endif // Multiply the bins magnitudes by the coeficients - for (i = 0; i < FFT_LENGTH/2; i++) { + comp[0] *= coefs[0]; + for (i = 1; i < FFT_LENGTH/2; i++) { comp[i] *= coefs[i]; comp[FFT_LENGTH-i] *= coefs[i]; } --- swh-plugins.orig/mbeq_1197.so.c +++ swh-plugins/mbeq_1197.so.c @@ -446,7 +446,8 @@ static void runMbeq(LADSPA_Handle instan #endif // Multiply the bins magnitudes by the coeficients - for (i = 0; i < FFT_LENGTH/2; i++) { + comp[0] *= coefs[0]; + for (i = 1; i < FFT_LENGTH/2; i++) { comp[i] *= coefs[i]; comp[FFT_LENGTH-i] *= coefs[i]; } --- swh-plugins.orig/mbeq_1197.xml +++ swh-plugins/mbeq_1197.xml @@ -171,7 +171,8 @@ for (pos = 0; pos < sample_count; pos++) #endif // Multiply the bins magnitudes by the coeficients - for (i = 0; i < FFT_LENGTH/2; i++) { + comp[0] *= coefs[0]; + for (i = 1; i < FFT_LENGTH/2; i++) { comp[i] *= coefs[i]; comp[FFT_LENGTH-i] *= coefs[i]; } debian/patches/01-dont-use-march.diff0000644000000000000000000000250712067076566014536 0ustar # Do not try to detect the architecture. Fixes FTBFS. --- configure.in | 13 +++---------- 1 file changed, 3 insertions(+), 10 deletions(-) --- swh-plugins.orig/configure.in +++ swh-plugins/configure.in @@ -96,20 +96,13 @@ CFLAGS=$lrintf_save_CFLAGS -I@top_srcdir if [ echo ${CFLAGS} | grep "\-march=" ]; then AC_MSG_WARN([CFLAGS appears to allready contain architecture specifaction, using exiting one]) else - AC_MSG_WARN([Can't find architecture specifaction in CFLAGS, picking one from build host CPU type]) - AC_MSG_WARN([May result in non-portable code]) - dnl For gcc use: - MACHINE="-march=${build_cpu}" - if test ${build_cpu} = "powerpc"; then MACHINE=""; fi - if test ${build_cpu} = "powerpc64"; then MACHINE=""; fi - if test ${build_cpu} = "x86_64"; then MACHINE=""; fi - - CFLAGS="$CFLAGS -Wall -O3 -fomit-frame-pointer -fstrength-reduce -funroll-loops -ffast-math -fPIC -DPIC ${MACHINE} ${USE_SSE} ${DARWIN_CFLAGS}" + AC_MSG_WARN([Can't find architecture specifaction in CFLAGS]) + CFLAGS="$CFLAGS -Wall -O3 -fomit-frame-pointer -fstrength-reduce -funroll-loops -ffast-math -fPIC -DPIC ${USE_SSE} ${DARWIN_CFLAGS}" dnl For Intel's C compiler use: dnl CC="icc" dnl CFLAGS="$CFLAGS -O2 -rcd -tpp6 -xiMK -KPIC -DPIC" - + dnl For debugging use: dnl CFLAGS="$CFLAGS -Wall -g -ffast-math -fPIC -DPIC" fi debian/swh-plugins.doc-base0000644000000000000000000000051512067064404013051 0ustar Document: swh-plugins Title: swh-plugins Manual Author: Steve Harris Abstract: This manual describes Steve Harris's (swh) plugins and how they can be used to manipulate audio with LADSPA hosts Section: Sound Format: HTML Index: /usr/share/doc/swh-plugins/html/ladspa-swh.html Files: /usr/share/doc/swh-plugins/html/ladspa-swh.html debian/rules0000755000000000000000000000235212067076174010262 0ustar #!/usr/bin/make -f # Uncomment this to turn on verbose mode. #export DH_VERBOSE=1 # These are used for cross-compiling and for saving the configure script # from having to guess our platform (since we know it already) DEB_HOST_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE) DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE) DEB_BUILD_ARCH ?= $(shell dpkg-architecture -qDEB_BUILD_ARCH) ifneq (,$(findstring debug,$(DEB_BUILD_OPTIONS))) CFLAGS += -g endif ifeq (,$(findstring nostrip,$(DEB_BUILD_OPTIONS))) INSTALL_PROGRAM += -s endif EXTRAFLAGS := ifeq ($(DEB_BUILD_ARCH),amd64) EXTRAFLAGS := --enable-sse endif %: dh $@ --with autoreconf override_dh_auto_configure: dh_auto_configure -- --enable-shared \ --disable-rpath $(EXTRAFLAGS) override_dh_auto_clean: rm -f conftest conftest.c rm -f po/stamp-po dh_auto_clean override_dh_auto_install: dh_auto_install # Remove rpaths. chrpath -d -k debian/swh-plugins/usr/lib/ladspa/pitch_scale_1193.so chrpath -d -k debian/swh-plugins/usr/lib/ladspa/pitch_scale_1194.so chrpath -d -k debian/swh-plugins/usr/lib/ladspa/mbeq_1197.so chrpath -d -k debian/swh-plugins/usr/lib/ladspa/imp_1199.so override_dh_installchangelogs: dh_installchangelogs ChangeLog debian/control0000644000000000000000000000213512067065143010576 0ustar Source: swh-plugins Section: sound Priority: optional Maintainer: Debian Multimedia Maintainers Uploaders: Alessio Treglia Build-Depends: chrpath, debhelper (>= 9~), dh-autoreconf, ladspa-sdk, libfftw3-dev, libtool, libxml2-utils, pkg-config Standards-Version: 3.9.2 Homepage: http://plugin.org.uk/ Vcs-Git: git://anonscm.debian.org/pkg-multimedia/swh-plugins.git Vcs-Browser: http://anonscm.debian.org/gitweb/?p=pkg-multimedia/swh-plugins.git Package: swh-plugins Architecture: any Depends: ${misc:Depends}, ${shlibs:Depends} Provides: ladspa-plugin Description: Steve Harris's LADSPA plugins Steve Harris has written a large number of plugins for LADSPA compatible hosts (e.g. GLAME, Sweep and ecasound). The plugins available are: . amp, fast overdrive, overdrive (with colourisation), comb filter, waveshaper, ringmod, divider, diode, decliper, pitch scaler, 16 band equaliser, sinus wavewrapper, hermes filter, chorus, flanger, decimater, oscillator, gverb, phasers, harmonic generators, surround encoders and more. debian/changelog0000644000000000000000000002655112067076652011064 0ustar swh-plugins (0.4.15+1-7) unstable; urgency=low * Adopting this. Thanks to Patrick Matthäi for the great job. (Closes: #622162) * Bump debhelper requirement. * Turn it into dh short form + dh_autoreconf. * Enable git-buildpackage support. * Plugins shouldn't call setlocale() as it could screw up the locale settings of any application using them. Thanks to Daniel Gibson for the patch. (Closes: #672705) * Fix buffer overrun that causes explosions on little endian 64bit platforms. (Closes: #629263) * Don't remove po/*.gmo files in order to preserve upstream's original sources tree. * debian/patches/01-dont-use-march.diff: - Don't patch configure, it's going to be regenerated by autoreconf. * Refresh other patches. -- Alessio Treglia Thu, 27 Dec 2012 16:46:16 +0000 swh-plugins (0.4.15+1-6) unstable; urgency=low * Bump Standards-Version to 3.9.2 (no changes needed). * Set the maintainer to the Debian QA Group. -- Patrick Matthäi Sun, 10 Apr 2011 18:16:21 +0200 swh-plugins (0.4.15+1-5) unstable; urgency=low * Bump Standards-Version to 3.9.1 (no changes needed). * Convert package to the 3.0 (quilt) format. -- Patrick Matthäi Sun, 06 Feb 2011 17:07:15 +0100 swh-plugins (0.4.15+1-4) unstable; urgency=low * Bump Standards-Version to 3.8.3. - Add debian/README.source. -- Patrick Matthäi Sun, 01 Nov 2009 14:39:10 +0100 swh-plugins (0.4.15+1-3) unstable; urgency=low * Disable model specific 3dnow on amd64. Closes: #539202 -- Patrick Matthäi Thu, 30 Jul 2009 09:45:49 +0200 swh-plugins (0.4.15+1-2) unstable; urgency=low * Mangle +1 in debian/watch. * Do not configure twice: touch configure-stamp. * Add again autoconf, automake1.9 and libtool build dependency. * Add patch 01-dont-use-march.dpatch which fixes a reopened FTBFS on most architectures. Closes: #539115 * Add patch 02-fix-spelling-add-de.po.dpatch which reincludes the german translation. * Add 03-uptodate-ltmain.dpatch which updates ltmain.sh. Thanks lintian. -- Patrick Matthäi Wed, 29 Jul 2009 17:12:58 +0200 swh-plugins (0.4.15+1-1) unstable; urgency=low * Gettextize and autoreconf the source to fix several FTBFS and build an new tarball, because of the bloated diff. Now we can also drop libtool, automake1.9 and autoconf from the build dependencys. * Build with --enable-shared. -- Patrick Matthäi Tue, 28 Jul 2009 21:35:17 +0200 swh-plugins (0.4.15-3) unstable; urgency=low * New maintainer. Closes: #503497 * Bump Standards-Version to 3.8.2 (no changes needed). * Tune the packaging a bit, use install file, drop useless debhelper calls and comments. * Add missing licenses informations. Closes: #532450 * Build with --enable-sse and --enable-3dnow optimizations on amd64. * Remove rpaths from some librarys. Thanks lintian. -- Patrick Matthäi Sun, 26 Jul 2009 13:38:29 +0200 swh-plugins (0.4.15-2) unstable; urgency=low * QA upload. * Gettextize to remove bogus hardcoded stuff in libtool. (Closes: #526557). + Ugly solution as it balloons the diff. * Add build-dep on libxml2-utils. * Fix spelling of Display in all files. (Closes: #522375). * Add German po file. (Closes: #524440). + Thanks to Chris Leick. * Bump Standards Version to 3.8.1. (No changes needed). -- Barry deFreese Tue, 19 May 2009 15:51:30 -0400 swh-plugins (0.4.15-1) unstable; urgency=low * QA upload. + Set maintainer to Debian QA Group . * Acknowledge NMUs. * Make clean not ignore errors. * Add missing comma to depends line in control. * Move doc-base section from audio to Sound. + Remove excess whitespace from doc-base. * Add proper Copyright holders to debian/copyright. * Fix changelog date format lines for 0.2.8-2, 0.2.8-3. * Add watch file. * Bump debhelper build-dep and compat to 5. * Bump Standards Version to 3.8.0. -- Barry deFreese Tue, 03 Feb 2009 10:37:41 -0500 swh-plugins (0.4.15-0.2) unstable; urgency=low * Non-maintainer upload. * The "neither maintainer nor NMUer fixes their shit" upload * Fixes provided by Samuel Tardieu, thanks: - Stop using idiotic compiler options if you don't know the arch closes: #428371, #428435, #440329 - build-depend libfftw3-dev instead of gone fftw3-dev, closes: #445795 * Use homepage field -- Riku Voipio Sun, 13 Apr 2008 21:21:13 +0300 swh-plugins (0.4.15-0.1) unstable; urgency=low * Non-Maintainer Upload * New upstream release (Closes :#324188) * Bumped Standards-Version to 3.7.2 -- Free Ekanayaka Mon, 4 Jun 2007 23:42:38 +0200 swh-plugins (0.4.14-1.1) unstable; urgency=medium * Non-maintainer upload to fix Failure To Build From Source, due missing build-dependency on pkg-config. Thanks to Daniel Schepler for the suggestion (Closes: #380147) -- Margarita Manterola Thu, 3 Aug 2006 18:23:07 -0300 swh-plugins (0.4.14-1) unstable; urgency=low * New upstream release * Update for C++ and gcc 4.x transitions (Closes: #300243) * Bump Standards-Version to 3.6.2.1 -- Anand Kumria Wed, 21 Sep 2005 01:11:27 +1000 swh-plugins (0.4.13-1) unstable; urgency=low * New upstream release -- Anand Kumria Sun, 6 Mar 2005 03:43:26 +1100 swh-plugins (0.4.12-1) unstable; urgency=low * New upstream release(s) * Update plugin documentation * This upgrade should fix the amd64 issue with _fini in the multiband equaliser (closes: #289804) -- Anand Kumria Sat, 15 Jan 2005 08:30:40 +1100 swh-plugins (0.4.7-1) unstable; urgency=medium * New upstream release * remove -fomit-frame-pointer; this will fix the m68k build (closes: #258237) -- Anand Kumria Mon, 19 Jul 2004 02:11:11 +1000 swh-plugins (0.4.4-2) unstable; urgency=low * Build-Dep on 'ed'. No, not the horse. -- Anand Kumria Wed, 30 Jun 2004 02:49:51 +1000 swh-plugins (0.4.4-1) unstable; urgency=low * New upstream release * Now with gcc 3.4 goodness (closes: #244303) -- Anand Kumria Tue, 29 Jun 2004 20:35:59 +1000 swh-plugins (0.4.3-4) unstable; urgency=medium * Respin build * Done only to get m68k to rebuild the package. -- Anand Kumria Sun, 29 Feb 2004 23:07:10 +1100 swh-plugins (0.4.3-3) unstable; urgency=low * Respin the package and only build gverb-test on i386 -- Anand Kumria Mon, 2 Feb 2004 13:20:27 +1100 swh-plugins (0.4.3-2) unstable; urgency=low * Correct documentation file for doc-base (Cloases: #229855) -- Anand Kumria Thu, 29 Jan 2004 09:28:47 +1100 swh-plugins (0.4.3-1) unstable; urgency=low * New upstream release -- Anand Kumria Mon, 26 Jan 2004 21:27:15 +1100 swh-plugins (0.4.2-5) unstable; urgency=low * Seems I must depend upon libtool now too. -- Anand Kumria Sun, 28 Sep 2003 19:39:16 +1000 swh-plugins (0.4.2-4) unstable; urgency=low * gverb-test uses i386 specific time stamp counting. Instead use gettimeofday on other architectures as the file isn't critical and isn't installed. This should get us into testing. Thanks to Robert Jordens for prodding me about this (Closes: #200576) -- Anand Kumria Sun, 28 Sep 2003 18:51:44 +1000 swh-plugins (0.4.2-3) unstable; urgency=low * fftw3-dev fixes the bug, so remove my attempted workaround -- Anand Kumria Tue, 8 Jul 2003 02:04:57 +1000 swh-plugins (0.4.2-2) unstable; urgency=low * Workaround bug in fftw3-dev (Bug: #197637) by depending upon pkg-config so we can build -- Anand Kumria Tue, 1 Jul 2003 00:18:51 +1000 swh-plugins (0.4.2-1) unstable; urgency=low * New upstream release -- Anand Kumria Sun, 8 Jun 2003 16:05:55 +1000 swh-plugins (0.4.0-2) unstable; urgency=low * Changes required by GCC 3.3 (Closes: #194162) * Bump to 3.5.10 -- Anand Kumria Sat, 24 May 2003 13:43:24 +1000 swh-plugins (0.4.0-1) unstable; urgency=low * New upstream release -- Anand Kumria Wed, 16 Apr 2003 04:54:22 +1000 swh-plugins (0.3.7-1) unstable; urgency=low * New upstream release -- Anand Kumria Sun, 23 Mar 2003 13:42:03 +1100 swh-plugins (0.3.6-1) unstable; urgency=low * New upstream release * Revert to upstream's config.guess / config.sub, let's see if they are good enough for mips/mipsel -- Anand Kumria Mon, 13 Jan 2003 01:52:16 +1100 swh-plugins (0.3.4-1) unstable; urgency=low * New upstream release * gcc 3.2 transition done (Closes: #163336) -- Anand Kumria Fri, 10 Jan 2003 19:40:58 +1100 swh-plugins (0.3.3-2) unstable; urgency=low * Remove, again, the CPU specific tests in configure -- Anand Kumria Sun, 8 Dec 2002 01:02:58 +1100 swh-plugins (0.3.3-1) unstable; urgency=low * New upstream release (Closes: #169212) * Update config.guess/config.sub * Use gcc to link (Closes: #134055, #154080) -- Anand Kumria Sat, 7 Dec 2002 18:45:42 +1100 swh-plugins (0.2.8-3) unstable; urgency=low * Opps, sign the uploads. Dammit. -- Anand Kumria Wed, 24 Jul 2002 03:09:18 +1000 swh-plugins (0.2.8-2) unstable; urgency=low * Remove the CPU specific tests in configure that might have been hindering compilation on other architectures. -- Anand Kumria Wed, 24 Jul 2002 01:41:16 +1000 swh-plugins (0.2.8-1) unstable; urgency=low * Many (many) new upstream releases. (Closes: #142002) * Learn to speel. (Closes: #125404) * Be specifice about which Fast Fourier Transforms we want (single or double). (Closes: #128774) * Newer version of triplepara (and other plugins) work. (Closes: #133582) -- Anand Kumria Tue, 23 Jul 2002 14:28:51 +1000 swh-plugins (0.2.0-2) unstable; urgency=low * Don't compile things that are architecture specific (i.e. -march=sparc64) -- Anand Kumria Sun, 26 Aug 2001 17:09:28 +1000 swh-plugins (0.2.0-1) unstable; urgency=low * New upstream version * Never released the one below * All three build problems are because make considers either Makefile.in or Makefile.am, configure.in and aclocal.m4 newer than Makefile. I suspect a build environment problem on m68k since that was the only architecture that report this. (Closes: #102754, #102768, #104065) -- Anand Kumria Sat, 25 Aug 2001 23:57:34 +1000 swh-plugins (0.1.14-1) unstable; urgency=low * New upstream version * Head off Lamont Jones, porter from Hell, by incorporating newer config.sub and config.guess -- Anand Kumria Sun, 5 Aug 2001 02:59:01 +1000 swh-plugins (0.1.13-2) unstable; urgency=low * Remove Intel specific CPU tests in configure (Closes: #101991) -- Anand Kumria Sun, 24 Jun 2001 07:36:13 +1000 swh-plugins (0.1.13-1) unstable; urgency=low * Initial Release. -- Anand Kumria Thu, 21 Jun 2001 02:29:08 +1000 debian/install0000644000000000000000000000006712067064736010575 0ustar debian/ladspa-swh.html usr/share/doc/swh-plugins/html/ debian/gbp.conf0000644000000000000000000000003612067065466010620 0ustar [DEFAULT] pristine-tar = True debian/copyright0000644000000000000000000000635512067064736011145 0ustar This package was debianized by Anand Kumria on Thu, 21 Jun 2001 02:29:08 +1000. It was taken over from Patrick Matthäi on Sun, 26 Jul 2009 12:57:07 +0200. It was downloaded from Upstream Authors: Steve Harris Copyright: Copyright (C) 2000-2003 Alexander Ehlert Copyright (C) 2002-2003 Steve Harris Copyright (C) 1999 Juhana Sadeharju Copyright (C) 1992 by Jutta Degener and Carsten Bormann Copyright (C) 2000-2002 Richard W.E. Furse, Paul Barton-Davis, Stefan Westerfeld License (ladspa.h): This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This library 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA On Debian systems, the complete text of the GNU Lesser General Public License can be found in `/usr/share/common-licenses/LGPL-2.1'. License (gsm/*): This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation. This library 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA On Debian systems, the complete text of the GNU Lesser General Public License can be found in `/usr/share/common-licenses/LGPL'. License (everything else): This package 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 2 of the License, or (at your option) any later version. This package 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 package; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA On Debian systems, the complete text of the GNU General Public License can be found in `/usr/share/common-licenses/GPL-2'. The Debian packaging is © 2009, Patrick Matthäi and is licensed under the GPL, see above. debian/ladspa-swh.html0000644000000000000000000024415412067064404012134 0ustar Steve Harris' LADSPA Plugin Docs

Steve Harris' LADSPA Plugin Docs

2004-10-26

steve@plugin.org.uk

Contents

1  Preamble
    1.1  What plugins?
    1.2  Where can I get them
2  The plugins
    2.1  Aliasing (alias, 1407)
    2.2  Allpass delay line, noninterpolating (allpass_n, 1895)
    2.3  Allpass delay line, linear interpolation (allpass_l, 1896)
    2.4  Allpass delay line, cubic spline interpolation (allpass_c, 1897)
    2.5  Simple amplifier (amp, 1181)
    2.6  AM pitchshifter (amPitchshift, 1433)
    2.7  Analogue Oscillator (analogueOsc, 1416)
    2.8  Glame Bandpass Analog Filter (bandpass_a_iir, 1893)
    2.9  Glame Bandpass Filter (bandpass_iir, 1892)
    2.10  Bode frequency shifter (bodeShifter, 1431)
    2.11  Bode frequency shifter (CV) (bodeShifterCV, 1432)
    2.12  Glame Butterworth X-over Filter (bwxover_iir, 1902)
    2.13  GLAME Butterworth Lowpass (buttlow_iir, 1903)
    2.14  GLAME Butterworth Highpass (butthigh_iir, 1904)
    2.15  Chebyshev distortion (chebstortion, 1430)
    2.16  Comb Filter (comb, 1190)
    2.17  Comb delay line, noninterpolating (comb_n, 1889)
    2.18  Comb delay line, linear interpolation (comb_l, 1887)
    2.19  Comb delay line, cubic spline interpolation (comb_c, 1888)
    2.20  Comb Splitter (combSplitter, 1411)
    2.21  Constant Signal Generator (const, 1909)
    2.22  Crossover distortion (crossoverDist, 1404)
    2.23  DC Offset Remover (dcRemove, 1207)
    2.24  Debug Plugin (debug, 1184)
    2.25  Exponential signal decay (decay, 1886)
    2.26  Decimator (decimator, 1202)
    2.27  Declipper (declip, 1195)
    2.28  Simple delay line, noninterpolating (delay_n, 1898)
    2.29  Simple delay line, linear interpolation (delay_l, 1899)
    2.30  Simple delay line, cubic spline interpolation (delay_c, 1900)
    2.31  Delayorama (delayorama, 1402)
    2.32  Diode Processor (diode, 1185)
    2.33  Audio Divider (Suboctave Generator) (divider, 1186)
    2.34  DJ EQ (mono) (dj_eq_mono, 1907)
    2.35  DJ EQ (dj_eq, 1901)
    2.36  DJ flanger (djFlanger, 1438)
    2.37  Dyson compressor (dysonCompress, 1403)
    2.38  Fractionally Addressed Delay Line (fadDelay, 1192)
    2.39  Fast Lookahead limiter (fastLookaheadLimiter, 1913)
    2.40  Flanger (flanger, 1191)
    2.41  FM Oscillator (fmOsc, 1415)
    2.42  Foldover distortion (foldover, 1213)
    2.43  Fast overdrive (foverdrive, 1196)
    2.44  Frequency tracker (freqTracker, 1418)
    2.45  Gate (gate, 1410)
    2.46  Gate (gate, 1921)
    2.47  Stereo Gate (stereo_gate, 1922)
    2.48  Giant flange (giantFlange, 1437)
    2.49  Gong model (gong, 1424)
    2.50  Gong beater (gongBeater, 1439)
    2.51  GSM simulator (gsm, 1215)
    2.52  GVerb (gverb, 1216)
    2.53  Hard Limiter (hardLimiter, 1413)
    2.54  Harmonic generator (harmonicGen, 1220)
        What does it do?
        Known bugs
        Examples
    2.55  Hermes Filter (hermesFilter, 1200)
    2.56  Glame Highpass Filter (highpass_iir, 1890)
    2.57  Hilbert transformer (hilbert, 1440)
    2.58  Impulse convolver (imp, 1199)
    2.59  Nonbandlimited single-sample impulses (Frequency: Control) (impulse_fc, 1885)
    2.60  Inverter (inv, 1429)
    2.61  Karaoke (karaoke, 1409)
    2.62  Artificial latency (artificialLatency, 1914)
    2.63  L/C/R Delay (lcrDelay, 1436)
    2.64  Lookahead limiter (lookaheadLimiter, 1435)
    2.65  Lookahead limiter (fixed latency) (lookaheadLimiterConst, 1906)
    2.66  Glame Lowpass Filter (lowpass_iir, 1891)
    2.67  LS Filter (lsFilter, 1908)
    2.68  Matrix: MS to Stereo (matrixMSSt, 1421)
    2.69  Matrix Spatialiser (matrixSpatialiser, 1422)
    2.70  Matrix: Stereo to MS (matrixStMS, 1420)
    2.71  Multiband EQ (mbeq, 1197)
    2.72  Modulatable delay (modDelay, 1419)
    2.73  Multivoice Chorus (multivoiceChorus, 1201)
    2.74  Mag's Notch Filter (notch_iir, 1894)
    2.75  LFO Phaser (lfoPhaser, 1217)
    2.76  4 x 4 pole allpass (fourByFourPole, 1218)
    2.77  Auto phaser (autoPhaser, 1219)
    2.78  Pitch Scaler (pitchScale, 1193)
    2.79  Higher Quality Pitch Scaler (pitchScaleHQ, 1194)
    2.80  Plate reverb (plate, 1423)
    2.81  Pointer cast distortion (pointerCastDistortion, 1910)
    2.82  Rate shifter (rateShifter, 1417)
    2.83  Retro Flanger (retroFlange, 1208)
    2.84  Reverse Delay (5s max) (revdelay, 1605)
    2.85  Ringmod with two inputs (ringmod_2i1o, 1188)
    2.86  Ringmod with LFO (ringmod_1i1o1l, 1189)
    2.87  Barry's Satan Maximiser (satanMaximiser, 1408)
    2.88  SC1 (sc1, 1425)
    2.89  SC2 (sc2, 1426)
    2.90  SC3 (sc3, 1427)
    2.91  SC4 (sc4, 1882)
    2.92  SE4 (se4, 1883)
    2.93  Wave shaper (shaper, 1187)
    2.94  Signal sifter (sifter, 1210)
    2.95  Sine + cosine oscillator (sinCos, 1881)
    2.96  Single band parametric (singlePara, 1203)
    2.97  Sinus wavewrapper (sinusWavewrapper, 1198)
    2.98  Smooth Decimator (smoothDecimate, 1414)
    2.99  Mono to Stereo splitter (split, 1406)
    2.100  Step Demuxer (stepMuxer, 1212)
    2.101  Surround matrix encoder (surroundEncoder, 1401)
        What does it do?
        Caveats
        Legalese
    2.102  State Variable Filter (svf, 1214)
    2.103  Tape Delay Simulation (tapeDelay, 1211)
    2.104  Transient mangler (transient, 1206)
    2.105  Triple band parametric with shelves (triplePara, 1204)
    2.106  Valve saturation (valve, 1209)
    2.107  Valve rectifier (valveRect, 1405)
    2.108  VyNil (Vinyl Effect) (vynil, 1905)
    2.109  Wave Terrain Oscillator (waveTerrain, 1412)
    2.110  Crossfade (xfade, 1915)
    2.111  Crossfade (4 outs) (xfade4, 1916)
    2.112  z-1 (zm1, 1428)
3  Licensing

1  Preamble

1.1  What plugins?

This is the documentation for some plugins that I have written for the Linux Audio Developers Simple Plugin Architecture. It is a nice audio plugin architecture with a very easy learning curve.

1.2  Where can I get them

From the website at http://plugin.org.uk/.

2  The plugins

2.1  Aliasing (alias, 1407)

Simulates aliasing using nyquist frequency modulation. Produces wacky results if the blocks aren't even numbers of samples long.

Aliasing level

Controls the amount of simulated aliasing in the output.

2.2  Allpass delay line, noninterpolating (allpass_n, 1895)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

Decay Time (s)

Time for the echoes to decay by 60 decibels. If this time is negative then the feedback coefficient will be negative, thus emphasizing only odd harmonics at an octave lower.

2.3  Allpass delay line, linear interpolation (allpass_l, 1896)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

Decay Time (s)

Time for the echoes to decay by 60 decibels. If this time is negative then the feedback coefficient will be negative, thus emphasizing only odd harmonics at an octave lower.

2.4  Allpass delay line, cubic spline interpolation (allpass_c, 1897)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

Decay Time (s)

Time for the echoes to decay by 60 decibels. If this time is negative then the feedback coefficient will be negative, thus emphasizing only odd harmonics at an octave lower.

2.5  Simple amplifier (amp, 1181)

CPU usage: 130 cycles/sample

Amps gain (dB)

Controls the gain of the input signal in dB's.

2.6  AM pitchshifter (amPitchshift, 1433)

This plugin works by running a single write pointer (monotonic) and two read pointers (pitchscaled) over a ringbuffer.The output is faded between the two readpointers according to the sine of the distance from the write pointer. The design is based on the mechanism of a mechanical pitchshifter I saw in the Gemeentemuseum in Den Haag, though I'm sure it is a common enough algorithm.

Pitch shift

The multiple of the output pitch, eg. 2.0 will increase the pitch by one octave.

Buffer size

The order of magnitude of the buffer size. Small buffers will sound fluttery, large buffers will have flangy sounding echos.I recommend a buffer size of 3 for a reasonable compromise, with wideband material at around 48KHz. For drums you might have to lower it, and for voiced background noises it can go higher.

2.7  Analogue Oscillator (analogueOsc, 1416)

This plugin simulates the output you get from an analogue synth's osciallators.You can get a reasonable emualtion of a 303's square (for exmaple) if you set the warmth to about 0.4 and the instability to about 0.05.The frequency is currently a control input, and there is no interpolation, so if your host is using large block sieze it will sound steppy.I'm unsure whether to convert this to an audio input or inpolate the control in.

Waveform (1=sin, 2=tri, 3=squ, 4=saw)

The basic shape of the waveform is selected using this control:

Value Waveform
1 Sine
2 Triangle
3 Square
4 Saw

Frequency (Hz)

The frequency of the output (Hz).

Warmth

The degree of softening that is applied to the generted waveform, reduces the number of harmonics in the output.

Instability

The degree of pitch instability of the output. Turning this too high with square and saw waves will produce an anoying jittery sound, I want to fix this but it is tricky.

2.8  Glame Bandpass Analog Filter (bandpass_a_iir, 1893)

IIR bandpass filter modeled after an analog circuit. This filter was ported from the glame multitrack editor to ladspa.

2.9  Glame Bandpass Filter (bandpass_iir, 1892)

IIR bandpass filter based using chebishev coefficients. The filter allows you to tweak the number of stages used for filtering. Every stage adds two more poles, which leads to a steeper dropoff. More stages need more CPU power. This filter was ported from the glame multitrack editor to ladspa.

2.10  Bode frequency shifter (bodeShifter, 1431)

A Bode/Moog Frequency Shifter is a popular analogue synth module, it works by shifting all the frequencies of an input signal up or down by a specified frequency. This version shifts in noth directions at the same time as its almost no extra work and its often useful to have both directions.It doesn't actually work in the same way as an analogue Bode/Moog, which use Dome filters as the core, it uses a Hilbert Transformer, which is much simpler to implemtent in digital systems. The output is very similar though, and people are familiar with the name Bode.The theory of operation is pretty simple, and uses some clever maths to cancel out the upper or lower sidebands of a ringmodulator applied to the input signal. Read the source if you want more information. The Hilbert Transformet coefficents came from mkfilter, the excellent filter calculator, available at http://www-users.cs.york.ac.uk/~fisher/mkfilter/.

Frequency shift

Controls the frequency shift applied to the input signal, in Hz. Note, this is not a pitch shift, so you not get natural sounding results out, it is an audio effect popular with modular synthesists.

2.11  Bode frequency shifter (CV) (bodeShifterCV, 1432)

See the non CV version for information.This is more or less a copy of the Doepfer A126, http://www.doepfer.de/a126.htm.

Shift CV

Controls the frequency shift applied to the input signal, in KHz.

2.12  Glame Butterworth X-over Filter (bwxover_iir, 1902)

Butterworth X-over filter

2.13  GLAME Butterworth Lowpass (buttlow_iir, 1903)

Butterworth lowpass filter

2.14  GLAME Butterworth Highpass (butthigh_iir, 1904)

Butterworth highpass filter

2.15  Chebyshev distortion (chebstortion, 1430)

This is an interesting distortion effect that is seeded from incoming signal envelope. As the level of the signal rises more and more harmonics will for added to the output signal.The distortion control sets the sensitivity of the input.The effect eveolved from some experiments between Tim Goetze and myself, apptempting to emulate valve based guitar amp distortion. This was one of the failures, but it still makes an interesting noise.

2.16  Comb Filter (comb, 1190)

CPU usage: 86 cycles/sample

Band separation (Hz)

Controls the distance between the filters peaks.

Feedback

Feedback level, increases the distinctive wooshy phaser sound.

2.17  Comb delay line, noninterpolating (comb_n, 1889)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

Decay Time (s)

Time for the echoes to decay by 60 decibels. If this time is negative then the feedback coefficient will be negative, thus emphasizing only odd harmonics at an octave lower.

2.18  Comb delay line, linear interpolation (comb_l, 1887)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

Decay Time (s)

Time for the echoes to decay by 60 decibels. If this time is negative then the feedback coefficient will be negative, thus emphasizing only odd harmonics at an octave lower.

2.19  Comb delay line, cubic spline interpolation (comb_c, 1888)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

Decay Time (s)

Time for the echoes to decay by 60 decibels. If this time is negative then the feedback coefficient will be negative, thus emphasizing only odd harmonics at an octave lower.

2.20  Comb Splitter (combSplitter, 1411)

Divides the input up into two parts with frequency peaks at f Hz intervals, skewed by f/2 Hz between the two outputs. Mixing the two outputs will get you exactly the input signal.I generally use this trick to divide up an input signal, process the two halves differently, then mix them again. It sounds pretty funky.

Band separation (Hz)

The distance between the frequency peaks.

Output 1

The sum output.

Output 2

The difference output.

2.21  Constant Signal Generator (const, 1909)

This plugin add an output DC offset at the given amplitude to the input signal. It has no real use other than for debugging and in modular synths.

Signal amplitude

Controls the amplitude of the output signal.

2.22  Crossover distortion (crossoverDist, 1404)

This is a simulation of the distortion that happens in class B and AB power amps when the signal crosses 0.For class B simulations the smooth value should be set to about 0.3 +/- 0.2 and for AB it should be set to near 1.0.

Crossover amplitude

Controls the point at which the output signal becomes linear.

Smoothing

Controls degree of smoothing of the crossover point.

2.23  DC Offset Remover (dcRemove, 1207)

CPU usage: 10 cycles/sample

Simply removes the DC (0 Hz) component from an audio signal, uses a high pass filter, so has some side effects, but they should be minimal.

2.24  Debug Plugin (debug, 1184)

Prints some stats about the input stream to stdout. Not intended for general use.

2.25  Exponential signal decay (decay, 1886)

Based on work by James McCartney in SuperCollider.

Decay Time (s)

Time for the echoes to decay by 60 decibels.

2.26  Decimator (decimator, 1202)

CPU usage: 29 cycles/sample

Decimates (reduces the effective sample rate), and reduces the bit depth of the input signal, allows non integer values for smooth transitions between clean and lofi signals.

Bit depth

The bit depth that the signal will be reduced to.

Sample rate (Hz)

The sample rate that the signal will be resampled at.

2.27  Declipper (declip, 1195)

CPU usage: 11 cycles/sample

Removes nasty clicks from input signals, not very kind to them though.This code came from the music-dsp mailing list, but it was unattributed, if it's yours, please drop me a line and I'll credit you.

2.28  Simple delay line, noninterpolating (delay_n, 1898)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

2.29  Simple delay line, linear interpolation (delay_l, 1899)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

2.30  Simple delay line, cubic spline interpolation (delay_c, 1900)

Based on work by James McCartney in SuperCollider.

Max Delay (s)

Maximum delay. Used to set the delay buffer size upon activation. Cannot be modulated. Note that if you do not connect to this port before activation, it will default to 1 second.

2.31  Delayorama (delayorama, 1402)

Random seed

Controls the random numbers that will be used to stagger the delays and amplitudes if random is turned up on them. Changing this forces the random values to be recalulated.

Input gain (dB)

Controls the gain of the input signal in dB's.

Feedback (%)

Controls the amount of output signal fed back into the input.

Number of taps

Controls the number of taps in the delay.

First delay (s)

The time of the first delay.

Delay range (s)

The time difference between the first and last delay.

Delay change

The scaling factor between one delay and the next.

Delay random (%)

The random factor applied to the delay.

Amplitude change

The scaling factor between one amplitude and the next.

Amplitude random (%)

The random factor applied to the amplitude.

Dry/wet mix

The level of delayed sound mixed into the output.

2.32  Diode Processor (diode, 1185)

CPU usage: 13 cycles/sample

Mangles the signal as if it had been passed through a diode rectifier network.You should probably follow this with a DC offset remover, unless you want the offset.

Mode (0 for none, 1 for half wave, 2 for full wave)

The mode parameter is continuously variable from thru to half-wave rectification to full-wave to silence.

2.33  Audio Divider (Suboctave Generator) (divider, 1186)

CPU usage: 55 cycles/sample

Reduces the period of the signal by the factor given, and makes it a square wave in the process. Has some amplitude tracking capability, but not really useful on complex signals.

Denominator

The factor the incoming frequency will be divided by.

2.34  DJ EQ (mono) (dj_eq_mono, 1907)

The design for this plugin is taken from the Allen & Heath Xone 32 DJ mixer. It was suggested by Patrick Shirkey. Mono version requested by Adam King

Lo gain (dB)

Controls the gain of the low (100Hz) peak/dip band

Mid gain (dB)

Controls the gain of the mid (1000Hz) peak/dip band

Hi gain (dB)

Controls the gain of the high (10000Hz) shelf band

2.35  DJ EQ (dj_eq, 1901)

The design for this plugin is taken from the Allen & Heath Xone 32 DJ mixer. It was suggested by Patrick Shirkey.

Lo gain (dB)

Controls the gain of the low (100Hz) peak/dip band

Mid gain (dB)

Controls the gain of the mid (1000Hz) peak/dip band

Hi gain (dB)

Controls the gain of the high (10000Hz) shelf band

2.36  DJ flanger (djFlanger, 1438)

This is a flanger which is more or less typical of DJ mising desks. Requested by Patrick Shirkey.

LFO sync

When turned from off to on it resets the phase of the LFO back to the start of the cycle. Used to sync the LFO to the track.

LFO period (s)

The cycle period of the LFO in seconds.

LFO depth (ms)

The maximum delay the LFO will use to flange, in milliseconds.

Feedback (%)

The amount of the delays output that is mixed back into the delay.

2.37  Dyson compressor (dysonCompress, 1403)

Peak limit (dB)

Controls the desired limit of the output signal in dB's.

Release time (s)

Controls the time taken for the compressor to relax its gain control over the input signal.

Fast compression ratio

I have no clear idea what this controls.

Compression ratio

I have no clear idea what this controls.

2.38  Fractionally Addressed Delay Line (fadDelay, 1192)

CPU usage: 397 cycles/sample

A fixed ring buffer delay implementation. Has different dynamics to a normal delay, more suitable for certain things.Changes in delay length are generally more pleasing, but delays >2s long have reduced sound quality.

Delay (seconds)

The neutral delay time is 2 seconds. Times above 2 seconds will have reduced quality and times below will have increased CPU usage.

2.39  Fast Lookahead limiter (fastLookaheadLimiter, 1913)

This is a limiter with an attack time of 5ms. It adds just over 5ms of lantecy to the input signal, but it guatantees that there will be no signals over the limit, and tries to get the minimum ammount of distortion.

Input gain (dB)

Gain that is applied to the input stage. Can be used to trim gain to bring it roughly under the limit or to push the signal against the limit.

Limit (dB)

The maximum output amplitude. Peaks over this level will be attenuated as smoothly as possible to bring them as close as possible to this level.

Release time (s)

The time taken for the limiters attenuation to return to 0 dB's

Attenuation (dB)

The current attenuation of the signal coming out of the delay buffer.

2.40  Flanger (flanger, 1191)

A digital flanger implementation. Uses a novel zero excursion, controlled bandwidth modulation function, which should make the modulation less repetitive and noticable.This effect is similar in character to a phaser (see section 2.75). The main difference is that a phaser sounds more regular and stable.

Delay base (ms)

This is the offset from the input time that the detune delay moves around.10 is probably a good starting value.

Max slowdown (ms)

This is the maximum delay that will be applied to the delayed signal, relative to the dry signal.

LFO frequency (Hz)

This is the core frequency that the 'LFO' will move at. The LFO isn't actually an oscillator, but it does vary periodically.

Feedback

Feedback applied from the output to the input, increases the depth of the effect, but makes it sound less like a real flanger.

2.41  FM Oscillator (fmOsc, 1415)

Waveform (1=sin, 2=tri, 3=squ, 4=saw)

The shape of the waveform.
Value Waveform
1 Sine
2 Triangle
3 Square
4 Saw

Frequency (Hz)

The frequency of the output (in Hertz).

2.42  Foldover distortion (foldover, 1213)

CPU usage: 11 cycles/sample

Uses a sinwave approximation to simulate valve style foldover distortion.Probably should have a DC offset remover on the output, but it's not always necessary.

Drive

Controls the degree of distortion.

Skew

Controls the asymmetry of the waveform.

2.43  Fast overdrive (foverdrive, 1196)

CPU usage: 21 cycles/sample

A simple overdrive. Compresses the extreme peaks to make a sound similar to an overdriven amplifier.

Drive level

Controls the point at which the signal starts to distort, and the degree of distortion.

2.44  Frequency tracker (freqTracker, 1418)

Tracking speed

This controls the level of damping applied to the output.High values will make the frequency output jump around, low values will make it a bit slow to respond.

2.45  Gate (gate, 1410)

The parameters are copied from the Drawmer DS-201, but I've never used one, so if someone out there has one, please tell me if it behaves differently.

LF key filter (Hz)

Controls the cutoff of the low frequency filter (highpass).

HF key filter (Hz)

Controls the cutoff of the high frequency filter (lowpass).

Threshold (dB)

Controls the level at which the gate will open.

Attack (ms)

Controls the time the gate will take to open fully.

Hold (ms)

Controls the minimum time the gate will stay open for.

Decay (ms)

Controls the time the gate will take to close fully.

Range (dB)

Controls the difference between the gate's open and closed state.

Output select (-1 = key listen, 0 = gate, 1 = bypass)

Controls output monitor. -1 is the output of the key filters (so you can check what is being gated on). 0 is the normal, gated output. 1 is bypass mode.

2.46  Gate (gate, 1921)

The parameters are copied from the Drawmer DS-201, but I've never used one, so if someone out there has one, please tell me if it behaves differently.

LF key filter (Hz)

Controls the cutoff of the low frequency filter (highpass).

HF key filter (Hz)

Controls the cutoff of the high frequency filter (lowpass).

Key level (dB)

Shows the current level of the key.

Threshold (dB)

Controls the level at which the gate will open.

Attack (ms)

Controls the time the gate will take to open fully.

Hold (ms)

Controls the minimum time the gate will stay open for.

Decay (ms)

Controls the time the gate will take to close fully.

Range (dB)

Controls the difference between the gate's open and closed state.

Output select (-1 = key listen, 0 = gate, 1 = bypass)

Controls output monitor. -1 is the output of the key filters (so you can check what is being gated on). 0 is the normal, gated output. 1 is bypass mode.

2.47  Stereo Gate (stereo_gate, 1922)

Derived from Steve Harris' gate plugin

LF key filter (Hz)

Controls the cutoff of the low frequency filter (highpass).

HF key filter (Hz)

Controls the cutoff of the high frequency filter (lowpass).

Key level (dB)

Shows the current level of the key.

Threshold (dB)

Controls the level at which the gate will open.

Attack (ms)

Controls the time the gate will take to open fully.

Hold (ms)

Controls the minimum time the gate will stay open for.

Decay (ms)

Controls the time the gate will take to close fully.

Range (dB)

Controls the difference between the gate's open and closed state.

Output select (-1 = key listen, 0 = gate, 1 = bypass)

Controls output monitor. -1 is the output of the key filters (so you can check what is being gated on). 0 is the normal, gated output. 1 is bypass mode.

2.48  Giant flange (giantFlange, 1437)

This is a fairly normal flanger but with excessivly long delay times. Requested by Patrick Shirkey.To cut down the memory requirements the internal delay buffer noly has 15bits or resolution, so there is no headroom, if you feed in signals over 0dB it will clip the output. There is code to soften the effect of the clipping, but beware of it.

Double delay

doubles the length of the delays, this will reduce the sound quality.

LFO frequency 1 (Hz)

The delay of the first LFO in seconds.

Delay 1 range (s)

The delay range of the first LFO in seconds.

LFO frequency 2 (Hz)

The delay of the second LFO in seconds.

Delay 2 range (s)

The delay range of the second LFO in seconds.

Feedback

The amount of the delays output that is mixed back into the delay.

Dry/Wet level

The ammounts of the input and effect mixed to produce the output.

2.49  Gong model (gong, 1424)

A physical model of a metal gong.Based on Josep Comajuncosas' gong explorer, which was built in Sync Modular, it uses 8 linear waveguides with nonlinear filters to model the gong surface.

Inner damping

Controls the degree of damping in the centre of the gong.

Outer damping

Controls the degree of damping on the edge of the gong.

Mic position

Controls the vertical position of the "microphone", 0 is the centre and 1 is the edge.

Inner size 1

The size of the upper, inner waveguide.

Inner stiffness 1 +

The stiffness of the gong against deflections in the positive direction.

Inner stiffness 1 -

The stiffness of the gong against deflections in the negative direction.

Inner size 2

The size of the right, inner waveguide.

Inner stiffness 2 +

The stiffness of the gong against deflections in the positive direction.

Inner stiffness 2 -

The stiffness of the gong against deflections in the negative direction.

Inner size 3

The size of the lower, inner waveguide.

Inner stiffness 3 +

The stiffness of the gong against deflections in the positive direction.

Inner stiffness 3 -

The stiffness of the gong against deflections in the negative direction.

Inner size 4

The size of the left, inner waveguide.

Inner stiffness 4 +

The stiffness of the gong against deflections in the positive direction.

Inner stiffness 4 -

The stiffness of the gong against deflections in the negative direction.

Outer size 1

The size of the upper right, outer waveguide.

Outer stiffness 1 +

The stiffness of the gong against deflections in the positive direction.

Outer stiffness 1 -

The stiffness of the gong against deflections in the negative direction.

Outer size 2

The size of the lower right, outer waveguide.

Outer stiffness 2 +

The stiffness of the gong against deflections in the positive direction.

Outer stiffness 2 -

The stiffness of the gong against deflections in the negative direction.

Outer size 3

The size of the lower left, outer waveguide.

Outer stiffness 3 +

The stiffness of the gong against deflections in the positive direction.

Outer stiffness 3 -

The stiffness of the gong against deflections in the negative direction.

Outer size 4

The size of the upper left, outer waveguide.

Outer stiffness 4 +

The stiffness of the gong against deflections in the positive direction.

Outer stiffness 4 -

The stiffness of the gong against deflections in the negative direction.

2.50  Gong beater (gongBeater, 1439)

A plugin to simulator the action of a beator on a gong surface, used to trigger the gong physical model.It is triggered by an impulse on the input, eg. from a mic or piezo placed near a solid surface, for an event sequencer.

Impulse gain (dB)

The gain of the input impulse mixed into the output, bringing this up allows you to make the outputted strike more impulsive, but may reduce the gongyness of the resulting output sound.

Strike gain (dB)

The gain of the simulated pressure wave mixed into the output, bringing this up allows you to make the outputted strike more pure. The final output level is also proprtional to the amplitude of the trigger.

Strike duration (s)

The duration of the pressure wave used to simulate the action of the beater on the gong surface. The logner the duration the more sonorus the resulting gong sound.

2.51  GSM simulator (gsm, 1215)

CPU usage: 377 cycles/sample

Encodes and decodes a signal using the GSM voice compression system. Has the effect of making the signal sound like it is being sent over a European mobile phone network.

Dry/wet mix

Controls the dry/wet mix, 0 will give you the dry signal (but with the appropriate amount of delay), 1 will give you a totally wet signal.

Number of passes

The number of times the signal is sent through the encode/decode process. Increases the CPU consumption almost linearly, and it will become more peaky so less friendly to realtime processing.

Error rate (bits/block)

The number of simulated bits that get changed during the transmission process.I really wanted to reduce the bandwidth to get that ßhouting down a drainpipe" effect, but I'm not sure how the reduced bandwidth is dealt with by real phones. I suspect it's heavily patented technology.

2.52  GVerb (gverb, 1216)

A mono in, stereo out reverb implementation by Juhana Sadeharju (kouhia at nic.funet.fi). I ported it to LADSPA and did some testing.Please contact Juhana directly regarding any bugs you find. Paul Winkler recommends a good starting point for a "large hall" as follows:

Parameter amp; Value
Roomsize amp; 200
Reverb time amp; 1.3
Damping amp; 0.4
Input bandwidth amp; 0.5
Dry signal level amp; 0
Early reflection level amp; -12
Tail level amp; 0

Roomsize (m)

The size of the room, in meters. Excessivly large, and excessivly small values will make it sound a bit unrealistic.Values of around 30 sound good.

Reverb time (s)

Reverb decay time, in seconds. 7 is a good place to start.

Damping

This controls the high frequency damping (a lowpass filter), values near 1 will make it sound very bright, values near 0 will make it sound very dark.

Input bandwidth

This is like a damping control for the input, it has a similar effect to the damping control, but is subtly different.

Dry signal level (dB)

The amount of dry signal to be mixed with the reverberated signal.

Early reflection level (dB)

The quantity of early reflections (scatter reflections directly from the source). Think of Lexicons ambiance patches.

Tail level (dB)

The level of the classic reverb tail reflections.

2.53  Hard Limiter (hardLimiter, 1413)

Brick hard limiter with residue mixer.

Wet level

Output level for limited signal.

Residue level

Output level for residue signal.

2.54  Harmonic generator (harmonicGen, 1220)

CPU usage: 45 cycles/sample

What does it do?

Allows you to add harmonics and remove the fundamental from any audio signal.

Known bugs

There is no bandwith limiting filter on the output, so it is easy to create excessively high frequency harmonics that could cause aliasing problems. In practive this doesn't seem to be a serious problem however.

Examples

There are many interesting effects you can achieve with sinewaves, one example is producing bandlimited squarewaves from sinewaves. To do this set the parameters to 1, 0, -0.3333, 0, 0.2, 0, -0.14285, 0, 0.11111.To get a triangle like signal use 1, 0, -0.3333, 0, -0.2, 0, -0.14285, 0, -0.11111.

Fundamental magnitude

The amplitude of the fundamental of the signal, reduce it to 0 to remove the base signal altogether, or -1 to phase invert it.

2nd harmonic magnitude

The 2nd harmonic, its frequency is twice the frequency of the harmonic.Even harmonics add a distorted feel to the sound, valve (tube) amplifiers introduce distortions at all the harmonics.

3rd harmonic magnitude

The 3rd harmonic, its frequency is three time the frequency of the fundamental.Transistor amplifiers only introduce distortion into the odd harmonics.

2.55  Hermes Filter (hermesFilter, 1200)

CPU usage: 1400 cycles/sample

This plugin is a simulation of a modern analogue synth called a Pro Tone, with some extra features bolted on, like a crossover. I tried to make it as comprehensive as possible, without requiring ludicrous amounts of CPU juice.N.B. as far as I know, noone has tried to use this (I certainly haven't), so it may be full of bugs and what not. The parameters are all undocumented, but there is a diagram of the routing on the website. Without a custom interface however it would be very hard to use.Historical note: the name is a bad pun, it comes from the name Hermes Trimegistus given to the Egyptian god Thoth by the greeks, it means Thrice Blessed, or something similar.

2.56  Glame Highpass Filter (highpass_iir, 1890)

IIR highpass filter based using chebishev coefficients. The filter allows you to tweak the number of stages used for filtering. Every stage adds two more poles, which leads to a steeper dropoff. More stages need more CPU power. This filter was ported from the glame multitrack editor to ladspa.

2.57  Hilbert transformer (hilbert, 1440)

A Hilbert Transformer phase shifts the input signal by 90degrees. It outputs the 90 degree phase shifted signal and the unshifted signal, both delayed by an equivlaent ammountThis plugin was written for a demo at the LAD Meet in 2003.

2.58  Impulse convolver (imp, 1199)

This is a convolver for a set of fairly short impulses.

The set of impulses has to be compiled in, they are:

Id Impulse
1 Unit impulse (identity)
2 My flat (light natural reverb)
3 Yamaha Marshall stack simulator
4 Fender 68 Vibrolux (SM57 on axis)
5 Fender 68 Vibrolux (SM57 off axis)
6 Fender 68 Vibrolux (Audio-technica AT4050)
7 Fender 68 Vibrolux (Neumann U87)
8 Fender Bassman (SM57 on axis)
9 Fender Bassman (SM57 off axis)
10 Fender Bassman (Audio-technica AT4050)
11 Fender Bassman (Neumann U87)
12 Fender Superchamp (SM57 on axis)
13 Fender Superchamp (SM57 off axis)
14 Fender Superchamp (Audio-technica AT4050)
15 Fender Superchamp (Neumann U87)
16 Marshall JCM2000 (SM57 on axis)
17 Marshall JCM2000 (SM57 off axis)
18 Marshall Plexi (SM57 on axis)
19 Marshall Plexi (SM57 off axis)
20 Matchless Chieftan (SM57 on axis)
21 Matchless Chieftan (SM57 off axis)

The first three were quickly grabbed by me using jack_impulse_grabber, and the others we collected by someone else, but unfortunately I've lost his email address and can't find him on the web :(

Impulse ID

Selects the impulse to convolve with. New impulses have to be compiled in.

High latency mode

If you are running with blocks that are not whole powers of two long, or you are hearing distortion, try changing this to 1.

Gain (dB)

Controls the gain of the output signal in dB's.

2.59  Nonbandlimited single-sample impulses (Frequency: Control) (impulse_fc, 1885)

Based on work by James McCartney in SuperCollider.

Frequency (Hz)

Frequency for the impulses.

2.60  Inverter (inv, 1429)

A utility plugin that inverts the signal, also (wrongly) known as a 180 degree phase shift.

2.61  Karaoke (karaoke, 1409)

Attempts to strip the vocals from a stereo signal.

Vocal volume (dB)

Controls the attenuation of the vocal (centre channel) in dB's.The greater the attenuation the greater the loss of stereo field.

2.62  Artificial latency (artificialLatency, 1914)

Reports its delay value as systemic latency. Does nothing else, *this is not a delay*.Can be used to correct for latency between channels.

2.63  L/C/R Delay (lcrDelay, 1436)

This is a left/centre/right delay with feedback, based on the one in the Korg Trinity. Requested by Marek Peteraj.

L delay (ms)

The delay of the left output in milliseconds.

L level

The level of the left output.

C delay (ms)

The delay of the centre output in milliseconds.

C level

The level of the centre output.

R delay (ms)

The delay of the right output in milliseconds.

R level

The level of the right output.

Feedback

The amount of the C delay output that is mixed back into the delay.

High damp (%)

The damping of the high frequencies in the feedback path.

Low damp (%)

The damping of the low frequencies in the feedback path.

Spread

The width of the stereo image.

Dry/Wet level

The ammounts of the input and effect mixed to produce the output.

2.64  Lookahead limiter (lookaheadLimiter, 1435)

Limit (dB)

The maximum output amplitude. Peaks over this level will be attenuated as smoothly as possible to bring them as close as possible to this level.

Lookahead delay

The delay used by the lookahead predictor. The longer the delay the smoother the limiting will be, but higher the latency.

Attenuation (dB)

The current attenuation of the signal coming out of the delay buffer.

2.65  Lookahead limiter (fixed latency) (lookaheadLimiterConst, 1906)

A lookahead limiter - similar to the original Lookahead Limiter, but with a constant latency of around 150ms and a reduacued maximum lookahead time.

Limit (dB)

The maximum output amplitude. Peaks over this level will be attenuated as smoothly as possible to bring them as close as possible to this level.

Lookahead time (s)

The lookahead time used by the lookahead predictor. The longer the time the smoother the limiting will be, but will tend to make the changes in dynamic range more obvious.

Attenuation (dB)

The current limiting attenuation of the signal coming out of the delay buffer.

2.66  Glame Lowpass Filter (lowpass_iir, 1891)

IIR lowpass filter based using chebishev coefficients. The filter allows you to tweak the number of stages used for filtering. Every stage adds two more poles, which leads to a steeper dropoff. More stages need more CPU power. This filter was ported from the glame multitrack editor to ladspa.

2.67  LS Filter (lsFilter, 1908)

This is a filter created for the LinkSampler project - its designed to closly follow the filter used in giga sampler.

Filter type (0=LP, 1=BP, 2=HP)

The type of the filter, 0 for low pass, 1 for band pass, 2 for high pass.

Cutoff frequency (Hz)

Controls the frequency at which the filter starts to effect the audio signal.eg. a lowpass filter with a cutoff frequency of 1000 Hz will only let frequencies below 100 Hz through.

Resonance

Creates a peak at the cutoff frequency, for the classic overdriven fileter sound. At high vlaues the peak at the cutoff will overwhelm the filtered signal.

2.68  Matrix: MS to Stereo (matrixMSSt, 1421)

Width

The width of the dematrixed stereo field. 1 will give you normal width, 0 will make it completely mono, < 1 will make it narrower and > 1 will make it wider.

2.69  Matrix Spatialiser (matrixSpatialiser, 1422)

A simple spatializer that lets you control the width of a stereo signal.

We convert it into a MS (mid/side) signal, manipulate the gain coefficients with a constant-power panning function, and reconvert to left/right stereo.

mid = (i_left + i_right) / 2

side = (i_left - i_right) / 2

width = (-pi/4)..0..(pi/4)

o_left = mid * cos(width + pi/4) o_right = side * sin(width + pi/4)

shifted by pi/4, so that 0 is neutral.

Width

0 is neutral (unmodified signal) + 128 is side only (=very wide) - 128 is mid only (=mono)

2.70  Matrix: Stereo to MS (matrixStMS, 1420)

2.71  Multiband EQ (mbeq, 1197)

This is a fairly typical multiband graphical equalizer. It's implemented using a FFT, so it takes quite a lot of CPU power, but should have less phase effects than an equivalent filter implementation.If the input signal is at too low a sample rate then the top bands will be ignored, the highest useful band will always be a high shelf.

2.72  Modulatable delay (modDelay, 1419)

A delay whose tap can be modulated at audio rate.Requested by Matthias Nagorni at LinuxTag 2002, in order to make a Leslie simulator.

2.73  Multivoice Chorus (multivoiceChorus, 1201)

This is an implementation of a Multivoice (as opposed to Multiscale) chorus algorithm. Its uses a novel, sinc based noise interpolation method to produce a subtle modulation law which makes it possible to get away with larger numbers of voices without the metallic, artificial sound common in chorus effects.

Voice separation (ms)

The individual voices can either be running at the same base delay (set this to zero) or staggered.Setting this to non-zero values can make the output sound richer, but will make it sound grainy with some type of signal.

Detune (%)

The maximum amount that a voice will be detuned by. I recommend a value of 1, but you may be able to get away with higher values if the signal is less harmonic.

LFO frequency (Hz)

The frequency that the detune effect will be modulated at. A matter of taste, for most types of input lower will be more subtle.

Output attenuation (dB)

With large numbers of voices the output can become too high, so use this to trim the amplitude to a more helpful level.

2.74  Mag's Notch Filter (notch_iir, 1894)

IIR notch filter based using chebishev coefficients. The filter allows you to tweak the number of stages used for filtering. Every stage adds two more poles, which leads to a steeper dropoff. More stages need more CPU power.

2.75  LFO Phaser (lfoPhaser, 1217)

CPU usage: 197 cycles/sample

2.76  4 x 4 pole allpass (fourByFourPole, 1218)

CPU usage: 262 cycles/sample

2.77  Auto phaser (autoPhaser, 1219)

CPU usage: 121 cycles/sample

2.78  Pitch Scaler (pitchScale, 1193)

CPU usage: 1323 cycles/sample

A pitch shifter implementation that scales the harmonics appropriately with the base frequencies. It is an implementation of Stephen M. Sprengler's pitch scaler design. It gives reasonable, general purpose results for small changes, but won't give Antares or Eventide anything to worry about.The FFT block size and oversampling has been kept at a minimum to keep the CPU usage low.

2.79  Higher Quality Pitch Scaler (pitchScaleHQ, 1194)

A pitch shifter implementation that scales the harmonics appropriately with the base frequencies. It is an implementation of Stephen M. Sprengler's pitch scaler design. It gives reasonable, general purpose results for small changes, but won't give Antares or Eventide anything to worry about.The FFT block size and oversampling has been kept at reasonable levels to keep the CPU usage low, but it is smoother than the other Pitch Scaler.

Pitch co-efficient

The pitch scaling factor, a value of 2.0 will increase the pitch by one octave, etc.

2.80  Plate reverb (plate, 1423)

A physical model of a steel plate reverb.Based on Josep Comajuncosas' gong model, it uses 8 linear waveguides to model the plate.

Reverb time

Controls the RT60 time of the reverb. Actually controls the size of the plate. The mapping betwwen plate size and RT60 time is just a heuristic, so it's not very accurate.

Damping

Controls the degree that the surface of the plate is damped.

Dry/wet mix

Controls the balance between the dry and wet signals.

2.81  Pointer cast distortion (pointerCastDistortion, 1910)

This distortion is created by treating the floating point repesentation of the input signal as a 0.32 1's complement fixedpoint integer. Its very unmusical but supprisingly recognisable. I'm not sure that its useful for anything, but it can make interesting noises.

Effect cutoff freq (Hz)

Controls the frequencies that will be passed to the effect.

Dry/wet mix

Controls the ammount of distioning mixed into the output.

2.82  Rate shifter (rateShifter, 1417)

Stretches or compresses the input with a ringbuffer.Because of the ringbuffer you will get stretches of silence or clicks when the read pointer passes the write pointer.The ringbuffer is about 2.7-3.0s long, depending on the sample rate.Versions with variable buffer sizes or declicking code would be easy (but a bit less efficient); shout if you would find them useful.

Rate

The rate of the output signal; eg. 2.0 will double the speed. Negative numbers will play backwards.Pretty much any value will work, but the ranges give what most people are going to want to use. You can get some interesting sounds with very high numbers (e.g. 2000).

2.83  Retro Flanger (retroFlange, 1208)

A model of someone flanging the input.Models the tape saturation effects, and frequency smear of a manual flanger. The results are a slightly distorted, but more subtle flanger sound that you get from a normal digial flanger.

Average stall (ms)

The average time difference between the two tapes, per stall

Flange frequency (Hz)

The rate the tape is stalled at.

2.84  Reverse Delay (5s max) (revdelay, 1605)

A reverse delay not really modelled on any existing one. You'll want to set the Crossfade Samples parameter to something reasonably small (but more than 20) for most applications, but you can try larger values if you start getting clicking.

Dry Level (dB)

Controls the level of the dry input signal in dB's.

Wet Level (dB)

Controls the level of the delayed signal in dB's.

2.85  Ringmod with two inputs (ringmod_2i1o, 1188)

This is a simple 2 input ring modulator.It is important that the modulator input is bounded to (-1, +1), otherwise you will get rubbish on the output.

Input

This is the audio input.

Modulator

This is the modulator input.

2.86  Ringmod with LFO (ringmod_1i1o1l, 1189)

CPU usage: 102 cycles/sample

This is a simple ring modulator and LFO.

2.87  Barry's Satan Maximiser (satanMaximiser, 1408)

Formerly Stupid Compressor. Thanks to Matt Yee-King for the name.Compresses signals with a stupidly short attack and decay, infinite ratio and hard knee. Not really as a compressor, but good harsh (non-musical) distortion.

Decay time (samples)

Controls the envelope decay time.

Knee point (dB)

Controls the knee roll-off point, ie. the point above which the compression kicks in. 0 will have no effect, -90 will remove virtually all dynamic range.

2.88  SC1 (sc1, 1425)

An high quality, reasonably low CPU cost RMS compressor designed for musical work.It has controls for the compression point, compression ratio and knee softness.

Attack time (ms)

The attack time in milliseconds.

Release time (ms)

The release time in milliseconds.

Threshold level (dB)

The point at which the compressor will start to kick in.

Ratio (1:n)

The gain reduction ratio used when the signal level exceeds the threshold.

Knee radius (dB)

The distance from the threshold where the knee curve starts.

Makeup gain (dB)

Controls the gain of the makeup input signal in dB's.

2.89  SC2 (sc2, 1426)

A compressor with sidechain. Based on the code for SC1.

Attack time (ms)

The attack time in milliseconds.

Release time (ms)

The release time in milliseconds.

Threshold level (dB)

The point at which the compressor will start to kick in.

Ratio (1:n)

The gain reduction ratio used when the signal level exceeds the threshold.

Knee radius (dB)

The distance from the threshold where the knee curve starts.

Makeup gain (dB)

Controls the gain of the makeup input signal in dB's.

2.90  SC3 (sc3, 1427)

A stereo compressor with sidechain input. Based on the code for SC1.

Attack time (ms)

The attack time in milliseconds.

Release time (ms)

The release time in milliseconds.

Threshold level (dB)

The point at which the compressor will start to kick in.

Ratio (1:n)

The gain reduction ratio used when the signal level exceeds the threshold.

Knee radius (dB)

The distance from the threshold where the knee curve starts.

Makeup gain (dB)

Controls the gain of the makeup input signal in dB's.

Chain balance

Controls the chain signal used, 0 = Left+right in, 1 = Sidechain.

2.91  SC4 (sc4, 1882)

A stereo compressor with variable envelope follower for RMS / peak behaviour. Based on the code for SC1.

RMS/peak

The blanace between the RMS and peak envelope followers.RMS is generally better for subtle, musical compression and peak is better for heavier, fast compression and percussion.

Attack time (ms)

The attack time in milliseconds.

Release time (ms)

The release time in milliseconds.

Threshold level (dB)

The point at which the compressor will start to kick in.

Ratio (1:n)

The gain reduction ratio used when the signal level exceeds the threshold.

Knee radius (dB)

The distance from the threshold where the knee curve starts.

Makeup gain (dB)

Controls the gain of the makeup input signal in dB's.

Amplitude (dB)

The level of the input signal, in decibels.

Gain reduction (dB)

The degree of gain reduction applied to the input signal, in decibels.

2.92  SE4 (se4, 1883)

A stereo expander with variable envelope follower for RMS / peak behaviour. Based on the code for SC1.

RMS/peak

The blanace between the RMS and peak envelope followers.

Attack time (ms)

The attack time in milliseconds.

Release time (ms)

The release time in milliseconds.

Threshold level (dB)

The point at which the expander will start to kick in.

Ratio (1:n)

The gain expansion ratio used when the signal level exceeds the threshold.

Knee radius (dB)

The distance from the threshold where the knee curve starts.

Attenuation (dB)

Controls the gain of the output signal in dB's. Used to correct for excessive amplitude caused by the extra dynamic range.

Amplitude (dB)

The level of the input signal, in decibels.

Gain expansion (dB)

The degree of gain expansion applied to the input signal, in decibels.

2.93  Wave shaper (shaper, 1187)

CPU usage: 200 cycles/sample

This plugin reshapes the wave by an exponential function, inspiration was taken from the Nord module of the same name.If you are getting rubbish out then it's probably because the host isn't using the input/output range hints, which are very important for this plugin.

Waveshape

Positive values have an expanding effect, and negative values have a compressing effect.

2.94  Signal sifter (sifter, 1210)

Sorts and mixes blocks of the input signal to give a "bumpy ramp" effect.Certain types of input will produce silence on the output (mostly ones with only low frequency components).This is a very odd effect, and doesn't really have any music applications, but can produce some interesting noises.

2.95  Sine + cosine oscillator (sinCos, 1881)

This is a simple oscillator that outputs sinewaves with a 90 degree phase shift between them.The current implementation is very inefficient, but I will improve it later.

Base frequency (Hz)

The base frequency of the output waves.

Pitch offset

The pitch offset of the output waves. Final oscillator frequency is base + 2pitch.

2.96  Single band parametric (singlePara, 1203)

A single band of a parametric filter.

Gain (dB)

The attenuation/gain of the eq.

Frequency (Hz)

The centre frequency (ie. point of most/least attenuation).Beware of high values for Frequency and Bandwidth, if the high pitch (Frequency * 2Bandwidth) goes over half the sample rate you will get aliasing.Note: if your host offers you a frequency range between 0 and 0.4 then it's not rendering the input parameter correctly, the input frequency will actually be that number multiplied by the sample rate (e.g. 44.1kHz).

Bandwidth (octaves)

The pitch difference from the centre before the attenuation has reached half the gain.

2.97  Sinus wavewrapper (sinusWavewrapper, 1198)

Produces an unusual distortion effect, for a more amp like tone, see the valve saturation plugin (section 2.106).

2.98  Smooth Decimator (smoothDecimate, 1414)

Resample rate

The rate at which the output signal will be resampled

Smoothing

The amount of smoothing on the output signal.

2.99  Mono to Stereo splitter (split, 1406)

Takes a mono input signal, and outputs it to both left and right channel, thus ßtereophizing" it.

2.100  Step Demuxer (stepMuxer, 1212)

Inputs up to 8 signals and switches between them on the output when then signal on the clock input goes high.This plugin is untested, and may not work.

2.101  Surround matrix encoder (surroundEncoder, 1401)

I haven't been able to test this plugin, so there may be bugs. I have successfully tested the algorithm, but the implementation is suspect.

What does it do?

It allows you to encode four channels of sound into a stereo compatible stream that will be decoded by a Dolby1 Surround/Pro-Logic decoder into Left, Right, Center and Surround signals.This is not a proper implementation of Pro-logic, there is no Dolby B processing done on the surround channel, which would help, but would be using Dolby intellectual property.

Caveats

Obviously you can't wedge four channels into two without loss, so something has to give. You will probably notice significant cross-talk between the channels, but the decoder should do cross-talk correction, which will help a lot. A side effect of this is that it will make left-right panning unusual, the sources will dwell near the left and right speakers and zip across the centre channel. Because of this it is only really possible to master surround recordings through a pre-logic decoder. Do not attempt to use a conventional 5 point surround multichannel setup, it behaves very differently.In addition to this, output from this process is not entirly mono compatible, in mono output the L, C and R will be preserved as per a stereo recording (centre will be mixed equally), but the surround channel will be totally lost.Careful gain control on the output is required, as the level of the output will be greater than the L and R inputs, but different to the sum amplitude of the input signals.Widely panned reverb fed to the L and R channels will often leak into the S channel, if this is not desired (often it is) reduce the width of the stereo image.The encoding will survive some processes (eg. copying to CD, MD etc.), but may not survive conversion to MP3 or recoding to tape with azimuth errors.

Legalese

This is a four channel matrix encoder, it happens to be compatible with Dolby Surround Pro-Logic.This implementation does not convey a license nor imply a right under any patent, or any other industrial or intellectual property right of Dolby Laboratories.

L

Left channel input. Can be treated as per normal stereo recoding, except that the speaker should be at -22.5°, rather than the normal stereo -30°.

R

Right channel input. As per left channel.

C

Center channel input. Will be directly in front of the listener, stereo and mono compatible.

S

Surround channel. Should sound from the rear speakers, may also leak into the left and right. Has slight delay and bandwidth reduction (cut below 100 Hz, and above 7 KHz) for leakage and noise reduction and enhanced psychoacoustic effects.Not mono compatible.

2.102  State Variable Filter (svf, 1214)

An oversampled state variable filter with a few tweaksQuite a nice State Variable Filter, tends to be unstable with high resonance and Q values, but good when kept under control.

Filter type (0=none, 1=LP, 2=HP, 3=BP, 4=BR, 5=AP)

Select between no filtering, low-pass, high-pass, band-pass, band-reject and all-pass.

Filter freq

Cutoff frequency, beware of high values with low sample rates.

Filter Q

The filters Q, or cutoff slope.

Filter resonance

The filter's resonance, sort of separate from Q but very related (implemented with feedback).Do not use with the bandpass mode.

2.103  Tape Delay Simulation (tapeDelay, 1211)

CPU usage: 405 cycles/sample

Correctly models the tape motion and some of the smear effect, there is no simulation fo the head saturation yet, as I don't have a good model of it. When I get one I will add it.The way the tape accelerates and decelerates gives a nicer delay effect for many purposes.

2.104  Transient mangler (transient, 1206)

2.105  Triple band parametric with shelves (triplePara, 1204)

Actually five bands of eq, but the first and last are locked to shelving filters.For details see the single band parametric (section 2.96).

2.106  Valve saturation (valve, 1209)

CPU usage: 317 cycles/sample

A model of valve (tube) distortion, lacking some of the harmonics you would get in a real tube amp, but sounds good nonetheless.Taken from Ragnar Bendiksen's thesis: http://www.notam02.no/~rbendiks/Diplom/Innhold.html.

Distortion level

How hard the signal is driven against the limit of the amplifier.

Distortion character

The hardness of the sound, low for soft, high for hard.

2.107  Valve rectifier (valveRect, 1405)

Sag level

The level of power supply sag that will be caused by attacks.

Distortion

How harsh the distortion caused by the sag will be.

2.108  VyNil (Vinyl Effect) (vynil, 1905)

Year

The date of the recording/playback equipment to be simulated.

RPM

The rotational speed of the platter.

Surface warping

The degree of variation in height of the record surface.

Crackle

The number of scratches on the record surface.

Wear

The ammount of wear on the grooves.

2.109  Wave Terrain Oscillator (waveTerrain, 1412)

A Wave Terrain oscillator, taken from Curtis Roads' example in The Computer Music Tutorial.Inputs x and y move the cursor around on a 2D landscape "wavetable" that is used to generate the output. The function used is z = (x - y) * (x - 1) * (x + 1) * (y - 1) * (y + 1).

2.110  Crossfade (xfade, 1915)

Crossfade

Controls the degree to which the inputs are mixed into the output. A value of -1 means that the output is just the A input, and a value of 1.0 means that it is just the B input.

2.111  Crossfade (4 outs) (xfade4, 1916)

Crossfade

Controls the degree to which the inputs are mixed into the output. A value of -1 means that the output is just the A input, and a value of 1.0 means that it is just the B input.

2.112  z-1 (zm1, 1428)

A plugin that implements the z-1 function (a single sample delay).

3  Licensing

All this code is available under the GNU Public Licence, see the file ''COPYING'' included with the source for more detials.


Footnotes:

1 "Dolby" is a trademark of Dolby Laboratories.


File translated from TEX by TTH, version 2.51.
On 26 Oct 2004, 14:38.
debian/source/0000755000000000000000000000000012067064404010471 5ustar debian/source/format0000644000000000000000000000001412067064404011677 0ustar 3.0 (quilt) debian/watch0000644000000000000000000000016012067064404010217 0ustar version=3 opts=dversionmangle=s/\+\d+// \ http://plugin.org.uk/releases/([\d.]+)/swh-plugins-([\d.]+)\.tar\.gz