Blame ltmain.sh

Packit Service e31359
#! /bin/sh
Packit Service e31359
## DO NOT EDIT - This file generated from ./build-aux/ltmain.in
Packit Service e31359
##               by inline-source v2014-01-03.01
Packit Service e31359
Packit Service e31359
# libtool (GNU libtool) 2.4.6
Packit Service e31359
# Provide generalized library-building support services.
Packit Service e31359
# Written by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
Packit Service e31359
Packit Service e31359
# Copyright (C) 1996-2015 Free Software Foundation, Inc.
Packit Service e31359
# This is free software; see the source for copying conditions.  There is NO
Packit Service e31359
# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Packit Service e31359
Packit Service e31359
# GNU Libtool is free software; you can redistribute it and/or modify
Packit Service e31359
# it under the terms of the GNU General Public License as published by
Packit Service e31359
# the Free Software Foundation; either version 2 of the License, or
Packit Service e31359
# (at your option) any later version.
Packit Service e31359
#
Packit Service e31359
# As a special exception to the GNU General Public License,
Packit Service e31359
# if you distribute this file as part of a program or library that
Packit Service e31359
# is built using GNU Libtool, you may include this file under the
Packit Service e31359
# same distribution terms that you use for the rest of that program.
Packit Service e31359
#
Packit Service e31359
# GNU Libtool is distributed in the hope that it will be useful, but
Packit Service e31359
# WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service e31359
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service e31359
# General Public License for more details.
Packit Service e31359
#
Packit Service e31359
# You should have received a copy of the GNU General Public License
Packit Service e31359
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
Packit Service e31359
Packit Service e31359
Packit Service e31359
PROGRAM=libtool
Packit Service e31359
PACKAGE=libtool
Packit Service e31359
VERSION=2.4.6
Packit Service e31359
package_revision=2.4.6
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ------ ##
Packit Service e31359
## Usage. ##
Packit Service e31359
## ------ ##
Packit Service e31359
Packit Service e31359
# Run './libtool --help' for help with using this script from the
Packit Service e31359
# command line.
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ------------------------------- ##
Packit Service e31359
## User overridable command paths. ##
Packit Service e31359
## ------------------------------- ##
Packit Service e31359
Packit Service e31359
# After configure completes, it has a better idea of some of the
Packit Service e31359
# shell tools we need than the defaults used by the functions shared
Packit Service e31359
# with bootstrap, so set those here where they can still be over-
Packit Service e31359
# ridden by the user, but otherwise take precedence.
Packit Service e31359
Packit Service e31359
: ${AUTOCONF="autoconf"}
Packit Service e31359
: ${AUTOMAKE="automake"}
Packit Service e31359
Packit Service e31359
Packit Service e31359
## -------------------------- ##
Packit Service e31359
## Source external libraries. ##
Packit Service e31359
## -------------------------- ##
Packit Service e31359
Packit Service e31359
# Much of our low-level functionality needs to be sourced from external
Packit Service e31359
# libraries, which are installed to $pkgauxdir.
Packit Service e31359
Packit Service e31359
# Set a version string for this script.
Packit Service e31359
scriptversion=2015-01-20.17; # UTC
Packit Service e31359
Packit Service e31359
# General shell script boiler plate, and helper functions.
Packit Service e31359
# Written by Gary V. Vaughan, 2004
Packit Service e31359
Packit Service e31359
# Copyright (C) 2004-2015 Free Software Foundation, Inc.
Packit Service e31359
# This is free software; see the source for copying conditions.  There is NO
Packit Service e31359
# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Packit Service e31359
Packit Service e31359
# This program is free software; you can redistribute it and/or modify
Packit Service e31359
# it under the terms of the GNU General Public License as published by
Packit Service e31359
# the Free Software Foundation; either version 3 of the License, or
Packit Service e31359
# (at your option) any later version.
Packit Service e31359
Packit Service e31359
# As a special exception to the GNU General Public License, if you distribute
Packit Service e31359
# this file as part of a program or library that is built using GNU Libtool,
Packit Service e31359
# you may include this file under the same distribution terms that you use
Packit Service e31359
# for the rest of that program.
Packit Service e31359
Packit Service e31359
# This program is distributed in the hope that it will be useful,
Packit Service e31359
# but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service e31359
# MERCHANTABILITY or FITNES FOR A PARTICULAR PURPOSE. See the GNU
Packit Service e31359
# General Public License for more details.
Packit Service e31359
Packit Service e31359
# You should have received a copy of the GNU General Public License
Packit Service e31359
# along with this program. If not, see <http://www.gnu.org/licenses/>.
Packit Service e31359
Packit Service e31359
# Please report bugs or propose patches to gary@gnu.org.
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ------ ##
Packit Service e31359
## Usage. ##
Packit Service e31359
## ------ ##
Packit Service e31359
Packit Service e31359
# Evaluate this file near the top of your script to gain access to
Packit Service e31359
# the functions and variables defined here:
Packit Service e31359
#
Packit Service e31359
#   . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh
Packit Service e31359
#
Packit Service e31359
# If you need to override any of the default environment variable
Packit Service e31359
# settings, do that before evaluating this file.
Packit Service e31359
Packit Service e31359
Packit Service e31359
## -------------------- ##
Packit Service e31359
## Shell normalisation. ##
Packit Service e31359
## -------------------- ##
Packit Service e31359
Packit Service e31359
# Some shells need a little help to be as Bourne compatible as possible.
Packit Service e31359
# Before doing anything else, make sure all that help has been provided!
Packit Service e31359
Packit Service e31359
DUALCASE=1; export DUALCASE # for MKS sh
Packit Service e31359
if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then :
Packit Service e31359
  emulate sh
Packit Service e31359
  NULLCMD=:
Packit Service e31359
  # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
Packit Service e31359
  # is contrary to our usage.  Disable this feature.
Packit Service e31359
  alias -g '${1+"$@"}'='"$@"'
Packit Service e31359
  setopt NO_GLOB_SUBST
Packit Service e31359
else
Packit Service e31359
  case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
# NLS nuisances: We save the old values in case they are required later.
Packit Service e31359
_G_user_locale=
Packit Service e31359
_G_safe_locale=
Packit Service e31359
for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
Packit Service e31359
do
Packit Service e31359
  eval "if test set = \"\${$_G_var+set}\"; then
Packit Service e31359
          save_$_G_var=\$$_G_var
Packit Service e31359
          $_G_var=C
Packit Service e31359
	  export $_G_var
Packit Service e31359
	  _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\"
Packit Service e31359
	  _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\"
Packit Service e31359
	fi"
Packit Service e31359
done
Packit Service e31359
Packit Service e31359
# CDPATH.
Packit Service e31359
(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
Packit Service e31359
Packit Service e31359
# Make sure IFS has a sensible default
Packit Service e31359
sp=' '
Packit Service e31359
nl='
Packit Service e31359
'
Packit Service e31359
IFS="$sp	$nl"
Packit Service e31359
Packit Service e31359
# There are apparently some retarded systems that use ';' as a PATH separator!
Packit Service e31359
if test "${PATH_SEPARATOR+set}" != set; then
Packit Service e31359
  PATH_SEPARATOR=:
Packit Service e31359
  (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && {
Packit Service e31359
    (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 ||
Packit Service e31359
      PATH_SEPARATOR=';'
Packit Service e31359
  }
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ------------------------- ##
Packit Service e31359
## Locate command utilities. ##
Packit Service e31359
## ------------------------- ##
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_executable_p FILE
Packit Service e31359
# ----------------------
Packit Service e31359
# Check that FILE is an executable regular file.
Packit Service e31359
func_executable_p ()
Packit Service e31359
{
Packit Service e31359
    test -f "$1" && test -x "$1"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_path_progs PROGS_LIST CHECK_FUNC [PATH]
Packit Service e31359
# --------------------------------------------
Packit Service e31359
# Search for either a program that responds to --version with output
Packit Service e31359
# containing "GNU", or else returned by CHECK_FUNC otherwise, by
Packit Service e31359
# trying all the directories in PATH with each of the elements of
Packit Service e31359
# PROGS_LIST.
Packit Service e31359
#
Packit Service e31359
# CHECK_FUNC should accept the path to a candidate program, and
Packit Service e31359
# set $func_check_prog_result if it truncates its output less than
Packit Service e31359
# $_G_path_prog_max characters.
Packit Service e31359
func_path_progs ()
Packit Service e31359
{
Packit Service e31359
    _G_progs_list=$1
Packit Service e31359
    _G_check_func=$2
Packit Service e31359
    _G_PATH=${3-"$PATH"}
Packit Service e31359
Packit Service e31359
    _G_path_prog_max=0
Packit Service e31359
    _G_path_prog_found=false
Packit Service e31359
    _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:}
Packit Service e31359
    for _G_dir in $_G_PATH; do
Packit Service e31359
      IFS=$_G_save_IFS
Packit Service e31359
      test -z "$_G_dir" && _G_dir=.
Packit Service e31359
      for _G_prog_name in $_G_progs_list; do
Packit Service e31359
        for _exeext in '' .EXE; do
Packit Service e31359
          _G_path_prog=$_G_dir/$_G_prog_name$_exeext
Packit Service e31359
          func_executable_p "$_G_path_prog" || continue
Packit Service e31359
          case `"$_G_path_prog" --version 2>&1` in
Packit Service e31359
            *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;;
Packit Service e31359
            *)     $_G_check_func $_G_path_prog
Packit Service e31359
		   func_path_progs_result=$func_check_prog_result
Packit Service e31359
		   ;;
Packit Service e31359
          esac
Packit Service e31359
          $_G_path_prog_found && break 3
Packit Service e31359
        done
Packit Service e31359
      done
Packit Service e31359
    done
Packit Service e31359
    IFS=$_G_save_IFS
Packit Service e31359
    test -z "$func_path_progs_result" && {
Packit Service e31359
      echo "no acceptable sed could be found in \$PATH" >&2
Packit Service e31359
      exit 1
Packit Service e31359
    }
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# We want to be able to use the functions in this file before configure
Packit Service e31359
# has figured out where the best binaries are kept, which means we have
Packit Service e31359
# to search for them ourselves - except when the results are already set
Packit Service e31359
# where we skip the searches.
Packit Service e31359
Packit Service e31359
# Unless the user overrides by setting SED, search the path for either GNU
Packit Service e31359
# sed, or the sed that truncates its output the least.
Packit Service e31359
test -z "$SED" && {
Packit Service e31359
  _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/
Packit Service e31359
  for _G_i in 1 2 3 4 5 6 7; do
Packit Service e31359
    _G_sed_script=$_G_sed_script$nl$_G_sed_script
Packit Service e31359
  done
Packit Service e31359
  echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed
Packit Service e31359
  _G_sed_script=
Packit Service e31359
Packit Service e31359
  func_check_prog_sed ()
Packit Service e31359
  {
Packit Service e31359
    _G_path_prog=$1
Packit Service e31359
Packit Service e31359
    _G_count=0
Packit Service e31359
    printf 0123456789 >conftest.in
Packit Service e31359
    while :
Packit Service e31359
    do
Packit Service e31359
      cat conftest.in conftest.in >conftest.tmp
Packit Service e31359
      mv conftest.tmp conftest.in
Packit Service e31359
      cp conftest.in conftest.nl
Packit Service e31359
      echo '' >> conftest.nl
Packit Service e31359
      "$_G_path_prog" -f conftest.sed <conftest.nl >conftest.out 2>/dev/null || break
Packit Service e31359
      diff conftest.out conftest.nl >/dev/null 2>&1 || break
Packit Service e31359
      _G_count=`expr $_G_count + 1`
Packit Service e31359
      if test "$_G_count" -gt "$_G_path_prog_max"; then
Packit Service e31359
        # Best one so far, save it but keep looking for a better one
Packit Service e31359
        func_check_prog_result=$_G_path_prog
Packit Service e31359
        _G_path_prog_max=$_G_count
Packit Service e31359
      fi
Packit Service e31359
      # 10*(2^10) chars as input seems more than enough
Packit Service e31359
      test 10 -lt "$_G_count" && break
Packit Service e31359
    done
Packit Service e31359
    rm -f conftest.in conftest.tmp conftest.nl conftest.out
Packit Service e31359
  }
Packit Service e31359
Packit Service e31359
  func_path_progs "sed gsed" func_check_prog_sed $PATH:/usr/xpg4/bin
Packit Service e31359
  rm -f conftest.sed
Packit Service e31359
  SED=$func_path_progs_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# Unless the user overrides by setting GREP, search the path for either GNU
Packit Service e31359
# grep, or the grep that truncates its output the least.
Packit Service e31359
test -z "$GREP" && {
Packit Service e31359
  func_check_prog_grep ()
Packit Service e31359
  {
Packit Service e31359
    _G_path_prog=$1
Packit Service e31359
Packit Service e31359
    _G_count=0
Packit Service e31359
    _G_path_prog_max=0
Packit Service e31359
    printf 0123456789 >conftest.in
Packit Service e31359
    while :
Packit Service e31359
    do
Packit Service e31359
      cat conftest.in conftest.in >conftest.tmp
Packit Service e31359
      mv conftest.tmp conftest.in
Packit Service e31359
      cp conftest.in conftest.nl
Packit Service e31359
      echo 'GREP' >> conftest.nl
Packit Service e31359
      "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' <conftest.nl >conftest.out 2>/dev/null || break
Packit Service e31359
      diff conftest.out conftest.nl >/dev/null 2>&1 || break
Packit Service e31359
      _G_count=`expr $_G_count + 1`
Packit Service e31359
      if test "$_G_count" -gt "$_G_path_prog_max"; then
Packit Service e31359
        # Best one so far, save it but keep looking for a better one
Packit Service e31359
        func_check_prog_result=$_G_path_prog
Packit Service e31359
        _G_path_prog_max=$_G_count
Packit Service e31359
      fi
Packit Service e31359
      # 10*(2^10) chars as input seems more than enough
Packit Service e31359
      test 10 -lt "$_G_count" && break
Packit Service e31359
    done
Packit Service e31359
    rm -f conftest.in conftest.tmp conftest.nl conftest.out
Packit Service e31359
  }
Packit Service e31359
Packit Service e31359
  func_path_progs "grep ggrep" func_check_prog_grep $PATH:/usr/xpg4/bin
Packit Service e31359
  GREP=$func_path_progs_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ------------------------------- ##
Packit Service e31359
## User overridable command paths. ##
Packit Service e31359
## ------------------------------- ##
Packit Service e31359
Packit Service e31359
# All uppercase variable names are used for environment variables.  These
Packit Service e31359
# variables can be overridden by the user before calling a script that
Packit Service e31359
# uses them if a suitable command of that name is not already available
Packit Service e31359
# in the command search PATH.
Packit Service e31359
Packit Service e31359
: ${CP="cp -f"}
Packit Service e31359
: ${ECHO="printf %s\n"}
Packit Service e31359
: ${EGREP="$GREP -E"}
Packit Service e31359
: ${FGREP="$GREP -F"}
Packit Service e31359
: ${LN_S="ln -s"}
Packit Service e31359
: ${MAKE="make"}
Packit Service e31359
: ${MKDIR="mkdir"}
Packit Service e31359
: ${MV="mv -f"}
Packit Service e31359
: ${RM="rm -f"}
Packit Service e31359
: ${SHELL="${CONFIG_SHELL-/bin/sh}"}
Packit Service e31359
Packit Service e31359
Packit Service e31359
## -------------------- ##
Packit Service e31359
## Useful sed snippets. ##
Packit Service e31359
## -------------------- ##
Packit Service e31359
Packit Service e31359
sed_dirname='s|/[^/]*$||'
Packit Service e31359
sed_basename='s|^.*/||'
Packit Service e31359
Packit Service e31359
# Sed substitution that helps us do robust quoting.  It backslashifies
Packit Service e31359
# metacharacters that are still active within double-quoted strings.
Packit Service e31359
sed_quote_subst='s|\([`"$\\]\)|\\\1|g'
Packit Service e31359
Packit Service e31359
# Same as above, but do not quote variable references.
Packit Service e31359
sed_double_quote_subst='s/\(["`\\]\)/\\\1/g'
Packit Service e31359
Packit Service e31359
# Sed substitution that turns a string into a regex matching for the
Packit Service e31359
# string literally.
Packit Service e31359
sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g'
Packit Service e31359
Packit Service e31359
# Sed substitution that converts a w32 file name or path
Packit Service e31359
# that contains forward slashes, into one that contains
Packit Service e31359
# (escaped) backslashes.  A very naive implementation.
Packit Service e31359
sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
Packit Service e31359
Packit Service e31359
# Re-'\' parameter expansions in output of sed_double_quote_subst that
Packit Service e31359
# were '\'-ed in input to the same.  If an odd number of '\' preceded a
Packit Service e31359
# '$' in input to sed_double_quote_subst, that '$' was protected from
Packit Service e31359
# expansion.  Since each input '\' is now two '\'s, look for any number
Packit Service e31359
# of runs of four '\'s followed by two '\'s and then a '$'.  '\' that '$'.
Packit Service e31359
_G_bs='\\'
Packit Service e31359
_G_bs2='\\\\'
Packit Service e31359
_G_bs4='\\\\\\\\'
Packit Service e31359
_G_dollar='\$'
Packit Service e31359
sed_double_backslash="\
Packit Service e31359
  s/$_G_bs4/&\\
Packit Service e31359
/g
Packit Service e31359
  s/^$_G_bs2$_G_dollar/$_G_bs&/
Packit Service e31359
  s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g
Packit Service e31359
  s/\n//g"
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ----------------- ##
Packit Service e31359
## Global variables. ##
Packit Service e31359
## ----------------- ##
Packit Service e31359
Packit Service e31359
# Except for the global variables explicitly listed below, the following
Packit Service e31359
# functions in the '^func_' namespace, and the '^require_' namespace
Packit Service e31359
# variables initialised in the 'Resource management' section, sourcing
Packit Service e31359
# this file will not pollute your global namespace with anything
Packit Service e31359
# else. There's no portable way to scope variables in Bourne shell
Packit Service e31359
# though, so actually running these functions will sometimes place
Packit Service e31359
# results into a variable named after the function, and often use
Packit Service e31359
# temporary variables in the '^_G_' namespace. If you are careful to
Packit Service e31359
# avoid using those namespaces casually in your sourcing script, things
Packit Service e31359
# should continue to work as you expect. And, of course, you can freely
Packit Service e31359
# overwrite any of the functions or variables defined here before
Packit Service e31359
# calling anything to customize them.
Packit Service e31359
Packit Service e31359
EXIT_SUCCESS=0
Packit Service e31359
EXIT_FAILURE=1
Packit Service e31359
EXIT_MISMATCH=63  # $? = 63 is used to indicate version mismatch to missing.
Packit Service e31359
EXIT_SKIP=77	  # $? = 77 is used to indicate a skipped test to automake.
Packit Service e31359
Packit Service e31359
# Allow overriding, eg assuming that you follow the convention of
Packit Service e31359
# putting '$debug_cmd' at the start of all your functions, you can get
Packit Service e31359
# bash to show function call trace with:
Packit Service e31359
#
Packit Service e31359
#    debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
Packit Service e31359
debug_cmd=${debug_cmd-":"}
Packit Service e31359
exit_cmd=:
Packit Service e31359
Packit Service e31359
# By convention, finish your script with:
Packit Service e31359
#
Packit Service e31359
#    exit $exit_status
Packit Service e31359
#
Packit Service e31359
# so that you can set exit_status to non-zero if you want to indicate
Packit Service e31359
# something went wrong during execution without actually bailing out at
Packit Service e31359
# the point of failure.
Packit Service e31359
exit_status=$EXIT_SUCCESS
Packit Service e31359
Packit Service e31359
# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
Packit Service e31359
# is ksh but when the shell is invoked as "sh" and the current value of
Packit Service e31359
# the _XPG environment variable is not equal to 1 (one), the special
Packit Service e31359
# positional parameter $0, within a function call, is the name of the
Packit Service e31359
# function.
Packit Service e31359
progpath=$0
Packit Service e31359
Packit Service e31359
# The name of this program.
Packit Service e31359
progname=`$ECHO "$progpath" |$SED "$sed_basename"`
Packit Service e31359
Packit Service e31359
# Make sure we have an absolute progpath for reexecution:
Packit Service e31359
case $progpath in
Packit Service e31359
  [\\/]*|[A-Za-z]:\\*) ;;
Packit Service e31359
  *[\\/]*)
Packit Service e31359
     progdir=`$ECHO "$progpath" |$SED "$sed_dirname"`
Packit Service e31359
     progdir=`cd "$progdir" && pwd`
Packit Service e31359
     progpath=$progdir/$progname
Packit Service e31359
     ;;
Packit Service e31359
  *)
Packit Service e31359
     _G_IFS=$IFS
Packit Service e31359
     IFS=${PATH_SEPARATOR-:}
Packit Service e31359
     for progdir in $PATH; do
Packit Service e31359
       IFS=$_G_IFS
Packit Service e31359
       test -x "$progdir/$progname" && break
Packit Service e31359
     done
Packit Service e31359
     IFS=$_G_IFS
Packit Service e31359
     test -n "$progdir" || progdir=`pwd`
Packit Service e31359
     progpath=$progdir/$progname
Packit Service e31359
     ;;
Packit Service e31359
esac
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ----------------- ##
Packit Service e31359
## Standard options. ##
Packit Service e31359
## ----------------- ##
Packit Service e31359
Packit Service e31359
# The following options affect the operation of the functions defined
Packit Service e31359
# below, and should be set appropriately depending on run-time para-
Packit Service e31359
# meters passed on the command line.
Packit Service e31359
Packit Service e31359
opt_dry_run=false
Packit Service e31359
opt_quiet=false
Packit Service e31359
opt_verbose=false
Packit Service e31359
Packit Service e31359
# Categories 'all' and 'none' are always available.  Append any others
Packit Service e31359
# you will pass as the first argument to func_warning from your own
Packit Service e31359
# code.
Packit Service e31359
warning_categories=
Packit Service e31359
Packit Service e31359
# By default, display warnings according to 'opt_warning_types'.  Set
Packit Service e31359
# 'warning_func'  to ':' to elide all warnings, or func_fatal_error to
Packit Service e31359
# treat the next displayed warning as a fatal error.
Packit Service e31359
warning_func=func_warn_and_continue
Packit Service e31359
Packit Service e31359
# Set to 'all' to display all warnings, 'none' to suppress all
Packit Service e31359
# warnings, or a space delimited list of some subset of
Packit Service e31359
# 'warning_categories' to display only the listed warnings.
Packit Service e31359
opt_warning_types=all
Packit Service e31359
Packit Service e31359
Packit Service e31359
## -------------------- ##
Packit Service e31359
## Resource management. ##
Packit Service e31359
## -------------------- ##
Packit Service e31359
Packit Service e31359
# This section contains definitions for functions that each ensure a
Packit Service e31359
# particular resource (a file, or a non-empty configuration variable for
Packit Service e31359
# example) is available, and if appropriate to extract default values
Packit Service e31359
# from pertinent package files. Call them using their associated
Packit Service e31359
# 'require_*' variable to ensure that they are executed, at most, once.
Packit Service e31359
#
Packit Service e31359
# It's entirely deliberate that calling these functions can set
Packit Service e31359
# variables that don't obey the namespace limitations obeyed by the rest
Packit Service e31359
# of this file, in order that that they be as useful as possible to
Packit Service e31359
# callers.
Packit Service e31359
Packit Service e31359
Packit Service e31359
# require_term_colors
Packit Service e31359
# -------------------
Packit Service e31359
# Allow display of bold text on terminals that support it.
Packit Service e31359
require_term_colors=func_require_term_colors
Packit Service e31359
func_require_term_colors ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    test -t 1 && {
Packit Service e31359
      # COLORTERM and USE_ANSI_COLORS environment variables take
Packit Service e31359
      # precedence, because most terminfo databases neglect to describe
Packit Service e31359
      # whether color sequences are supported.
Packit Service e31359
      test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"}
Packit Service e31359
Packit Service e31359
      if test 1 = "$USE_ANSI_COLORS"; then
Packit Service e31359
        # Standard ANSI escape sequences
Packit Service e31359
        tc_reset='?[0m'
Packit Service e31359
        tc_bold='?[1m';   tc_standout='?[7m'
Packit Service e31359
        tc_red='?[31m';   tc_green='?[32m'
Packit Service e31359
        tc_blue='?[34m';  tc_cyan='?[36m'
Packit Service e31359
      else
Packit Service e31359
        # Otherwise trust the terminfo database after all.
Packit Service e31359
        test -n "`tput sgr0 2>/dev/null`" && {
Packit Service e31359
          tc_reset=`tput sgr0`
Packit Service e31359
          test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold`
Packit Service e31359
          tc_standout=$tc_bold
Packit Service e31359
          test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso`
Packit Service e31359
          test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1`
Packit Service e31359
          test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2`
Packit Service e31359
          test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4`
Packit Service e31359
          test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5`
Packit Service e31359
        }
Packit Service e31359
      fi
Packit Service e31359
    }
Packit Service e31359
Packit Service e31359
    require_term_colors=:
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ----------------- ##
Packit Service e31359
## Function library. ##
Packit Service e31359
## ----------------- ##
Packit Service e31359
Packit Service e31359
# This section contains a variety of useful functions to call in your
Packit Service e31359
# scripts. Take note of the portable wrappers for features provided by
Packit Service e31359
# some modern shells, which will fall back to slower equivalents on
Packit Service e31359
# less featureful shells.
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_append VAR VALUE
Packit Service e31359
# ---------------------
Packit Service e31359
# Append VALUE onto the existing contents of VAR.
Packit Service e31359
Packit Service e31359
  # We should try to minimise forks, especially on Windows where they are
Packit Service e31359
  # unreasonably slow, so skip the feature probes when bash or zsh are
Packit Service e31359
  # being used:
Packit Service e31359
  if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then
Packit Service e31359
    : ${_G_HAVE_ARITH_OP="yes"}
Packit Service e31359
    : ${_G_HAVE_XSI_OPS="yes"}
Packit Service e31359
    # The += operator was introduced in bash 3.1
Packit Service e31359
    case $BASH_VERSION in
Packit Service e31359
      [12].* | 3.0 | 3.0*) ;;
Packit Service e31359
      *)
Packit Service e31359
        : ${_G_HAVE_PLUSEQ_OP="yes"}
Packit Service e31359
        ;;
Packit Service e31359
    esac
Packit Service e31359
  fi
Packit Service e31359
Packit Service e31359
  # _G_HAVE_PLUSEQ_OP
Packit Service e31359
  # Can be empty, in which case the shell is probed, "yes" if += is
Packit Service e31359
  # useable or anything else if it does not work.
Packit Service e31359
  test -z "$_G_HAVE_PLUSEQ_OP" \
Packit Service e31359
    && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \
Packit Service e31359
    && _G_HAVE_PLUSEQ_OP=yes
Packit Service e31359
Packit Service e31359
if test yes = "$_G_HAVE_PLUSEQ_OP"
Packit Service e31359
then
Packit Service e31359
  # This is an XSI compatible shell, allowing a faster implementation...
Packit Service e31359
  eval 'func_append ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    eval "$1+=\$2"
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  # ...otherwise fall back to using expr, which is often a shell builtin.
Packit Service e31359
  func_append ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    eval "$1=\$$1\$2"
Packit Service e31359
  }
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_append_quoted VAR VALUE
Packit Service e31359
# ----------------------------
Packit Service e31359
# Quote VALUE and append to the end of shell variable VAR, separated
Packit Service e31359
# by a space.
Packit Service e31359
if test yes = "$_G_HAVE_PLUSEQ_OP"; then
Packit Service e31359
  eval 'func_append_quoted ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_quote_for_eval "$2"
Packit Service e31359
    eval "$1+=\\ \$func_quote_for_eval_result"
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  func_append_quoted ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_quote_for_eval "$2"
Packit Service e31359
    eval "$1=\$$1\\ \$func_quote_for_eval_result"
Packit Service e31359
  }
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_append_uniq VAR VALUE
Packit Service e31359
# --------------------------
Packit Service e31359
# Append unique VALUE onto the existing contents of VAR, assuming
Packit Service e31359
# entries are delimited by the first character of VALUE.  For example:
Packit Service e31359
#
Packit Service e31359
#   func_append_uniq options " --another-option option-argument"
Packit Service e31359
#
Packit Service e31359
# will only append to $options if " --another-option option-argument "
Packit Service e31359
# is not already present somewhere in $options already (note spaces at
Packit Service e31359
# each end implied by leading space in second argument).
Packit Service e31359
func_append_uniq ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    eval _G_current_value='`$ECHO $'$1'`'
Packit Service e31359
    _G_delim=`expr "$2" : '\(.\)'`
Packit Service e31359
Packit Service e31359
    case $_G_delim$_G_current_value$_G_delim in
Packit Service e31359
      *"$2$_G_delim"*) ;;
Packit Service e31359
      *) func_append "$@" ;;
Packit Service e31359
    esac
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_arith TERM...
Packit Service e31359
# ------------------
Packit Service e31359
# Set func_arith_result to the result of evaluating TERMs.
Packit Service e31359
  test -z "$_G_HAVE_ARITH_OP" \
Packit Service e31359
    && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \
Packit Service e31359
    && _G_HAVE_ARITH_OP=yes
Packit Service e31359
Packit Service e31359
if test yes = "$_G_HAVE_ARITH_OP"; then
Packit Service e31359
  eval 'func_arith ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_arith_result=$(( $* ))
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  func_arith ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_arith_result=`expr "$@"`
Packit Service e31359
  }
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_basename FILE
Packit Service e31359
# ------------------
Packit Service e31359
# Set func_basename_result to FILE with everything up to and including
Packit Service e31359
# the last / stripped.
Packit Service e31359
if test yes = "$_G_HAVE_XSI_OPS"; then
Packit Service e31359
  # If this shell supports suffix pattern removal, then use it to avoid
Packit Service e31359
  # forking. Hide the definitions single quotes in case the shell chokes
Packit Service e31359
  # on unsupported syntax...
Packit Service e31359
  _b='func_basename_result=${1##*/}'
Packit Service e31359
  _d='case $1 in
Packit Service e31359
        */*) func_dirname_result=${1%/*}$2 ;;
Packit Service e31359
        *  ) func_dirname_result=$3        ;;
Packit Service e31359
      esac'
Packit Service e31359
Packit Service e31359
else
Packit Service e31359
  # ...otherwise fall back to using sed.
Packit Service e31359
  _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`'
Packit Service e31359
  _d='func_dirname_result=`$ECHO "$1"  |$SED "$sed_dirname"`
Packit Service e31359
      if test "X$func_dirname_result" = "X$1"; then
Packit Service e31359
        func_dirname_result=$3
Packit Service e31359
      else
Packit Service e31359
        func_append func_dirname_result "$2"
Packit Service e31359
      fi'
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
eval 'func_basename ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    '"$_b"'
Packit Service e31359
}'
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_dirname FILE APPEND NONDIR_REPLACEMENT
Packit Service e31359
# -------------------------------------------
Packit Service e31359
# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
Packit Service e31359
# otherwise set result to NONDIR_REPLACEMENT.
Packit Service e31359
eval 'func_dirname ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    '"$_d"'
Packit Service e31359
}'
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT
Packit Service e31359
# --------------------------------------------------------
Packit Service e31359
# Perform func_basename and func_dirname in a single function
Packit Service e31359
# call:
Packit Service e31359
#   dirname:  Compute the dirname of FILE.  If nonempty,
Packit Service e31359
#             add APPEND to the result, otherwise set result
Packit Service e31359
#             to NONDIR_REPLACEMENT.
Packit Service e31359
#             value returned in "$func_dirname_result"
Packit Service e31359
#   basename: Compute filename of FILE.
Packit Service e31359
#             value retuned in "$func_basename_result"
Packit Service e31359
# For efficiency, we do not delegate to the functions above but instead
Packit Service e31359
# duplicate the functionality here.
Packit Service e31359
eval 'func_dirname_and_basename ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    '"$_b"'
Packit Service e31359
    '"$_d"'
Packit Service e31359
}'
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_echo ARG...
Packit Service e31359
# ----------------
Packit Service e31359
# Echo program name prefixed message.
Packit Service e31359
func_echo ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    _G_message=$*
Packit Service e31359
Packit Service e31359
    func_echo_IFS=$IFS
Packit Service e31359
    IFS=$nl
Packit Service e31359
    for _G_line in $_G_message; do
Packit Service e31359
      IFS=$func_echo_IFS
Packit Service e31359
      $ECHO "$progname: $_G_line"
Packit Service e31359
    done
Packit Service e31359
    IFS=$func_echo_IFS
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_echo_all ARG...
Packit Service e31359
# --------------------
Packit Service e31359
# Invoke $ECHO with all args, space-separated.
Packit Service e31359
func_echo_all ()
Packit Service e31359
{
Packit Service e31359
    $ECHO "$*"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_echo_infix_1 INFIX ARG...
Packit Service e31359
# ------------------------------
Packit Service e31359
# Echo program name, followed by INFIX on the first line, with any
Packit Service e31359
# additional lines not showing INFIX.
Packit Service e31359
func_echo_infix_1 ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    $require_term_colors
Packit Service e31359
Packit Service e31359
    _G_infix=$1; shift
Packit Service e31359
    _G_indent=$_G_infix
Packit Service e31359
    _G_prefix="$progname: $_G_infix: "
Packit Service e31359
    _G_message=$*
Packit Service e31359
Packit Service e31359
    # Strip color escape sequences before counting printable length
Packit Service e31359
    for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan"
Packit Service e31359
    do
Packit Service e31359
      test -n "$_G_tc" && {
Packit Service e31359
        _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"`
Packit Service e31359
        _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"`
Packit Service e31359
      }
Packit Service e31359
    done
Packit Service e31359
    _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`"  " ## exclude from sc_prohibit_nested_quotes
Packit Service e31359
Packit Service e31359
    func_echo_infix_1_IFS=$IFS
Packit Service e31359
    IFS=$nl
Packit Service e31359
    for _G_line in $_G_message; do
Packit Service e31359
      IFS=$func_echo_infix_1_IFS
Packit Service e31359
      $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2
Packit Service e31359
      _G_prefix=$_G_indent
Packit Service e31359
    done
Packit Service e31359
    IFS=$func_echo_infix_1_IFS
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_error ARG...
Packit Service e31359
# -----------------
Packit Service e31359
# Echo program name prefixed message to standard error.
Packit Service e31359
func_error ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    $require_term_colors
Packit Service e31359
Packit Service e31359
    func_echo_infix_1 "  $tc_standout${tc_red}error$tc_reset" "$*" >&2
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_fatal_error ARG...
Packit Service e31359
# -----------------------
Packit Service e31359
# Echo program name prefixed message to standard error, and exit.
Packit Service e31359
func_fatal_error ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_error "$*"
Packit Service e31359
    exit $EXIT_FAILURE
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_grep EXPRESSION FILENAME
Packit Service e31359
# -----------------------------
Packit Service e31359
# Check whether EXPRESSION matches any line of FILENAME, without output.
Packit Service e31359
func_grep ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    $GREP "$1" "$2" >/dev/null 2>&1
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_len STRING
Packit Service e31359
# ---------------
Packit Service e31359
# Set func_len_result to the length of STRING. STRING may not
Packit Service e31359
# start with a hyphen.
Packit Service e31359
  test -z "$_G_HAVE_XSI_OPS" \
Packit Service e31359
    && (eval 'x=a/b/c;
Packit Service e31359
      test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
Packit Service e31359
    && _G_HAVE_XSI_OPS=yes
Packit Service e31359
Packit Service e31359
if test yes = "$_G_HAVE_XSI_OPS"; then
Packit Service e31359
  eval 'func_len ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_len_result=${#1}
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  func_len ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len`
Packit Service e31359
  }
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_mkdir_p DIRECTORY-PATH
Packit Service e31359
# ---------------------------
Packit Service e31359
# Make sure the entire path to DIRECTORY-PATH is available.
Packit Service e31359
func_mkdir_p ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    _G_directory_path=$1
Packit Service e31359
    _G_dir_list=
Packit Service e31359
Packit Service e31359
    if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then
Packit Service e31359
Packit Service e31359
      # Protect directory names starting with '-'
Packit Service e31359
      case $_G_directory_path in
Packit Service e31359
        -*) _G_directory_path=./$_G_directory_path ;;
Packit Service e31359
      esac
Packit Service e31359
Packit Service e31359
      # While some portion of DIR does not yet exist...
Packit Service e31359
      while test ! -d "$_G_directory_path"; do
Packit Service e31359
        # ...make a list in topmost first order.  Use a colon delimited
Packit Service e31359
	# list incase some portion of path contains whitespace.
Packit Service e31359
        _G_dir_list=$_G_directory_path:$_G_dir_list
Packit Service e31359
Packit Service e31359
        # If the last portion added has no slash in it, the list is done
Packit Service e31359
        case $_G_directory_path in */*) ;; *) break ;; esac
Packit Service e31359
Packit Service e31359
        # ...otherwise throw away the child directory and loop
Packit Service e31359
        _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"`
Packit Service e31359
      done
Packit Service e31359
      _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'`
Packit Service e31359
Packit Service e31359
      func_mkdir_p_IFS=$IFS; IFS=:
Packit Service e31359
      for _G_dir in $_G_dir_list; do
Packit Service e31359
	IFS=$func_mkdir_p_IFS
Packit Service e31359
        # mkdir can fail with a 'File exist' error if two processes
Packit Service e31359
        # try to create one of the directories concurrently.  Don't
Packit Service e31359
        # stop in that case!
Packit Service e31359
        $MKDIR "$_G_dir" 2>/dev/null || :
Packit Service e31359
      done
Packit Service e31359
      IFS=$func_mkdir_p_IFS
Packit Service e31359
Packit Service e31359
      # Bail out if we (or some other process) failed to create a directory.
Packit Service e31359
      test -d "$_G_directory_path" || \
Packit Service e31359
        func_fatal_error "Failed to create '$1'"
Packit Service e31359
    fi
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_mktempdir [BASENAME]
Packit Service e31359
# -------------------------
Packit Service e31359
# Make a temporary directory that won't clash with other running
Packit Service e31359
# libtool processes, and avoids race conditions if possible.  If
Packit Service e31359
# given, BASENAME is the basename for that directory.
Packit Service e31359
func_mktempdir ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    _G_template=${TMPDIR-/tmp}/${1-$progname}
Packit Service e31359
Packit Service e31359
    if test : = "$opt_dry_run"; then
Packit Service e31359
      # Return a directory name, but don't create it in dry-run mode
Packit Service e31359
      _G_tmpdir=$_G_template-$$
Packit Service e31359
    else
Packit Service e31359
Packit Service e31359
      # If mktemp works, use that first and foremost
Packit Service e31359
      _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null`
Packit Service e31359
Packit Service e31359
      if test ! -d "$_G_tmpdir"; then
Packit Service e31359
        # Failing that, at least try and use $RANDOM to avoid a race
Packit Service e31359
        _G_tmpdir=$_G_template-${RANDOM-0}$$
Packit Service e31359
Packit Service e31359
        func_mktempdir_umask=`umask`
Packit Service e31359
        umask 0077
Packit Service e31359
        $MKDIR "$_G_tmpdir"
Packit Service e31359
        umask $func_mktempdir_umask
Packit Service e31359
      fi
Packit Service e31359
Packit Service e31359
      # If we're not in dry-run mode, bomb out on failure
Packit Service e31359
      test -d "$_G_tmpdir" || \
Packit Service e31359
        func_fatal_error "cannot create temporary directory '$_G_tmpdir'"
Packit Service e31359
    fi
Packit Service e31359
Packit Service e31359
    $ECHO "$_G_tmpdir"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_normal_abspath PATH
Packit Service e31359
# ------------------------
Packit Service e31359
# Remove doubled-up and trailing slashes, "." path components,
Packit Service e31359
# and cancel out any ".." path components in PATH after making
Packit Service e31359
# it an absolute path.
Packit Service e31359
func_normal_abspath ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    # These SED scripts presuppose an absolute path with a trailing slash.
Packit Service e31359
    _G_pathcar='s|^/\([^/]*\).*$|\1|'
Packit Service e31359
    _G_pathcdr='s|^/[^/]*||'
Packit Service e31359
    _G_removedotparts=':dotsl
Packit Service e31359
		s|/\./|/|g
Packit Service e31359
		t dotsl
Packit Service e31359
		s|/\.$|/|'
Packit Service e31359
    _G_collapseslashes='s|/\{1,\}|/|g'
Packit Service e31359
    _G_finalslash='s|/*$|/|'
Packit Service e31359
Packit Service e31359
    # Start from root dir and reassemble the path.
Packit Service e31359
    func_normal_abspath_result=
Packit Service e31359
    func_normal_abspath_tpath=$1
Packit Service e31359
    func_normal_abspath_altnamespace=
Packit Service e31359
    case $func_normal_abspath_tpath in
Packit Service e31359
      "")
Packit Service e31359
        # Empty path, that just means $cwd.
Packit Service e31359
        func_stripname '' '/' "`pwd`"
Packit Service e31359
        func_normal_abspath_result=$func_stripname_result
Packit Service e31359
        return
Packit Service e31359
        ;;
Packit Service e31359
      # The next three entries are used to spot a run of precisely
Packit Service e31359
      # two leading slashes without using negated character classes;
Packit Service e31359
      # we take advantage of case's first-match behaviour.
Packit Service e31359
      ///*)
Packit Service e31359
        # Unusual form of absolute path, do nothing.
Packit Service e31359
        ;;
Packit Service e31359
      //*)
Packit Service e31359
        # Not necessarily an ordinary path; POSIX reserves leading '//'
Packit Service e31359
        # and for example Cygwin uses it to access remote file shares
Packit Service e31359
        # over CIFS/SMB, so we conserve a leading double slash if found.
Packit Service e31359
        func_normal_abspath_altnamespace=/
Packit Service e31359
        ;;
Packit Service e31359
      /*)
Packit Service e31359
        # Absolute path, do nothing.
Packit Service e31359
        ;;
Packit Service e31359
      *)
Packit Service e31359
        # Relative path, prepend $cwd.
Packit Service e31359
        func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath
Packit Service e31359
        ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    # Cancel out all the simple stuff to save iterations.  We also want
Packit Service e31359
    # the path to end with a slash for ease of parsing, so make sure
Packit Service e31359
    # there is one (and only one) here.
Packit Service e31359
    func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
Packit Service e31359
          -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"`
Packit Service e31359
    while :; do
Packit Service e31359
      # Processed it all yet?
Packit Service e31359
      if test / = "$func_normal_abspath_tpath"; then
Packit Service e31359
        # If we ascended to the root using ".." the result may be empty now.
Packit Service e31359
        if test -z "$func_normal_abspath_result"; then
Packit Service e31359
          func_normal_abspath_result=/
Packit Service e31359
        fi
Packit Service e31359
        break
Packit Service e31359
      fi
Packit Service e31359
      func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \
Packit Service e31359
          -e "$_G_pathcar"`
Packit Service e31359
      func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
Packit Service e31359
          -e "$_G_pathcdr"`
Packit Service e31359
      # Figure out what to do with it
Packit Service e31359
      case $func_normal_abspath_tcomponent in
Packit Service e31359
        "")
Packit Service e31359
          # Trailing empty path component, ignore it.
Packit Service e31359
          ;;
Packit Service e31359
        ..)
Packit Service e31359
          # Parent dir; strip last assembled component from result.
Packit Service e31359
          func_dirname "$func_normal_abspath_result"
Packit Service e31359
          func_normal_abspath_result=$func_dirname_result
Packit Service e31359
          ;;
Packit Service e31359
        *)
Packit Service e31359
          # Actual path component, append it.
Packit Service e31359
          func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent"
Packit Service e31359
          ;;
Packit Service e31359
      esac
Packit Service e31359
    done
Packit Service e31359
    # Restore leading double-slash if one was found on entry.
Packit Service e31359
    func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_notquiet ARG...
Packit Service e31359
# --------------------
Packit Service e31359
# Echo program name prefixed message only when not in quiet mode.
Packit Service e31359
func_notquiet ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    $opt_quiet || func_echo ${1+"$@"}
Packit Service e31359
Packit Service e31359
    # A bug in bash halts the script if the last line of a function
Packit Service e31359
    # fails when set -e is in force, so we need another command to
Packit Service e31359
    # work around that:
Packit Service e31359
    :
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_relative_path SRCDIR DSTDIR
Packit Service e31359
# --------------------------------
Packit Service e31359
# Set func_relative_path_result to the relative path from SRCDIR to DSTDIR.
Packit Service e31359
func_relative_path ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_relative_path_result=
Packit Service e31359
    func_normal_abspath "$1"
Packit Service e31359
    func_relative_path_tlibdir=$func_normal_abspath_result
Packit Service e31359
    func_normal_abspath "$2"
Packit Service e31359
    func_relative_path_tbindir=$func_normal_abspath_result
Packit Service e31359
Packit Service e31359
    # Ascend the tree starting from libdir
Packit Service e31359
    while :; do
Packit Service e31359
      # check if we have found a prefix of bindir
Packit Service e31359
      case $func_relative_path_tbindir in
Packit Service e31359
        $func_relative_path_tlibdir)
Packit Service e31359
          # found an exact match
Packit Service e31359
          func_relative_path_tcancelled=
Packit Service e31359
          break
Packit Service e31359
          ;;
Packit Service e31359
        $func_relative_path_tlibdir*)
Packit Service e31359
          # found a matching prefix
Packit Service e31359
          func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir"
Packit Service e31359
          func_relative_path_tcancelled=$func_stripname_result
Packit Service e31359
          if test -z "$func_relative_path_result"; then
Packit Service e31359
            func_relative_path_result=.
Packit Service e31359
          fi
Packit Service e31359
          break
Packit Service e31359
          ;;
Packit Service e31359
        *)
Packit Service e31359
          func_dirname $func_relative_path_tlibdir
Packit Service e31359
          func_relative_path_tlibdir=$func_dirname_result
Packit Service e31359
          if test -z "$func_relative_path_tlibdir"; then
Packit Service e31359
            # Have to descend all the way to the root!
Packit Service e31359
            func_relative_path_result=../$func_relative_path_result
Packit Service e31359
            func_relative_path_tcancelled=$func_relative_path_tbindir
Packit Service e31359
            break
Packit Service e31359
          fi
Packit Service e31359
          func_relative_path_result=../$func_relative_path_result
Packit Service e31359
          ;;
Packit Service e31359
      esac
Packit Service e31359
    done
Packit Service e31359
Packit Service e31359
    # Now calculate path; take care to avoid doubling-up slashes.
Packit Service e31359
    func_stripname '' '/' "$func_relative_path_result"
Packit Service e31359
    func_relative_path_result=$func_stripname_result
Packit Service e31359
    func_stripname '/' '/' "$func_relative_path_tcancelled"
Packit Service e31359
    if test -n "$func_stripname_result"; then
Packit Service e31359
      func_append func_relative_path_result "/$func_stripname_result"
Packit Service e31359
    fi
Packit Service e31359
Packit Service e31359
    # Normalisation. If bindir is libdir, return '.' else relative path.
Packit Service e31359
    if test -n "$func_relative_path_result"; then
Packit Service e31359
      func_stripname './' '' "$func_relative_path_result"
Packit Service e31359
      func_relative_path_result=$func_stripname_result
Packit Service e31359
    fi
Packit Service e31359
Packit Service e31359
    test -n "$func_relative_path_result" || func_relative_path_result=.
Packit Service e31359
Packit Service e31359
    :
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_quote_for_eval ARG...
Packit Service e31359
# --------------------------
Packit Service e31359
# Aesthetically quote ARGs to be evaled later.
Packit Service e31359
# This function returns two values:
Packit Service e31359
#   i) func_quote_for_eval_result
Packit Service e31359
#      double-quoted, suitable for a subsequent eval
Packit Service e31359
#  ii) func_quote_for_eval_unquoted_result
Packit Service e31359
#      has all characters that are still active within double
Packit Service e31359
#      quotes backslashified.
Packit Service e31359
func_quote_for_eval ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_quote_for_eval_unquoted_result=
Packit Service e31359
    func_quote_for_eval_result=
Packit Service e31359
    while test 0 -lt $#; do
Packit Service e31359
      case $1 in
Packit Service e31359
        *[\\\`\"\$]*)
Packit Service e31359
	  _G_unquoted_arg=`printf '%s\n' "$1" |$SED "$sed_quote_subst"` ;;
Packit Service e31359
        *)
Packit Service e31359
          _G_unquoted_arg=$1 ;;
Packit Service e31359
      esac
Packit Service e31359
      if test -n "$func_quote_for_eval_unquoted_result"; then
Packit Service e31359
	func_append func_quote_for_eval_unquoted_result " $_G_unquoted_arg"
Packit Service e31359
      else
Packit Service e31359
        func_append func_quote_for_eval_unquoted_result "$_G_unquoted_arg"
Packit Service e31359
      fi
Packit Service e31359
Packit Service e31359
      case $_G_unquoted_arg in
Packit Service e31359
        # Double-quote args containing shell metacharacters to delay
Packit Service e31359
        # word splitting, command substitution and variable expansion
Packit Service e31359
        # for a subsequent eval.
Packit Service e31359
        # Many Bourne shells cannot handle close brackets correctly
Packit Service e31359
        # in scan sets, so we specify it separately.
Packit Service e31359
        *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \	]*|*]*|"")
Packit Service e31359
          _G_quoted_arg=\"$_G_unquoted_arg\"
Packit Service e31359
          ;;
Packit Service e31359
        *)
Packit Service e31359
          _G_quoted_arg=$_G_unquoted_arg
Packit Service e31359
	  ;;
Packit Service e31359
      esac
Packit Service e31359
Packit Service e31359
      if test -n "$func_quote_for_eval_result"; then
Packit Service e31359
	func_append func_quote_for_eval_result " $_G_quoted_arg"
Packit Service e31359
      else
Packit Service e31359
        func_append func_quote_for_eval_result "$_G_quoted_arg"
Packit Service e31359
      fi
Packit Service e31359
      shift
Packit Service e31359
    done
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_quote_for_expand ARG
Packit Service e31359
# -------------------------
Packit Service e31359
# Aesthetically quote ARG to be evaled later; same as above,
Packit Service e31359
# but do not quote variable references.
Packit Service e31359
func_quote_for_expand ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    case $1 in
Packit Service e31359
      *[\\\`\"]*)
Packit Service e31359
	_G_arg=`$ECHO "$1" | $SED \
Packit Service e31359
	    -e "$sed_double_quote_subst" -e "$sed_double_backslash"` ;;
Packit Service e31359
      *)
Packit Service e31359
        _G_arg=$1 ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    case $_G_arg in
Packit Service e31359
      # Double-quote args containing shell metacharacters to delay
Packit Service e31359
      # word splitting and command substitution for a subsequent eval.
Packit Service e31359
      # Many Bourne shells cannot handle close brackets correctly
Packit Service e31359
      # in scan sets, so we specify it separately.
Packit Service e31359
      *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \	]*|*]*|"")
Packit Service e31359
        _G_arg=\"$_G_arg\"
Packit Service e31359
        ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    func_quote_for_expand_result=$_G_arg
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_stripname PREFIX SUFFIX NAME
Packit Service e31359
# ---------------------------------
Packit Service e31359
# strip PREFIX and SUFFIX from NAME, and store in func_stripname_result.
Packit Service e31359
# PREFIX and SUFFIX must not contain globbing or regex special
Packit Service e31359
# characters, hashes, percent signs, but SUFFIX may contain a leading
Packit Service e31359
# dot (in which case that matches only a dot).
Packit Service e31359
if test yes = "$_G_HAVE_XSI_OPS"; then
Packit Service e31359
  eval 'func_stripname ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
Packit Service e31359
    # positional parameters, so assign one to ordinary variable first.
Packit Service e31359
    func_stripname_result=$3
Packit Service e31359
    func_stripname_result=${func_stripname_result#"$1"}
Packit Service e31359
    func_stripname_result=${func_stripname_result%"$2"}
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  func_stripname ()
Packit Service e31359
  {
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    case $2 in
Packit Service e31359
      .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;;
Packit Service e31359
      *)  func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;;
Packit Service e31359
    esac
Packit Service e31359
  }
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_show_eval CMD [FAIL_EXP]
Packit Service e31359
# -----------------------------
Packit Service e31359
# Unless opt_quiet is true, then output CMD.  Then, if opt_dryrun is
Packit Service e31359
# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
Packit Service e31359
# is given, then evaluate it.
Packit Service e31359
func_show_eval ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    _G_cmd=$1
Packit Service e31359
    _G_fail_exp=${2-':'}
Packit Service e31359
Packit Service e31359
    func_quote_for_expand "$_G_cmd"
Packit Service e31359
    eval "func_notquiet $func_quote_for_expand_result"
Packit Service e31359
Packit Service e31359
    $opt_dry_run || {
Packit Service e31359
      eval "$_G_cmd"
Packit Service e31359
      _G_status=$?
Packit Service e31359
      if test 0 -ne "$_G_status"; then
Packit Service e31359
	eval "(exit $_G_status); $_G_fail_exp"
Packit Service e31359
      fi
Packit Service e31359
    }
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_show_eval_locale CMD [FAIL_EXP]
Packit Service e31359
# ------------------------------------
Packit Service e31359
# Unless opt_quiet is true, then output CMD.  Then, if opt_dryrun is
Packit Service e31359
# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
Packit Service e31359
# is given, then evaluate it.  Use the saved locale for evaluation.
Packit Service e31359
func_show_eval_locale ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    _G_cmd=$1
Packit Service e31359
    _G_fail_exp=${2-':'}
Packit Service e31359
Packit Service e31359
    $opt_quiet || {
Packit Service e31359
      func_quote_for_expand "$_G_cmd"
Packit Service e31359
      eval "func_echo $func_quote_for_expand_result"
Packit Service e31359
    }
Packit Service e31359
Packit Service e31359
    $opt_dry_run || {
Packit Service e31359
      eval "$_G_user_locale
Packit Service e31359
	    $_G_cmd"
Packit Service e31359
      _G_status=$?
Packit Service e31359
      eval "$_G_safe_locale"
Packit Service e31359
      if test 0 -ne "$_G_status"; then
Packit Service e31359
	eval "(exit $_G_status); $_G_fail_exp"
Packit Service e31359
      fi
Packit Service e31359
    }
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_tr_sh
Packit Service e31359
# ----------
Packit Service e31359
# Turn $1 into a string suitable for a shell variable name.
Packit Service e31359
# Result is stored in $func_tr_sh_result.  All characters
Packit Service e31359
# not in the set a-zA-Z0-9_ are replaced with '_'. Further,
Packit Service e31359
# if $1 begins with a digit, a '_' is prepended as well.
Packit Service e31359
func_tr_sh ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    case $1 in
Packit Service e31359
    [0-9]* | *[!a-zA-Z0-9_]*)
Packit Service e31359
      func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'`
Packit Service e31359
      ;;
Packit Service e31359
    * )
Packit Service e31359
      func_tr_sh_result=$1
Packit Service e31359
      ;;
Packit Service e31359
    esac
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_verbose ARG...
Packit Service e31359
# -------------------
Packit Service e31359
# Echo program name prefixed message in verbose mode only.
Packit Service e31359
func_verbose ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    $opt_verbose && func_echo "$*"
Packit Service e31359
Packit Service e31359
    :
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_warn_and_continue ARG...
Packit Service e31359
# -----------------------------
Packit Service e31359
# Echo program name prefixed warning message to standard error.
Packit Service e31359
func_warn_and_continue ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    $require_term_colors
Packit Service e31359
Packit Service e31359
    func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_warning CATEGORY ARG...
Packit Service e31359
# ----------------------------
Packit Service e31359
# Echo program name prefixed warning message to standard error. Warning
Packit Service e31359
# messages can be filtered according to CATEGORY, where this function
Packit Service e31359
# elides messages where CATEGORY is not listed in the global variable
Packit Service e31359
# 'opt_warning_types'.
Packit Service e31359
func_warning ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    # CATEGORY must be in the warning_categories list!
Packit Service e31359
    case " $warning_categories " in
Packit Service e31359
      *" $1 "*) ;;
Packit Service e31359
      *) func_internal_error "invalid warning category '$1'" ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    _G_category=$1
Packit Service e31359
    shift
Packit Service e31359
Packit Service e31359
    case " $opt_warning_types " in
Packit Service e31359
      *" $_G_category "*) $warning_func ${1+"$@"} ;;
Packit Service e31359
    esac
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_sort_ver VER1 VER2
Packit Service e31359
# -----------------------
Packit Service e31359
# 'sort -V' is not generally available.
Packit Service e31359
# Note this deviates from the version comparison in automake
Packit Service e31359
# in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
Packit Service e31359
# but this should suffice as we won't be specifying old
Packit Service e31359
# version formats or redundant trailing .0 in bootstrap.conf.
Packit Service e31359
# If we did want full compatibility then we should probably
Packit Service e31359
# use m4_version_compare from autoconf.
Packit Service e31359
func_sort_ver ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    printf '%s\n%s\n' "$1" "$2" \
Packit Service e31359
      | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_lt_ver PREV CURR
Packit Service e31359
# ---------------------
Packit Service e31359
# Return true if PREV and CURR are in the correct order according to
Packit Service e31359
# func_sort_ver, otherwise false.  Use it like this:
Packit Service e31359
#
Packit Service e31359
#  func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..."
Packit Service e31359
func_lt_ver ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q`
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# Local variables:
Packit Service e31359
# mode: shell-script
Packit Service e31359
# sh-indentation: 2
Packit Service e31359
# eval: (add-hook 'before-save-hook 'time-stamp)
Packit Service e31359
# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
Packit Service e31359
# time-stamp-time-zone: "UTC"
Packit Service e31359
# End:
Packit Service e31359
#! /bin/sh
Packit Service e31359
Packit Service e31359
# Set a version string for this script.
Packit Service e31359
scriptversion=2014-01-07.03; # UTC
Packit Service e31359
Packit Service e31359
# A portable, pluggable option parser for Bourne shell.
Packit Service e31359
# Written by Gary V. Vaughan, 2010
Packit Service e31359
Packit Service e31359
# Copyright (C) 2010-2015 Free Software Foundation, Inc.
Packit Service e31359
# This is free software; see the source for copying conditions.  There is NO
Packit Service e31359
# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Packit Service e31359
Packit Service e31359
# This program is free software: you can redistribute it and/or modify
Packit Service e31359
# it under the terms of the GNU General Public License as published by
Packit Service e31359
# the Free Software Foundation, either version 3 of the License, or
Packit Service e31359
# (at your option) any later version.
Packit Service e31359
Packit Service e31359
# This program is distributed in the hope that it will be useful,
Packit Service e31359
# but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service e31359
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service e31359
# GNU General Public License for more details.
Packit Service e31359
Packit Service e31359
# You should have received a copy of the GNU General Public License
Packit Service e31359
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
Packit Service e31359
Packit Service e31359
# Please report bugs or propose patches to gary@gnu.org.
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ------ ##
Packit Service e31359
## Usage. ##
Packit Service e31359
## ------ ##
Packit Service e31359
Packit Service e31359
# This file is a library for parsing options in your shell scripts along
Packit Service e31359
# with assorted other useful supporting features that you can make use
Packit Service e31359
# of too.
Packit Service e31359
#
Packit Service e31359
# For the simplest scripts you might need only:
Packit Service e31359
#
Packit Service e31359
#   #!/bin/sh
Packit Service e31359
#   . relative/path/to/funclib.sh
Packit Service e31359
#   . relative/path/to/options-parser
Packit Service e31359
#   scriptversion=1.0
Packit Service e31359
#   func_options ${1+"$@"}
Packit Service e31359
#   eval set dummy "$func_options_result"; shift
Packit Service e31359
#   ...rest of your script...
Packit Service e31359
#
Packit Service e31359
# In order for the '--version' option to work, you will need to have a
Packit Service e31359
# suitably formatted comment like the one at the top of this file
Packit Service e31359
# starting with '# Written by ' and ending with '# warranty; '.
Packit Service e31359
#
Packit Service e31359
# For '-h' and '--help' to work, you will also need a one line
Packit Service e31359
# description of your script's purpose in a comment directly above the
Packit Service e31359
# '# Written by ' line, like the one at the top of this file.
Packit Service e31359
#
Packit Service e31359
# The default options also support '--debug', which will turn on shell
Packit Service e31359
# execution tracing (see the comment above debug_cmd below for another
Packit Service e31359
# use), and '--verbose' and the func_verbose function to allow your script
Packit Service e31359
# to display verbose messages only when your user has specified
Packit Service e31359
# '--verbose'.
Packit Service e31359
#
Packit Service e31359
# After sourcing this file, you can plug processing for additional
Packit Service e31359
# options by amending the variables from the 'Configuration' section
Packit Service e31359
# below, and following the instructions in the 'Option parsing'
Packit Service e31359
# section further down.
Packit Service e31359
Packit Service e31359
## -------------- ##
Packit Service e31359
## Configuration. ##
Packit Service e31359
## -------------- ##
Packit Service e31359
Packit Service e31359
# You should override these variables in your script after sourcing this
Packit Service e31359
# file so that they reflect the customisations you have added to the
Packit Service e31359
# option parser.
Packit Service e31359
Packit Service e31359
# The usage line for option parsing errors and the start of '-h' and
Packit Service e31359
# '--help' output messages. You can embed shell variables for delayed
Packit Service e31359
# expansion at the time the message is displayed, but you will need to
Packit Service e31359
# quote other shell meta-characters carefully to prevent them being
Packit Service e31359
# expanded when the contents are evaled.
Packit Service e31359
usage='$progpath [OPTION]...'
Packit Service e31359
Packit Service e31359
# Short help message in response to '-h' and '--help'.  Add to this or
Packit Service e31359
# override it after sourcing this library to reflect the full set of
Packit Service e31359
# options your script accepts.
Packit Service e31359
usage_message="\
Packit Service e31359
       --debug        enable verbose shell tracing
Packit Service e31359
   -W, --warnings=CATEGORY
Packit Service e31359
                      report the warnings falling in CATEGORY [all]
Packit Service e31359
   -v, --verbose      verbosely report processing
Packit Service e31359
       --version      print version information and exit
Packit Service e31359
   -h, --help         print short or long help message and exit
Packit Service e31359
"
Packit Service e31359
Packit Service e31359
# Additional text appended to 'usage_message' in response to '--help'.
Packit Service e31359
long_help_message="
Packit Service e31359
Warning categories include:
Packit Service e31359
       'all'          show all warnings
Packit Service e31359
       'none'         turn off all the warnings
Packit Service e31359
       'error'        warnings are treated as fatal errors"
Packit Service e31359
Packit Service e31359
# Help message printed before fatal option parsing errors.
Packit Service e31359
fatal_help="Try '\$progname --help' for more information."
Packit Service e31359
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ------------------------- ##
Packit Service e31359
## Hook function management. ##
Packit Service e31359
## ------------------------- ##
Packit Service e31359
Packit Service e31359
# This section contains functions for adding, removing, and running hooks
Packit Service e31359
# to the main code.  A hook is just a named list of of function, that can
Packit Service e31359
# be run in order later on.
Packit Service e31359
Packit Service e31359
# func_hookable FUNC_NAME
Packit Service e31359
# -----------------------
Packit Service e31359
# Declare that FUNC_NAME will run hooks added with
Packit Service e31359
# 'func_add_hook FUNC_NAME ...'.
Packit Service e31359
func_hookable ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_append hookable_fns " $1"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_add_hook FUNC_NAME HOOK_FUNC
Packit Service e31359
# ---------------------------------
Packit Service e31359
# Request that FUNC_NAME call HOOK_FUNC before it returns.  FUNC_NAME must
Packit Service e31359
# first have been declared "hookable" by a call to 'func_hookable'.
Packit Service e31359
func_add_hook ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    case " $hookable_fns " in
Packit Service e31359
      *" $1 "*) ;;
Packit Service e31359
      *) func_fatal_error "'$1' does not accept hook functions." ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    eval func_append ${1}_hooks '" $2"'
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_remove_hook FUNC_NAME HOOK_FUNC
Packit Service e31359
# ------------------------------------
Packit Service e31359
# Remove HOOK_FUNC from the list of functions called by FUNC_NAME.
Packit Service e31359
func_remove_hook ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`'
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_run_hooks FUNC_NAME [ARG]...
Packit Service e31359
# ---------------------------------
Packit Service e31359
# Run all hook functions registered to FUNC_NAME.
Packit Service e31359
# It is assumed that the list of hook functions contains nothing more
Packit Service e31359
# than a whitespace-delimited list of legal shell function names, and
Packit Service e31359
# no effort is wasted trying to catch shell meta-characters or preserve
Packit Service e31359
# whitespace.
Packit Service e31359
func_run_hooks ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    case " $hookable_fns " in
Packit Service e31359
      *" $1 "*) ;;
Packit Service e31359
      *) func_fatal_error "'$1' does not support hook funcions.n" ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    eval _G_hook_fns=\$$1_hooks; shift
Packit Service e31359
Packit Service e31359
    for _G_hook in $_G_hook_fns; do
Packit Service e31359
      eval $_G_hook '"$@"'
Packit Service e31359
Packit Service e31359
      # store returned options list back into positional
Packit Service e31359
      # parameters for next 'cmd' execution.
Packit Service e31359
      eval _G_hook_result=\$${_G_hook}_result
Packit Service e31359
      eval set dummy "$_G_hook_result"; shift
Packit Service e31359
    done
Packit Service e31359
Packit Service e31359
    func_quote_for_eval ${1+"$@"}
Packit Service e31359
    func_run_hooks_result=$func_quote_for_eval_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
Packit Service e31359
## --------------- ##
Packit Service e31359
## Option parsing. ##
Packit Service e31359
## --------------- ##
Packit Service e31359
Packit Service e31359
# In order to add your own option parsing hooks, you must accept the
Packit Service e31359
# full positional parameter list in your hook function, remove any
Packit Service e31359
# options that you action, and then pass back the remaining unprocessed
Packit Service e31359
# options in '<hooked_function_name>_result', escaped suitably for
Packit Service e31359
# 'eval'.  Like this:
Packit Service e31359
#
Packit Service e31359
#    my_options_prep ()
Packit Service e31359
#    {
Packit Service e31359
#        $debug_cmd
Packit Service e31359
#
Packit Service e31359
#        # Extend the existing usage message.
Packit Service e31359
#        usage_message=$usage_message'
Packit Service e31359
#      -s, --silent       don'\''t print informational messages
Packit Service e31359
#    '
Packit Service e31359
#
Packit Service e31359
#        func_quote_for_eval ${1+"$@"}
Packit Service e31359
#        my_options_prep_result=$func_quote_for_eval_result
Packit Service e31359
#    }
Packit Service e31359
#    func_add_hook func_options_prep my_options_prep
Packit Service e31359
#
Packit Service e31359
#
Packit Service e31359
#    my_silent_option ()
Packit Service e31359
#    {
Packit Service e31359
#        $debug_cmd
Packit Service e31359
#
Packit Service e31359
#        # Note that for efficiency, we parse as many options as we can
Packit Service e31359
#        # recognise in a loop before passing the remainder back to the
Packit Service e31359
#        # caller on the first unrecognised argument we encounter.
Packit Service e31359
#        while test $# -gt 0; do
Packit Service e31359
#          opt=$1; shift
Packit Service e31359
#          case $opt in
Packit Service e31359
#            --silent|-s) opt_silent=: ;;
Packit Service e31359
#            # Separate non-argument short options:
Packit Service e31359
#            -s*)         func_split_short_opt "$_G_opt"
Packit Service e31359
#                         set dummy "$func_split_short_opt_name" \
Packit Service e31359
#                             "-$func_split_short_opt_arg" ${1+"$@"}
Packit Service e31359
#                         shift
Packit Service e31359
#                         ;;
Packit Service e31359
#            *)            set dummy "$_G_opt" "$*"; shift; break ;;
Packit Service e31359
#          esac
Packit Service e31359
#        done
Packit Service e31359
#
Packit Service e31359
#        func_quote_for_eval ${1+"$@"}
Packit Service e31359
#        my_silent_option_result=$func_quote_for_eval_result
Packit Service e31359
#    }
Packit Service e31359
#    func_add_hook func_parse_options my_silent_option
Packit Service e31359
#
Packit Service e31359
#
Packit Service e31359
#    my_option_validation ()
Packit Service e31359
#    {
Packit Service e31359
#        $debug_cmd
Packit Service e31359
#
Packit Service e31359
#        $opt_silent && $opt_verbose && func_fatal_help "\
Packit Service e31359
#    '--silent' and '--verbose' options are mutually exclusive."
Packit Service e31359
#
Packit Service e31359
#        func_quote_for_eval ${1+"$@"}
Packit Service e31359
#        my_option_validation_result=$func_quote_for_eval_result
Packit Service e31359
#    }
Packit Service e31359
#    func_add_hook func_validate_options my_option_validation
Packit Service e31359
#
Packit Service e31359
# You'll alse need to manually amend $usage_message to reflect the extra
Packit Service e31359
# options you parse.  It's preferable to append if you can, so that
Packit Service e31359
# multiple option parsing hooks can be added safely.
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_options [ARG]...
Packit Service e31359
# ---------------------
Packit Service e31359
# All the functions called inside func_options are hookable. See the
Packit Service e31359
# individual implementations for details.
Packit Service e31359
func_hookable func_options
Packit Service e31359
func_options ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_options_prep ${1+"$@"}
Packit Service e31359
    eval func_parse_options \
Packit Service e31359
        ${func_options_prep_result+"$func_options_prep_result"}
Packit Service e31359
    eval func_validate_options \
Packit Service e31359
        ${func_parse_options_result+"$func_parse_options_result"}
Packit Service e31359
Packit Service e31359
    eval func_run_hooks func_options \
Packit Service e31359
        ${func_validate_options_result+"$func_validate_options_result"}
Packit Service e31359
Packit Service e31359
    # save modified positional parameters for caller
Packit Service e31359
    func_options_result=$func_run_hooks_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_options_prep [ARG]...
Packit Service e31359
# --------------------------
Packit Service e31359
# All initialisations required before starting the option parse loop.
Packit Service e31359
# Note that when calling hook functions, we pass through the list of
Packit Service e31359
# positional parameters.  If a hook function modifies that list, and
Packit Service e31359
# needs to propogate that back to rest of this script, then the complete
Packit Service e31359
# modified list must be put in 'func_run_hooks_result' before
Packit Service e31359
# returning.
Packit Service e31359
func_hookable func_options_prep
Packit Service e31359
func_options_prep ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    # Option defaults:
Packit Service e31359
    opt_verbose=false
Packit Service e31359
    opt_warning_types=
Packit Service e31359
Packit Service e31359
    func_run_hooks func_options_prep ${1+"$@"}
Packit Service e31359
Packit Service e31359
    # save modified positional parameters for caller
Packit Service e31359
    func_options_prep_result=$func_run_hooks_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_parse_options [ARG]...
Packit Service e31359
# ---------------------------
Packit Service e31359
# The main option parsing loop.
Packit Service e31359
func_hookable func_parse_options
Packit Service e31359
func_parse_options ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_parse_options_result=
Packit Service e31359
Packit Service e31359
    # this just eases exit handling
Packit Service e31359
    while test $# -gt 0; do
Packit Service e31359
      # Defer to hook functions for initial option parsing, so they
Packit Service e31359
      # get priority in the event of reusing an option name.
Packit Service e31359
      func_run_hooks func_parse_options ${1+"$@"}
Packit Service e31359
Packit Service e31359
      # Adjust func_parse_options positional parameters to match
Packit Service e31359
      eval set dummy "$func_run_hooks_result"; shift
Packit Service e31359
Packit Service e31359
      # Break out of the loop if we already parsed every option.
Packit Service e31359
      test $# -gt 0 || break
Packit Service e31359
Packit Service e31359
      _G_opt=$1
Packit Service e31359
      shift
Packit Service e31359
      case $_G_opt in
Packit Service e31359
        --debug|-x)   debug_cmd='set -x'
Packit Service e31359
                      func_echo "enabling shell trace mode"
Packit Service e31359
                      $debug_cmd
Packit Service e31359
                      ;;
Packit Service e31359
Packit Service e31359
        --no-warnings|--no-warning|--no-warn)
Packit Service e31359
                      set dummy --warnings none ${1+"$@"}
Packit Service e31359
                      shift
Packit Service e31359
		      ;;
Packit Service e31359
Packit Service e31359
        --warnings|--warning|-W)
Packit Service e31359
                      test $# = 0 && func_missing_arg $_G_opt && break
Packit Service e31359
                      case " $warning_categories $1" in
Packit Service e31359
                        *" $1 "*)
Packit Service e31359
                          # trailing space prevents matching last $1 above
Packit Service e31359
                          func_append_uniq opt_warning_types " $1"
Packit Service e31359
                          ;;
Packit Service e31359
                        *all)
Packit Service e31359
                          opt_warning_types=$warning_categories
Packit Service e31359
                          ;;
Packit Service e31359
                        *none)
Packit Service e31359
                          opt_warning_types=none
Packit Service e31359
                          warning_func=:
Packit Service e31359
                          ;;
Packit Service e31359
                        *error)
Packit Service e31359
                          opt_warning_types=$warning_categories
Packit Service e31359
                          warning_func=func_fatal_error
Packit Service e31359
                          ;;
Packit Service e31359
                        *)
Packit Service e31359
                          func_fatal_error \
Packit Service e31359
                             "unsupported warning category: '$1'"
Packit Service e31359
                          ;;
Packit Service e31359
                      esac
Packit Service e31359
                      shift
Packit Service e31359
                      ;;
Packit Service e31359
Packit Service e31359
        --verbose|-v) opt_verbose=: ;;
Packit Service e31359
        --version)    func_version ;;
Packit Service e31359
        -\?|-h)       func_usage ;;
Packit Service e31359
        --help)       func_help ;;
Packit Service e31359
Packit Service e31359
	# Separate optargs to long options (plugins may need this):
Packit Service e31359
	--*=*)        func_split_equals "$_G_opt"
Packit Service e31359
	              set dummy "$func_split_equals_lhs" \
Packit Service e31359
                          "$func_split_equals_rhs" ${1+"$@"}
Packit Service e31359
                      shift
Packit Service e31359
                      ;;
Packit Service e31359
Packit Service e31359
       # Separate optargs to short options:
Packit Service e31359
        -W*)
Packit Service e31359
                      func_split_short_opt "$_G_opt"
Packit Service e31359
                      set dummy "$func_split_short_opt_name" \
Packit Service e31359
                          "$func_split_short_opt_arg" ${1+"$@"}
Packit Service e31359
                      shift
Packit Service e31359
                      ;;
Packit Service e31359
Packit Service e31359
        # Separate non-argument short options:
Packit Service e31359
        -\?*|-h*|-v*|-x*)
Packit Service e31359
                      func_split_short_opt "$_G_opt"
Packit Service e31359
                      set dummy "$func_split_short_opt_name" \
Packit Service e31359
                          "-$func_split_short_opt_arg" ${1+"$@"}
Packit Service e31359
                      shift
Packit Service e31359
                      ;;
Packit Service e31359
Packit Service e31359
        --)           break ;;
Packit Service e31359
        -*)           func_fatal_help "unrecognised option: '$_G_opt'" ;;
Packit Service e31359
        *)            set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
Packit Service e31359
      esac
Packit Service e31359
    done
Packit Service e31359
Packit Service e31359
    # save modified positional parameters for caller
Packit Service e31359
    func_quote_for_eval ${1+"$@"}
Packit Service e31359
    func_parse_options_result=$func_quote_for_eval_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_validate_options [ARG]...
Packit Service e31359
# ------------------------------
Packit Service e31359
# Perform any sanity checks on option settings and/or unconsumed
Packit Service e31359
# arguments.
Packit Service e31359
func_hookable func_validate_options
Packit Service e31359
func_validate_options ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    # Display all warnings if -W was not given.
Packit Service e31359
    test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
Packit Service e31359
Packit Service e31359
    func_run_hooks func_validate_options ${1+"$@"}
Packit Service e31359
Packit Service e31359
    # Bail if the options were screwed!
Packit Service e31359
    $exit_cmd $EXIT_FAILURE
Packit Service e31359
Packit Service e31359
    # save modified positional parameters for caller
Packit Service e31359
    func_validate_options_result=$func_run_hooks_result
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ----------------- ##
Packit Service e31359
## Helper functions. ##
Packit Service e31359
## ----------------- ##
Packit Service e31359
Packit Service e31359
# This section contains the helper functions used by the rest of the
Packit Service e31359
# hookable option parser framework in ascii-betical order.
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_fatal_help ARG...
Packit Service e31359
# ----------------------
Packit Service e31359
# Echo program name prefixed message to standard error, followed by
Packit Service e31359
# a help hint, and exit.
Packit Service e31359
func_fatal_help ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    eval \$ECHO \""Usage: $usage"\"
Packit Service e31359
    eval \$ECHO \""$fatal_help"\"
Packit Service e31359
    func_error ${1+"$@"}
Packit Service e31359
    exit $EXIT_FAILURE
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_help
Packit Service e31359
# ---------
Packit Service e31359
# Echo long help message to standard output and exit.
Packit Service e31359
func_help ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_usage_message
Packit Service e31359
    $ECHO "$long_help_message"
Packit Service e31359
    exit 0
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_missing_arg ARGNAME
Packit Service e31359
# ------------------------
Packit Service e31359
# Echo program name prefixed message to standard error and set global
Packit Service e31359
# exit_cmd.
Packit Service e31359
func_missing_arg ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_error "Missing argument for '$1'."
Packit Service e31359
    exit_cmd=exit
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_split_equals STRING
Packit Service e31359
# ------------------------
Packit Service e31359
# Set func_split_equals_lhs and func_split_equals_rhs shell variables after
Packit Service e31359
# splitting STRING at the '=' sign.
Packit Service e31359
test -z "$_G_HAVE_XSI_OPS" \
Packit Service e31359
    && (eval 'x=a/b/c;
Packit Service e31359
      test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
Packit Service e31359
    && _G_HAVE_XSI_OPS=yes
Packit Service e31359
Packit Service e31359
if test yes = "$_G_HAVE_XSI_OPS"
Packit Service e31359
then
Packit Service e31359
  # This is an XSI compatible shell, allowing a faster implementation...
Packit Service e31359
  eval 'func_split_equals ()
Packit Service e31359
  {
Packit Service e31359
      $debug_cmd
Packit Service e31359
Packit Service e31359
      func_split_equals_lhs=${1%%=*}
Packit Service e31359
      func_split_equals_rhs=${1#*=}
Packit Service e31359
      test "x$func_split_equals_lhs" = "x$1" \
Packit Service e31359
        && func_split_equals_rhs=
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  # ...otherwise fall back to using expr, which is often a shell builtin.
Packit Service e31359
  func_split_equals ()
Packit Service e31359
  {
Packit Service e31359
      $debug_cmd
Packit Service e31359
Packit Service e31359
      func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'`
Packit Service e31359
      func_split_equals_rhs=
Packit Service e31359
      test "x$func_split_equals_lhs" = "x$1" \
Packit Service e31359
        || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'`
Packit Service e31359
  }
Packit Service e31359
fi #func_split_equals
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_split_short_opt SHORTOPT
Packit Service e31359
# -----------------------------
Packit Service e31359
# Set func_split_short_opt_name and func_split_short_opt_arg shell
Packit Service e31359
# variables after splitting SHORTOPT after the 2nd character.
Packit Service e31359
if test yes = "$_G_HAVE_XSI_OPS"
Packit Service e31359
then
Packit Service e31359
  # This is an XSI compatible shell, allowing a faster implementation...
Packit Service e31359
  eval 'func_split_short_opt ()
Packit Service e31359
  {
Packit Service e31359
      $debug_cmd
Packit Service e31359
Packit Service e31359
      func_split_short_opt_arg=${1#??}
Packit Service e31359
      func_split_short_opt_name=${1%"$func_split_short_opt_arg"}
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  # ...otherwise fall back to using expr, which is often a shell builtin.
Packit Service e31359
  func_split_short_opt ()
Packit Service e31359
  {
Packit Service e31359
      $debug_cmd
Packit Service e31359
Packit Service e31359
      func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'`
Packit Service e31359
      func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'`
Packit Service e31359
  }
Packit Service e31359
fi #func_split_short_opt
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_usage
Packit Service e31359
# ----------
Packit Service e31359
# Echo short help message to standard output and exit.
Packit Service e31359
func_usage ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_usage_message
Packit Service e31359
    $ECHO "Run '$progname --help |${PAGER-more}' for full usage"
Packit Service e31359
    exit 0
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_usage_message
Packit Service e31359
# ------------------
Packit Service e31359
# Echo short help message to standard output.
Packit Service e31359
func_usage_message ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    eval \$ECHO \""Usage: $usage"\"
Packit Service e31359
    echo
Packit Service e31359
    $SED -n 's|^# ||
Packit Service e31359
        /^Written by/{
Packit Service e31359
          x;p;x
Packit Service e31359
        }
Packit Service e31359
	h
Packit Service e31359
	/^Written by/q' < "$progpath"
Packit Service e31359
    echo
Packit Service e31359
    eval \$ECHO \""$usage_message"\"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_version
Packit Service e31359
# ------------
Packit Service e31359
# Echo version message to standard output and exit.
Packit Service e31359
func_version ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    printf '%s\n' "$progname $scriptversion"
Packit Service e31359
    $SED -n '
Packit Service e31359
        /(C)/!b go
Packit Service e31359
        :more
Packit Service e31359
        /\./!{
Packit Service e31359
          N
Packit Service e31359
          s|\n# | |
Packit Service e31359
          b more
Packit Service e31359
        }
Packit Service e31359
        :go
Packit Service e31359
        /^# Written by /,/# warranty; / {
Packit Service e31359
          s|^# ||
Packit Service e31359
          s|^# *$||
Packit Service e31359
          s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2|
Packit Service e31359
          p
Packit Service e31359
        }
Packit Service e31359
        /^# Written by / {
Packit Service e31359
          s|^# ||
Packit Service e31359
          p
Packit Service e31359
        }
Packit Service e31359
        /^warranty; /q' < "$progpath"
Packit Service e31359
Packit Service e31359
    exit $?
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# Local variables:
Packit Service e31359
# mode: shell-script
Packit Service e31359
# sh-indentation: 2
Packit Service e31359
# eval: (add-hook 'before-save-hook 'time-stamp)
Packit Service e31359
# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
Packit Service e31359
# time-stamp-time-zone: "UTC"
Packit Service e31359
# End:
Packit Service e31359
Packit Service e31359
# Set a version string.
Packit Service e31359
scriptversion='(GNU libtool) 2.4.6'
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_echo ARG...
Packit Service e31359
# ----------------
Packit Service e31359
# Libtool also displays the current mode in messages, so override
Packit Service e31359
# funclib.sh func_echo with this custom definition.
Packit Service e31359
func_echo ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    _G_message=$*
Packit Service e31359
Packit Service e31359
    func_echo_IFS=$IFS
Packit Service e31359
    IFS=$nl
Packit Service e31359
    for _G_line in $_G_message; do
Packit Service e31359
      IFS=$func_echo_IFS
Packit Service e31359
      $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line"
Packit Service e31359
    done
Packit Service e31359
    IFS=$func_echo_IFS
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_warning ARG...
Packit Service e31359
# -------------------
Packit Service e31359
# Libtool warnings are not categorized, so override funclib.sh
Packit Service e31359
# func_warning with this simpler definition.
Packit Service e31359
func_warning ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    $warning_func ${1+"$@"}
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ---------------- ##
Packit Service e31359
## Options parsing. ##
Packit Service e31359
## ---------------- ##
Packit Service e31359
Packit Service e31359
# Hook in the functions to make sure our own options are parsed during
Packit Service e31359
# the option parsing loop.
Packit Service e31359
Packit Service e31359
usage='$progpath [OPTION]... [MODE-ARG]...'
Packit Service e31359
Packit Service e31359
# Short help message in response to '-h'.
Packit Service e31359
usage_message="Options:
Packit Service e31359
       --config             show all configuration variables
Packit Service e31359
       --debug              enable verbose shell tracing
Packit Service e31359
   -n, --dry-run            display commands without modifying any files
Packit Service e31359
       --features           display basic configuration information and exit
Packit Service e31359
       --mode=MODE          use operation mode MODE
Packit Service e31359
       --no-warnings        equivalent to '-Wnone'
Packit Service e31359
       --preserve-dup-deps  don't remove duplicate dependency libraries
Packit Service e31359
       --quiet, --silent    don't print informational messages
Packit Service e31359
       --tag=TAG            use configuration variables from tag TAG
Packit Service e31359
   -v, --verbose            print more informational messages than default
Packit Service e31359
       --version            print version information
Packit Service e31359
   -W, --warnings=CATEGORY  report the warnings falling in CATEGORY [all]
Packit Service e31359
   -h, --help, --help-all   print short, long, or detailed help message
Packit Service e31359
"
Packit Service e31359
Packit Service e31359
# Additional text appended to 'usage_message' in response to '--help'.
Packit Service e31359
func_help ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    func_usage_message
Packit Service e31359
    $ECHO "$long_help_message
Packit Service e31359
Packit Service e31359
MODE must be one of the following:
Packit Service e31359
Packit Service e31359
       clean           remove files from the build directory
Packit Service e31359
       compile         compile a source file into a libtool object
Packit Service e31359
       execute         automatically set library path, then run a program
Packit Service e31359
       finish          complete the installation of libtool libraries
Packit Service e31359
       install         install libraries or executables
Packit Service e31359
       link            create a library or an executable
Packit Service e31359
       uninstall       remove libraries from an installed directory
Packit Service e31359
Packit Service e31359
MODE-ARGS vary depending on the MODE.  When passed as first option,
Packit Service e31359
'--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that.
Packit Service e31359
Try '$progname --help --mode=MODE' for a more detailed description of MODE.
Packit Service e31359
Packit Service e31359
When reporting a bug, please describe a test case to reproduce it and
Packit Service e31359
include the following information:
Packit Service e31359
Packit Service e31359
       host-triplet:   $host
Packit Service e31359
       shell:          $SHELL
Packit Service e31359
       compiler:       $LTCC
Packit Service e31359
       compiler flags: $LTCFLAGS
Packit Service e31359
       linker:         $LD (gnu? $with_gnu_ld)
Packit Service e31359
       version:        $progname (GNU libtool) 2.4.6
Packit Service e31359
       automake:       `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
Packit Service e31359
       autoconf:       `($AUTOCONF --version) 2>/dev/null |$SED 1q`
Packit Service e31359
Packit Service e31359
Report bugs to <bug-libtool@gnu.org>.
Packit Service e31359
GNU libtool home page: <http://www.gnu.org/software/libtool/>.
Packit Service e31359
General help using GNU software: <http://www.gnu.org/gethelp/>."
Packit Service e31359
    exit 0
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_lo2o OBJECT-NAME
Packit Service e31359
# ---------------------
Packit Service e31359
# Transform OBJECT-NAME from a '.lo' suffix to the platform specific
Packit Service e31359
# object suffix.
Packit Service e31359
Packit Service e31359
lo2o=s/\\.lo\$/.$objext/
Packit Service e31359
o2lo=s/\\.$objext\$/.lo/
Packit Service e31359
Packit Service e31359
if test yes = "$_G_HAVE_XSI_OPS"; then
Packit Service e31359
  eval 'func_lo2o ()
Packit Service e31359
  {
Packit Service e31359
    case $1 in
Packit Service e31359
      *.lo) func_lo2o_result=${1%.lo}.$objext ;;
Packit Service e31359
      *   ) func_lo2o_result=$1               ;;
Packit Service e31359
    esac
Packit Service e31359
  }'
Packit Service e31359
Packit Service e31359
  # func_xform LIBOBJ-OR-SOURCE
Packit Service e31359
  # ---------------------------
Packit Service e31359
  # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise)
Packit Service e31359
  # suffix to a '.lo' libtool-object suffix.
Packit Service e31359
  eval 'func_xform ()
Packit Service e31359
  {
Packit Service e31359
    func_xform_result=${1%.*}.lo
Packit Service e31359
  }'
Packit Service e31359
else
Packit Service e31359
  # ...otherwise fall back to using sed.
Packit Service e31359
  func_lo2o ()
Packit Service e31359
  {
Packit Service e31359
    func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"`
Packit Service e31359
  }
Packit Service e31359
Packit Service e31359
  func_xform ()
Packit Service e31359
  {
Packit Service e31359
    func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'`
Packit Service e31359
  }
Packit Service e31359
fi
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_fatal_configuration ARG...
Packit Service e31359
# -------------------------------
Packit Service e31359
# Echo program name prefixed message to standard error, followed by
Packit Service e31359
# a configuration failure hint, and exit.
Packit Service e31359
func_fatal_configuration ()
Packit Service e31359
{
Packit Service e31359
    func__fatal_error ${1+"$@"} \
Packit Service e31359
      "See the $PACKAGE documentation for more information." \
Packit Service e31359
      "Fatal configuration error."
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_config
Packit Service e31359
# -----------
Packit Service e31359
# Display the configuration for all the tags in this script.
Packit Service e31359
func_config ()
Packit Service e31359
{
Packit Service e31359
    re_begincf='^# ### BEGIN LIBTOOL'
Packit Service e31359
    re_endcf='^# ### END LIBTOOL'
Packit Service e31359
Packit Service e31359
    # Default configuration.
Packit Service e31359
    $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath"
Packit Service e31359
Packit Service e31359
    # Now print the configurations for the tags.
Packit Service e31359
    for tagname in $taglist; do
Packit Service e31359
      $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath"
Packit Service e31359
    done
Packit Service e31359
Packit Service e31359
    exit $?
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_features
Packit Service e31359
# -------------
Packit Service e31359
# Display the features supported by this script.
Packit Service e31359
func_features ()
Packit Service e31359
{
Packit Service e31359
    echo "host: $host"
Packit Service e31359
    if test yes = "$build_libtool_libs"; then
Packit Service e31359
      echo "enable shared libraries"
Packit Service e31359
    else
Packit Service e31359
      echo "disable shared libraries"
Packit Service e31359
    fi
Packit Service e31359
    if test yes = "$build_old_libs"; then
Packit Service e31359
      echo "enable static libraries"
Packit Service e31359
    else
Packit Service e31359
      echo "disable static libraries"
Packit Service e31359
    fi
Packit Service e31359
Packit Service e31359
    exit $?
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_enable_tag TAGNAME
Packit Service e31359
# -----------------------
Packit Service e31359
# Verify that TAGNAME is valid, and either flag an error and exit, or
Packit Service e31359
# enable the TAGNAME tag.  We also add TAGNAME to the global $taglist
Packit Service e31359
# variable here.
Packit Service e31359
func_enable_tag ()
Packit Service e31359
{
Packit Service e31359
    # Global variable:
Packit Service e31359
    tagname=$1
Packit Service e31359
Packit Service e31359
    re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
Packit Service e31359
    re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
Packit Service e31359
    sed_extractcf=/$re_begincf/,/$re_endcf/p
Packit Service e31359
Packit Service e31359
    # Validate tagname.
Packit Service e31359
    case $tagname in
Packit Service e31359
      *[!-_A-Za-z0-9,/]*)
Packit Service e31359
        func_fatal_error "invalid tag name: $tagname"
Packit Service e31359
        ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    # Don't test for the "default" C tag, as we know it's
Packit Service e31359
    # there but not specially marked.
Packit Service e31359
    case $tagname in
Packit Service e31359
        CC) ;;
Packit Service e31359
    *)
Packit Service e31359
        if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
Packit Service e31359
	  taglist="$taglist $tagname"
Packit Service e31359
Packit Service e31359
	  # Evaluate the configuration.  Be careful to quote the path
Packit Service e31359
	  # and the sed script, to avoid splitting on whitespace, but
Packit Service e31359
	  # also don't use non-portable quotes within backquotes within
Packit Service e31359
	  # quotes we have to do it in 2 steps:
Packit Service e31359
	  extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
Packit Service e31359
	  eval "$extractedcf"
Packit Service e31359
        else
Packit Service e31359
	  func_error "ignoring unknown tag $tagname"
Packit Service e31359
        fi
Packit Service e31359
        ;;
Packit Service e31359
    esac
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_check_version_match
Packit Service e31359
# ------------------------
Packit Service e31359
# Ensure that we are using m4 macros, and libtool script from the same
Packit Service e31359
# release of libtool.
Packit Service e31359
func_check_version_match ()
Packit Service e31359
{
Packit Service e31359
    if test "$package_revision" != "$macro_revision"; then
Packit Service e31359
      if test "$VERSION" != "$macro_version"; then
Packit Service e31359
        if test -z "$macro_version"; then
Packit Service e31359
          cat >&2 <<_LT_EOF
Packit Service e31359
$progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
Packit Service e31359
$progname: definition of this LT_INIT comes from an older release.
Packit Service e31359
$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
Packit Service e31359
$progname: and run autoconf again.
Packit Service e31359
_LT_EOF
Packit Service e31359
        else
Packit Service e31359
          cat >&2 <<_LT_EOF
Packit Service e31359
$progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
Packit Service e31359
$progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
Packit Service e31359
$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
Packit Service e31359
$progname: and run autoconf again.
Packit Service e31359
_LT_EOF
Packit Service e31359
        fi
Packit Service e31359
      else
Packit Service e31359
        cat >&2 <<_LT_EOF
Packit Service e31359
$progname: Version mismatch error.  This is $PACKAGE $VERSION, revision $package_revision,
Packit Service e31359
$progname: but the definition of this LT_INIT comes from revision $macro_revision.
Packit Service e31359
$progname: You should recreate aclocal.m4 with macros from revision $package_revision
Packit Service e31359
$progname: of $PACKAGE $VERSION and run autoconf again.
Packit Service e31359
_LT_EOF
Packit Service e31359
      fi
Packit Service e31359
Packit Service e31359
      exit $EXIT_MISMATCH
Packit Service e31359
    fi
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# libtool_options_prep [ARG]...
Packit Service e31359
# -----------------------------
Packit Service e31359
# Preparation for options parsed by libtool.
Packit Service e31359
libtool_options_prep ()
Packit Service e31359
{
Packit Service e31359
    $debug_mode
Packit Service e31359
Packit Service e31359
    # Option defaults:
Packit Service e31359
    opt_config=false
Packit Service e31359
    opt_dlopen=
Packit Service e31359
    opt_dry_run=false
Packit Service e31359
    opt_help=false
Packit Service e31359
    opt_mode=
Packit Service e31359
    opt_preserve_dup_deps=false
Packit Service e31359
    opt_quiet=false
Packit Service e31359
Packit Service e31359
    nonopt=
Packit Service e31359
    preserve_args=
Packit Service e31359
Packit Service e31359
    # Shorthand for --mode=foo, only valid as the first argument
Packit Service e31359
    case $1 in
Packit Service e31359
    clean|clea|cle|cl)
Packit Service e31359
      shift; set dummy --mode clean ${1+"$@"}; shift
Packit Service e31359
      ;;
Packit Service e31359
    compile|compil|compi|comp|com|co|c)
Packit Service e31359
      shift; set dummy --mode compile ${1+"$@"}; shift
Packit Service e31359
      ;;
Packit Service e31359
    execute|execut|execu|exec|exe|ex|e)
Packit Service e31359
      shift; set dummy --mode execute ${1+"$@"}; shift
Packit Service e31359
      ;;
Packit Service e31359
    finish|finis|fini|fin|fi|f)
Packit Service e31359
      shift; set dummy --mode finish ${1+"$@"}; shift
Packit Service e31359
      ;;
Packit Service e31359
    install|instal|insta|inst|ins|in|i)
Packit Service e31359
      shift; set dummy --mode install ${1+"$@"}; shift
Packit Service e31359
      ;;
Packit Service e31359
    link|lin|li|l)
Packit Service e31359
      shift; set dummy --mode link ${1+"$@"}; shift
Packit Service e31359
      ;;
Packit Service e31359
    uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
Packit Service e31359
      shift; set dummy --mode uninstall ${1+"$@"}; shift
Packit Service e31359
      ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    # Pass back the list of options.
Packit Service e31359
    func_quote_for_eval ${1+"$@"}
Packit Service e31359
    libtool_options_prep_result=$func_quote_for_eval_result
Packit Service e31359
}
Packit Service e31359
func_add_hook func_options_prep libtool_options_prep
Packit Service e31359
Packit Service e31359
Packit Service e31359
# libtool_parse_options [ARG]...
Packit Service e31359
# ---------------------------------
Packit Service e31359
# Provide handling for libtool specific options.
Packit Service e31359
libtool_parse_options ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    # Perform our own loop to consume as many options as possible in
Packit Service e31359
    # each iteration.
Packit Service e31359
    while test $# -gt 0; do
Packit Service e31359
      _G_opt=$1
Packit Service e31359
      shift
Packit Service e31359
      case $_G_opt in
Packit Service e31359
        --dry-run|--dryrun|-n)
Packit Service e31359
                        opt_dry_run=:
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --config)       func_config ;;
Packit Service e31359
Packit Service e31359
        --dlopen|-dlopen)
Packit Service e31359
                        opt_dlopen="${opt_dlopen+$opt_dlopen
Packit Service e31359
}$1"
Packit Service e31359
                        shift
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --preserve-dup-deps)
Packit Service e31359
                        opt_preserve_dup_deps=: ;;
Packit Service e31359
Packit Service e31359
        --features)     func_features ;;
Packit Service e31359
Packit Service e31359
        --finish)       set dummy --mode finish ${1+"$@"}; shift ;;
Packit Service e31359
Packit Service e31359
        --help)         opt_help=: ;;
Packit Service e31359
Packit Service e31359
        --help-all)     opt_help=': help-all' ;;
Packit Service e31359
Packit Service e31359
        --mode)         test $# = 0 && func_missing_arg $_G_opt && break
Packit Service e31359
                        opt_mode=$1
Packit Service e31359
                        case $1 in
Packit Service e31359
                          # Valid mode arguments:
Packit Service e31359
                          clean|compile|execute|finish|install|link|relink|uninstall) ;;
Packit Service e31359
Packit Service e31359
                          # Catch anything else as an error
Packit Service e31359
                          *) func_error "invalid argument for $_G_opt"
Packit Service e31359
                             exit_cmd=exit
Packit Service e31359
                             break
Packit Service e31359
                             ;;
Packit Service e31359
                        esac
Packit Service e31359
                        shift
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --no-silent|--no-quiet)
Packit Service e31359
                        opt_quiet=false
Packit Service e31359
                        func_append preserve_args " $_G_opt"
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --no-warnings|--no-warning|--no-warn)
Packit Service e31359
                        opt_warning=false
Packit Service e31359
                        func_append preserve_args " $_G_opt"
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --no-verbose)
Packit Service e31359
                        opt_verbose=false
Packit Service e31359
                        func_append preserve_args " $_G_opt"
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --silent|--quiet)
Packit Service e31359
                        opt_quiet=:
Packit Service e31359
                        opt_verbose=false
Packit Service e31359
                        func_append preserve_args " $_G_opt"
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --tag)          test $# = 0 && func_missing_arg $_G_opt && break
Packit Service e31359
                        opt_tag=$1
Packit Service e31359
                        func_append preserve_args " $_G_opt $1"
Packit Service e31359
                        func_enable_tag "$1"
Packit Service e31359
                        shift
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
        --verbose|-v)   opt_quiet=false
Packit Service e31359
                        opt_verbose=:
Packit Service e31359
                        func_append preserve_args " $_G_opt"
Packit Service e31359
                        ;;
Packit Service e31359
Packit Service e31359
	# An option not handled by this hook function:
Packit Service e31359
        *)		set dummy "$_G_opt" ${1+"$@"};	shift; break  ;;
Packit Service e31359
      esac
Packit Service e31359
    done
Packit Service e31359
Packit Service e31359
Packit Service e31359
    # save modified positional parameters for caller
Packit Service e31359
    func_quote_for_eval ${1+"$@"}
Packit Service e31359
    libtool_parse_options_result=$func_quote_for_eval_result
Packit Service e31359
}
Packit Service e31359
func_add_hook func_parse_options libtool_parse_options
Packit Service e31359
Packit Service e31359
Packit Service e31359
Packit Service e31359
# libtool_validate_options [ARG]...
Packit Service e31359
# ---------------------------------
Packit Service e31359
# Perform any sanity checks on option settings and/or unconsumed
Packit Service e31359
# arguments.
Packit Service e31359
libtool_validate_options ()
Packit Service e31359
{
Packit Service e31359
    # save first non-option argument
Packit Service e31359
    if test 0 -lt $#; then
Packit Service e31359
      nonopt=$1
Packit Service e31359
      shift
Packit Service e31359
    fi
Packit Service e31359
Packit Service e31359
    # preserve --debug
Packit Service e31359
    test : = "$debug_cmd" || func_append preserve_args " --debug"
Packit Service e31359
Packit Service e31359
    case $host in
Packit Service e31359
      # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452
Packit Service e31359
      # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788
Packit Service e31359
      *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*)
Packit Service e31359
        # don't eliminate duplications in $postdeps and $predeps
Packit Service e31359
        opt_duplicate_compiler_generated_deps=:
Packit Service e31359
        ;;
Packit Service e31359
      *)
Packit Service e31359
        opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
Packit Service e31359
        ;;
Packit Service e31359
    esac
Packit Service e31359
Packit Service e31359
    $opt_help || {
Packit Service e31359
      # Sanity checks first:
Packit Service e31359
      func_check_version_match
Packit Service e31359
Packit Service e31359
      test yes != "$build_libtool_libs" \
Packit Service e31359
        && test yes != "$build_old_libs" \
Packit Service e31359
        && func_fatal_configuration "not configured to build any kind of library"
Packit Service e31359
Packit Service e31359
      # Darwin sucks
Packit Service e31359
      eval std_shrext=\"$shrext_cmds\"
Packit Service e31359
Packit Service e31359
      # Only execute mode is allowed to have -dlopen flags.
Packit Service e31359
      if test -n "$opt_dlopen" && test execute != "$opt_mode"; then
Packit Service e31359
        func_error "unrecognized option '-dlopen'"
Packit Service e31359
        $ECHO "$help" 1>&2
Packit Service e31359
        exit $EXIT_FAILURE
Packit Service e31359
      fi
Packit Service e31359
Packit Service e31359
      # Change the help message to a mode-specific one.
Packit Service e31359
      generic_help=$help
Packit Service e31359
      help="Try '$progname --help --mode=$opt_mode' for more information."
Packit Service e31359
    }
Packit Service e31359
Packit Service e31359
    # Pass back the unparsed argument list
Packit Service e31359
    func_quote_for_eval ${1+"$@"}
Packit Service e31359
    libtool_validate_options_result=$func_quote_for_eval_result
Packit Service e31359
}
Packit Service e31359
func_add_hook func_validate_options libtool_validate_options
Packit Service e31359
Packit Service e31359
Packit Service e31359
# Process options as early as possible so that --help and --version
Packit Service e31359
# can return quickly.
Packit Service e31359
func_options ${1+"$@"}
Packit Service e31359
eval set dummy "$func_options_result"; shift
Packit Service e31359
Packit Service e31359
Packit Service e31359
Packit Service e31359
## ----------- ##
Packit Service e31359
##    Main.    ##
Packit Service e31359
## ----------- ##
Packit Service e31359
Packit Service e31359
magic='%%%MAGIC variable%%%'
Packit Service e31359
magic_exe='%%%MAGIC EXE variable%%%'
Packit Service e31359
Packit Service e31359
# Global variables.
Packit Service e31359
extracted_archives=
Packit Service e31359
extracted_serial=0
Packit Service e31359
Packit Service e31359
# If this variable is set in any of the actions, the command in it
Packit Service e31359
# will be execed at the end.  This prevents here-documents from being
Packit Service e31359
# left over by shells.
Packit Service e31359
exec_cmd=
Packit Service e31359
Packit Service e31359
Packit Service e31359
# A function that is used when there is no print builtin or printf.
Packit Service e31359
func_fallback_echo ()
Packit Service e31359
{
Packit Service e31359
  eval 'cat <<_LTECHO_EOF
Packit Service e31359
$1
Packit Service e31359
_LTECHO_EOF'
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_generated_by_libtool
Packit Service e31359
# True iff stdin has been generated by Libtool. This function is only
Packit Service e31359
# a basic sanity check; it will hardly flush out determined imposters.
Packit Service e31359
func_generated_by_libtool_p ()
Packit Service e31359
{
Packit Service e31359
  $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_lalib_p file
Packit Service e31359
# True iff FILE is a libtool '.la' library or '.lo' object file.
Packit Service e31359
# This function is only a basic sanity check; it will hardly flush out
Packit Service e31359
# determined imposters.
Packit Service e31359
func_lalib_p ()
Packit Service e31359
{
Packit Service e31359
    test -f "$1" &&
Packit Service e31359
      $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_lalib_unsafe_p file
Packit Service e31359
# True iff FILE is a libtool '.la' library or '.lo' object file.
Packit Service e31359
# This function implements the same check as func_lalib_p without
Packit Service e31359
# resorting to external programs.  To this end, it redirects stdin and
Packit Service e31359
# closes it afterwards, without saving the original file descriptor.
Packit Service e31359
# As a safety measure, use it only where a negative result would be
Packit Service e31359
# fatal anyway.  Works if 'file' does not exist.
Packit Service e31359
func_lalib_unsafe_p ()
Packit Service e31359
{
Packit Service e31359
    lalib_p=no
Packit Service e31359
    if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then
Packit Service e31359
	for lalib_p_l in 1 2 3 4
Packit Service e31359
	do
Packit Service e31359
	    read lalib_p_line
Packit Service e31359
	    case $lalib_p_line in
Packit Service e31359
		\#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;;
Packit Service e31359
	    esac
Packit Service e31359
	done
Packit Service e31359
	exec 0<&5 5<&-
Packit Service e31359
    fi
Packit Service e31359
    test yes = "$lalib_p"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_ltwrapper_script_p file
Packit Service e31359
# True iff FILE is a libtool wrapper script
Packit Service e31359
# This function is only a basic sanity check; it will hardly flush out
Packit Service e31359
# determined imposters.
Packit Service e31359
func_ltwrapper_script_p ()
Packit Service e31359
{
Packit Service e31359
    test -f "$1" &&
Packit Service e31359
      $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_ltwrapper_executable_p file
Packit Service e31359
# True iff FILE is a libtool wrapper executable
Packit Service e31359
# This function is only a basic sanity check; it will hardly flush out
Packit Service e31359
# determined imposters.
Packit Service e31359
func_ltwrapper_executable_p ()
Packit Service e31359
{
Packit Service e31359
    func_ltwrapper_exec_suffix=
Packit Service e31359
    case $1 in
Packit Service e31359
    *.exe) ;;
Packit Service e31359
    *) func_ltwrapper_exec_suffix=.exe ;;
Packit Service e31359
    esac
Packit Service e31359
    $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_ltwrapper_scriptname file
Packit Service e31359
# Assumes file is an ltwrapper_executable
Packit Service e31359
# uses $file to determine the appropriate filename for a
Packit Service e31359
# temporary ltwrapper_script.
Packit Service e31359
func_ltwrapper_scriptname ()
Packit Service e31359
{
Packit Service e31359
    func_dirname_and_basename "$1" "" "."
Packit Service e31359
    func_stripname '' '.exe' "$func_basename_result"
Packit Service e31359
    func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_ltwrapper_p file
Packit Service e31359
# True iff FILE is a libtool wrapper script or wrapper executable
Packit Service e31359
# This function is only a basic sanity check; it will hardly flush out
Packit Service e31359
# determined imposters.
Packit Service e31359
func_ltwrapper_p ()
Packit Service e31359
{
Packit Service e31359
    func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_execute_cmds commands fail_cmd
Packit Service e31359
# Execute tilde-delimited COMMANDS.
Packit Service e31359
# If FAIL_CMD is given, eval that upon failure.
Packit Service e31359
# FAIL_CMD may read-access the current command in variable CMD!
Packit Service e31359
func_execute_cmds ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    save_ifs=$IFS; IFS='~'
Packit Service e31359
    for cmd in $1; do
Packit Service e31359
      IFS=$sp$nl
Packit Service e31359
      eval cmd=\"$cmd\"
Packit Service e31359
      IFS=$save_ifs
Packit Service e31359
      func_show_eval "$cmd" "${2-:}"
Packit Service e31359
    done
Packit Service e31359
    IFS=$save_ifs
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_source file
Packit Service e31359
# Source FILE, adding directory component if necessary.
Packit Service e31359
# Note that it is not necessary on cygwin/mingw to append a dot to
Packit Service e31359
# FILE even if both FILE and FILE.exe exist: automatic-append-.exe
Packit Service e31359
# behavior happens only for exec(3), not for open(2)!  Also, sourcing
Packit Service e31359
# 'FILE.' does not work on cygwin managed mounts.
Packit Service e31359
func_source ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    case $1 in
Packit Service e31359
    */* | *\\*)	. "$1" ;;
Packit Service e31359
    *)		. "./$1" ;;
Packit Service e31359
    esac
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_resolve_sysroot PATH
Packit Service e31359
# Replace a leading = in PATH with a sysroot.  Store the result into
Packit Service e31359
# func_resolve_sysroot_result
Packit Service e31359
func_resolve_sysroot ()
Packit Service e31359
{
Packit Service e31359
  func_resolve_sysroot_result=$1
Packit Service e31359
  case $func_resolve_sysroot_result in
Packit Service e31359
  =*)
Packit Service e31359
    func_stripname '=' '' "$func_resolve_sysroot_result"
Packit Service e31359
    func_resolve_sysroot_result=$lt_sysroot$func_stripname_result
Packit Service e31359
    ;;
Packit Service e31359
  esac
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_replace_sysroot PATH
Packit Service e31359
# If PATH begins with the sysroot, replace it with = and
Packit Service e31359
# store the result into func_replace_sysroot_result.
Packit Service e31359
func_replace_sysroot ()
Packit Service e31359
{
Packit Service e31359
  case $lt_sysroot:$1 in
Packit Service e31359
  ?*:"$lt_sysroot"*)
Packit Service e31359
    func_stripname "$lt_sysroot" '' "$1"
Packit Service e31359
    func_replace_sysroot_result='='$func_stripname_result
Packit Service e31359
    ;;
Packit Service e31359
  *)
Packit Service e31359
    # Including no sysroot.
Packit Service e31359
    func_replace_sysroot_result=$1
Packit Service e31359
    ;;
Packit Service e31359
  esac
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
# func_infer_tag arg
Packit Service e31359
# Infer tagged configuration to use if any are available and
Packit Service e31359
# if one wasn't chosen via the "--tag" command line option.
Packit Service e31359
# Only attempt this if the compiler in the base compile
Packit Service e31359
# command doesn't match the default compiler.
Packit Service e31359
# arg is usually of the form 'gcc ...'
Packit Service e31359
func_infer_tag ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    if test -n "$available_tags" && test -z "$tagname"; then
Packit Service e31359
      CC_quoted=
Packit Service e31359
      for arg in $CC; do
Packit Service e31359
	func_append_quoted CC_quoted "$arg"
Packit Service e31359
      done
Packit Service e31359
      CC_expanded=`func_echo_all $CC`
Packit Service e31359
      CC_quoted_expanded=`func_echo_all $CC_quoted`
Packit Service e31359
      case $@ in
Packit Service e31359
      # Blanks in the command may have been stripped by the calling shell,
Packit Service e31359
      # but not from the CC environment variable when configure was run.
Packit Service e31359
      " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
Packit Service e31359
      " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;;
Packit Service e31359
      # Blanks at the start of $base_compile will cause this to fail
Packit Service e31359
      # if we don't check for them as well.
Packit Service e31359
      *)
Packit Service e31359
	for z in $available_tags; do
Packit Service e31359
	  if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then
Packit Service e31359
	    # Evaluate the configuration.
Packit Service e31359
	    eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
Packit Service e31359
	    CC_quoted=
Packit Service e31359
	    for arg in $CC; do
Packit Service e31359
	      # Double-quote args containing other shell metacharacters.
Packit Service e31359
	      func_append_quoted CC_quoted "$arg"
Packit Service e31359
	    done
Packit Service e31359
	    CC_expanded=`func_echo_all $CC`
Packit Service e31359
	    CC_quoted_expanded=`func_echo_all $CC_quoted`
Packit Service e31359
	    case "$@ " in
Packit Service e31359
	    " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
Packit Service e31359
	    " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*)
Packit Service e31359
	      # The compiler in the base compile command matches
Packit Service e31359
	      # the one in the tagged configuration.
Packit Service e31359
	      # Assume this is the tagged configuration we want.
Packit Service e31359
	      tagname=$z
Packit Service e31359
	      break
Packit Service e31359
	      ;;
Packit Service e31359
	    esac
Packit Service e31359
	  fi
Packit Service e31359
	done
Packit Service e31359
	# If $tagname still isn't set, then no tagged configuration
Packit Service e31359
	# was found and let the user know that the "--tag" command
Packit Service e31359
	# line option must be used.
Packit Service e31359
	if test -z "$tagname"; then
Packit Service e31359
	  func_echo "unable to infer tagged configuration"
Packit Service e31359
	  func_fatal_error "specify a tag with '--tag'"
Packit Service e31359
#	else
Packit Service e31359
#	  func_verbose "using $tagname tagged configuration"
Packit Service e31359
	fi
Packit Service e31359
	;;
Packit Service e31359
      esac
Packit Service e31359
    fi
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_write_libtool_object output_name pic_name nonpic_name
Packit Service e31359
# Create a libtool object file (analogous to a ".la" file),
Packit Service e31359
# but don't create it if we're doing a dry run.
Packit Service e31359
func_write_libtool_object ()
Packit Service e31359
{
Packit Service e31359
    write_libobj=$1
Packit Service e31359
    if test yes = "$build_libtool_libs"; then
Packit Service e31359
      write_lobj=\'$2\'
Packit Service e31359
    else
Packit Service e31359
      write_lobj=none
Packit Service e31359
    fi
Packit Service e31359
Packit Service e31359
    if test yes = "$build_old_libs"; then
Packit Service e31359
      write_oldobj=\'$3\'
Packit Service e31359
    else
Packit Service e31359
      write_oldobj=none
Packit Service e31359
    fi
Packit Service e31359
Packit Service e31359
    $opt_dry_run || {
Packit Service e31359
      cat >${write_libobj}T <
Packit Service e31359
# $write_libobj - a libtool object file
Packit Service e31359
# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
Packit Service e31359
#
Packit Service e31359
# Please DO NOT delete this file!
Packit Service e31359
# It is necessary for linking the library.
Packit Service e31359
Packit Service e31359
# Name of the PIC object.
Packit Service e31359
pic_object=$write_lobj
Packit Service e31359
Packit Service e31359
# Name of the non-PIC object
Packit Service e31359
non_pic_object=$write_oldobj
Packit Service e31359
Packit Service e31359
EOF
Packit Service e31359
      $MV "${write_libobj}T" "$write_libobj"
Packit Service e31359
    }
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
##################################################
Packit Service e31359
# FILE NAME AND PATH CONVERSION HELPER FUNCTIONS #
Packit Service e31359
##################################################
Packit Service e31359
Packit Service e31359
# func_convert_core_file_wine_to_w32 ARG
Packit Service e31359
# Helper function used by file name conversion functions when $build is *nix,
Packit Service e31359
# and $host is mingw, cygwin, or some other w32 environment. Relies on a
Packit Service e31359
# correctly configured wine environment available, with the winepath program
Packit Service e31359
# in $build's $PATH.
Packit Service e31359
#
Packit Service e31359
# ARG is the $build file name to be converted to w32 format.
Packit Service e31359
# Result is available in $func_convert_core_file_wine_to_w32_result, and will
Packit Service e31359
# be empty on error (or when ARG is empty)
Packit Service e31359
func_convert_core_file_wine_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_convert_core_file_wine_to_w32_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # Unfortunately, winepath does not exit with a non-zero error code, so we
Packit Service e31359
    # are forced to check the contents of stdout. On the other hand, if the
Packit Service e31359
    # command is not found, the shell will set an exit code of 127 and print
Packit Service e31359
    # *an error message* to stdout. So we must check for both error code of
Packit Service e31359
    # zero AND non-empty stdout, which explains the odd construction:
Packit Service e31359
    func_convert_core_file_wine_to_w32_tmp=`winepath -w "$1" 2>/dev/null`
Packit Service e31359
    if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then
Packit Service e31359
      func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" |
Packit Service e31359
        $SED -e "$sed_naive_backslashify"`
Packit Service e31359
    else
Packit Service e31359
      func_convert_core_file_wine_to_w32_result=
Packit Service e31359
    fi
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end: func_convert_core_file_wine_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_core_path_wine_to_w32 ARG
Packit Service e31359
# Helper function used by path conversion functions when $build is *nix, and
Packit Service e31359
# $host is mingw, cygwin, or some other w32 environment. Relies on a correctly
Packit Service e31359
# configured wine environment available, with the winepath program in $build's
Packit Service e31359
# $PATH. Assumes ARG has no leading or trailing path separator characters.
Packit Service e31359
#
Packit Service e31359
# ARG is path to be converted from $build format to win32.
Packit Service e31359
# Result is available in $func_convert_core_path_wine_to_w32_result.
Packit Service e31359
# Unconvertible file (directory) names in ARG are skipped; if no directory names
Packit Service e31359
# are convertible, then the result may be empty.
Packit Service e31359
func_convert_core_path_wine_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  # unfortunately, winepath doesn't convert paths, only file names
Packit Service e31359
  func_convert_core_path_wine_to_w32_result=
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    oldIFS=$IFS
Packit Service e31359
    IFS=:
Packit Service e31359
    for func_convert_core_path_wine_to_w32_f in $1; do
Packit Service e31359
      IFS=$oldIFS
Packit Service e31359
      func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f"
Packit Service e31359
      if test -n "$func_convert_core_file_wine_to_w32_result"; then
Packit Service e31359
        if test -z "$func_convert_core_path_wine_to_w32_result"; then
Packit Service e31359
          func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result
Packit Service e31359
        else
Packit Service e31359
          func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result"
Packit Service e31359
        fi
Packit Service e31359
      fi
Packit Service e31359
    done
Packit Service e31359
    IFS=$oldIFS
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end: func_convert_core_path_wine_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_cygpath ARGS...
Packit Service e31359
# Wrapper around calling the cygpath program via LT_CYGPATH. This is used when
Packit Service e31359
# when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2)
Packit Service e31359
# $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or
Packit Service e31359
# (2), returns the Cygwin file name or path in func_cygpath_result (input
Packit Service e31359
# file name or path is assumed to be in w32 format, as previously converted
Packit Service e31359
# from $build's *nix or MSYS format). In case (3), returns the w32 file name
Packit Service e31359
# or path in func_cygpath_result (input file name or path is assumed to be in
Packit Service e31359
# Cygwin format). Returns an empty string on error.
Packit Service e31359
#
Packit Service e31359
# ARGS are passed to cygpath, with the last one being the file name or path to
Packit Service e31359
# be converted.
Packit Service e31359
#
Packit Service e31359
# Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH
Packit Service e31359
# environment variable; do not put it in $PATH.
Packit Service e31359
func_cygpath ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then
Packit Service e31359
    func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null`
Packit Service e31359
    if test "$?" -ne 0; then
Packit Service e31359
      # on failure, ensure result is empty
Packit Service e31359
      func_cygpath_result=
Packit Service e31359
    fi
Packit Service e31359
  else
Packit Service e31359
    func_cygpath_result=
Packit Service e31359
    func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'"
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
#end: func_cygpath
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_core_msys_to_w32 ARG
Packit Service e31359
# Convert file name or path ARG from MSYS format to w32 format.  Return
Packit Service e31359
# result in func_convert_core_msys_to_w32_result.
Packit Service e31359
func_convert_core_msys_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  # awkward: cmd appends spaces to result
Packit Service e31359
  func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null |
Packit Service e31359
    $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"`
Packit Service e31359
}
Packit Service e31359
#end: func_convert_core_msys_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_file_check ARG1 ARG2
Packit Service e31359
# Verify that ARG1 (a file name in $build format) was converted to $host
Packit Service e31359
# format in ARG2. Otherwise, emit an error message, but continue (resetting
Packit Service e31359
# func_to_host_file_result to ARG1).
Packit Service e31359
func_convert_file_check ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  if test -z "$2" && test -n "$1"; then
Packit Service e31359
    func_error "Could not determine host file name corresponding to"
Packit Service e31359
    func_error "  '$1'"
Packit Service e31359
    func_error "Continuing, but uninstalled executables may not work."
Packit Service e31359
    # Fallback:
Packit Service e31359
    func_to_host_file_result=$1
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end func_convert_file_check
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH
Packit Service e31359
# Verify that FROM_PATH (a path in $build format) was converted to $host
Packit Service e31359
# format in TO_PATH. Otherwise, emit an error message, but continue, resetting
Packit Service e31359
# func_to_host_file_result to a simplistic fallback value (see below).
Packit Service e31359
func_convert_path_check ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  if test -z "$4" && test -n "$3"; then
Packit Service e31359
    func_error "Could not determine the host path corresponding to"
Packit Service e31359
    func_error "  '$3'"
Packit Service e31359
    func_error "Continuing, but uninstalled executables may not work."
Packit Service e31359
    # Fallback.  This is a deliberately simplistic "conversion" and
Packit Service e31359
    # should not be "improved".  See libtool.info.
Packit Service e31359
    if test "x$1" != "x$2"; then
Packit Service e31359
      lt_replace_pathsep_chars="s|$1|$2|g"
Packit Service e31359
      func_to_host_path_result=`echo "$3" |
Packit Service e31359
        $SED -e "$lt_replace_pathsep_chars"`
Packit Service e31359
    else
Packit Service e31359
      func_to_host_path_result=$3
Packit Service e31359
    fi
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_check
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG
Packit Service e31359
# Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT
Packit Service e31359
# and appending REPL if ORIG matches BACKPAT.
Packit Service e31359
func_convert_path_front_back_pathsep ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  case $4 in
Packit Service e31359
  $1 ) func_to_host_path_result=$3$func_to_host_path_result
Packit Service e31359
    ;;
Packit Service e31359
  esac
Packit Service e31359
  case $4 in
Packit Service e31359
  $2 ) func_append func_to_host_path_result "$3"
Packit Service e31359
    ;;
Packit Service e31359
  esac
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_front_back_pathsep
Packit Service e31359
Packit Service e31359
Packit Service e31359
##################################################
Packit Service e31359
# $build to $host FILE NAME CONVERSION FUNCTIONS #
Packit Service e31359
##################################################
Packit Service e31359
# invoked via '$to_host_file_cmd ARG'
Packit Service e31359
#
Packit Service e31359
# In each case, ARG is the path to be converted from $build to $host format.
Packit Service e31359
# Result will be available in $func_to_host_file_result.
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_to_host_file ARG
Packit Service e31359
# Converts the file name ARG from $build format to $host format. Return result
Packit Service e31359
# in func_to_host_file_result.
Packit Service e31359
func_to_host_file ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  $to_host_file_cmd "$1"
Packit Service e31359
}
Packit Service e31359
# end func_to_host_file
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_to_tool_file ARG LAZY
Packit Service e31359
# converts the file name ARG from $build format to toolchain format. Return
Packit Service e31359
# result in func_to_tool_file_result.  If the conversion in use is listed
Packit Service e31359
# in (the comma separated) LAZY, no conversion takes place.
Packit Service e31359
func_to_tool_file ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  case ,$2, in
Packit Service e31359
    *,"$to_tool_file_cmd",*)
Packit Service e31359
      func_to_tool_file_result=$1
Packit Service e31359
      ;;
Packit Service e31359
    *)
Packit Service e31359
      $to_tool_file_cmd "$1"
Packit Service e31359
      func_to_tool_file_result=$func_to_host_file_result
Packit Service e31359
      ;;
Packit Service e31359
  esac
Packit Service e31359
}
Packit Service e31359
# end func_to_tool_file
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_file_noop ARG
Packit Service e31359
# Copy ARG to func_to_host_file_result.
Packit Service e31359
func_convert_file_noop ()
Packit Service e31359
{
Packit Service e31359
  func_to_host_file_result=$1
Packit Service e31359
}
Packit Service e31359
# end func_convert_file_noop
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_file_msys_to_w32 ARG
Packit Service e31359
# Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic
Packit Service e31359
# conversion to w32 is not available inside the cwrapper.  Returns result in
Packit Service e31359
# func_to_host_file_result.
Packit Service e31359
func_convert_file_msys_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_file_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    func_convert_core_msys_to_w32 "$1"
Packit Service e31359
    func_to_host_file_result=$func_convert_core_msys_to_w32_result
Packit Service e31359
  fi
Packit Service e31359
  func_convert_file_check "$1" "$func_to_host_file_result"
Packit Service e31359
}
Packit Service e31359
# end func_convert_file_msys_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_file_cygwin_to_w32 ARG
Packit Service e31359
# Convert file name ARG from Cygwin to w32 format.  Returns result in
Packit Service e31359
# func_to_host_file_result.
Packit Service e31359
func_convert_file_cygwin_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_file_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # because $build is cygwin, we call "the" cygpath in $PATH; no need to use
Packit Service e31359
    # LT_CYGPATH in this case.
Packit Service e31359
    func_to_host_file_result=`cygpath -m "$1"`
Packit Service e31359
  fi
Packit Service e31359
  func_convert_file_check "$1" "$func_to_host_file_result"
Packit Service e31359
}
Packit Service e31359
# end func_convert_file_cygwin_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_file_nix_to_w32 ARG
Packit Service e31359
# Convert file name ARG from *nix to w32 format.  Requires a wine environment
Packit Service e31359
# and a working winepath. Returns result in func_to_host_file_result.
Packit Service e31359
func_convert_file_nix_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_file_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    func_convert_core_file_wine_to_w32 "$1"
Packit Service e31359
    func_to_host_file_result=$func_convert_core_file_wine_to_w32_result
Packit Service e31359
  fi
Packit Service e31359
  func_convert_file_check "$1" "$func_to_host_file_result"
Packit Service e31359
}
Packit Service e31359
# end func_convert_file_nix_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_file_msys_to_cygwin ARG
Packit Service e31359
# Convert file name ARG from MSYS to Cygwin format.  Requires LT_CYGPATH set.
Packit Service e31359
# Returns result in func_to_host_file_result.
Packit Service e31359
func_convert_file_msys_to_cygwin ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_file_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    func_convert_core_msys_to_w32 "$1"
Packit Service e31359
    func_cygpath -u "$func_convert_core_msys_to_w32_result"
Packit Service e31359
    func_to_host_file_result=$func_cygpath_result
Packit Service e31359
  fi
Packit Service e31359
  func_convert_file_check "$1" "$func_to_host_file_result"
Packit Service e31359
}
Packit Service e31359
# end func_convert_file_msys_to_cygwin
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_file_nix_to_cygwin ARG
Packit Service e31359
# Convert file name ARG from *nix to Cygwin format.  Requires Cygwin installed
Packit Service e31359
# in a wine environment, working winepath, and LT_CYGPATH set.  Returns result
Packit Service e31359
# in func_to_host_file_result.
Packit Service e31359
func_convert_file_nix_to_cygwin ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_file_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # convert from *nix to w32, then use cygpath to convert from w32 to cygwin.
Packit Service e31359
    func_convert_core_file_wine_to_w32 "$1"
Packit Service e31359
    func_cygpath -u "$func_convert_core_file_wine_to_w32_result"
Packit Service e31359
    func_to_host_file_result=$func_cygpath_result
Packit Service e31359
  fi
Packit Service e31359
  func_convert_file_check "$1" "$func_to_host_file_result"
Packit Service e31359
}
Packit Service e31359
# end func_convert_file_nix_to_cygwin
Packit Service e31359
Packit Service e31359
Packit Service e31359
#############################################
Packit Service e31359
# $build to $host PATH CONVERSION FUNCTIONS #
Packit Service e31359
#############################################
Packit Service e31359
# invoked via '$to_host_path_cmd ARG'
Packit Service e31359
#
Packit Service e31359
# In each case, ARG is the path to be converted from $build to $host format.
Packit Service e31359
# The result will be available in $func_to_host_path_result.
Packit Service e31359
#
Packit Service e31359
# Path separators are also converted from $build format to $host format.  If
Packit Service e31359
# ARG begins or ends with a path separator character, it is preserved (but
Packit Service e31359
# converted to $host format) on output.
Packit Service e31359
#
Packit Service e31359
# All path conversion functions are named using the following convention:
Packit Service e31359
#   file name conversion function    : func_convert_file_X_to_Y ()
Packit Service e31359
#   path conversion function         : func_convert_path_X_to_Y ()
Packit Service e31359
# where, for any given $build/$host combination the 'X_to_Y' value is the
Packit Service e31359
# same.  If conversion functions are added for new $build/$host combinations,
Packit Service e31359
# the two new functions must follow this pattern, or func_init_to_host_path_cmd
Packit Service e31359
# will break.
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_init_to_host_path_cmd
Packit Service e31359
# Ensures that function "pointer" variable $to_host_path_cmd is set to the
Packit Service e31359
# appropriate value, based on the value of $to_host_file_cmd.
Packit Service e31359
to_host_path_cmd=
Packit Service e31359
func_init_to_host_path_cmd ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  if test -z "$to_host_path_cmd"; then
Packit Service e31359
    func_stripname 'func_convert_file_' '' "$to_host_file_cmd"
Packit Service e31359
    to_host_path_cmd=func_convert_path_$func_stripname_result
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_to_host_path ARG
Packit Service e31359
# Converts the path ARG from $build format to $host format. Return result
Packit Service e31359
# in func_to_host_path_result.
Packit Service e31359
func_to_host_path ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_init_to_host_path_cmd
Packit Service e31359
  $to_host_path_cmd "$1"
Packit Service e31359
}
Packit Service e31359
# end func_to_host_path
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_noop ARG
Packit Service e31359
# Copy ARG to func_to_host_path_result.
Packit Service e31359
func_convert_path_noop ()
Packit Service e31359
{
Packit Service e31359
  func_to_host_path_result=$1
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_noop
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_msys_to_w32 ARG
Packit Service e31359
# Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic
Packit Service e31359
# conversion to w32 is not available inside the cwrapper.  Returns result in
Packit Service e31359
# func_to_host_path_result.
Packit Service e31359
func_convert_path_msys_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_path_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # Remove leading and trailing path separator characters from ARG.  MSYS
Packit Service e31359
    # behavior is inconsistent here; cygpath turns them into '.;' and ';.';
Packit Service e31359
    # and winepath ignores them completely.
Packit Service e31359
    func_stripname : : "$1"
Packit Service e31359
    func_to_host_path_tmp1=$func_stripname_result
Packit Service e31359
    func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
Packit Service e31359
    func_to_host_path_result=$func_convert_core_msys_to_w32_result
Packit Service e31359
    func_convert_path_check : ";" \
Packit Service e31359
      "$func_to_host_path_tmp1" "$func_to_host_path_result"
Packit Service e31359
    func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_msys_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_cygwin_to_w32 ARG
Packit Service e31359
# Convert path ARG from Cygwin to w32 format.  Returns result in
Packit Service e31359
# func_to_host_file_result.
Packit Service e31359
func_convert_path_cygwin_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_path_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # See func_convert_path_msys_to_w32:
Packit Service e31359
    func_stripname : : "$1"
Packit Service e31359
    func_to_host_path_tmp1=$func_stripname_result
Packit Service e31359
    func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"`
Packit Service e31359
    func_convert_path_check : ";" \
Packit Service e31359
      "$func_to_host_path_tmp1" "$func_to_host_path_result"
Packit Service e31359
    func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_cygwin_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_nix_to_w32 ARG
Packit Service e31359
# Convert path ARG from *nix to w32 format.  Requires a wine environment and
Packit Service e31359
# a working winepath.  Returns result in func_to_host_file_result.
Packit Service e31359
func_convert_path_nix_to_w32 ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_path_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # See func_convert_path_msys_to_w32:
Packit Service e31359
    func_stripname : : "$1"
Packit Service e31359
    func_to_host_path_tmp1=$func_stripname_result
Packit Service e31359
    func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
Packit Service e31359
    func_to_host_path_result=$func_convert_core_path_wine_to_w32_result
Packit Service e31359
    func_convert_path_check : ";" \
Packit Service e31359
      "$func_to_host_path_tmp1" "$func_to_host_path_result"
Packit Service e31359
    func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_nix_to_w32
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_msys_to_cygwin ARG
Packit Service e31359
# Convert path ARG from MSYS to Cygwin format.  Requires LT_CYGPATH set.
Packit Service e31359
# Returns result in func_to_host_file_result.
Packit Service e31359
func_convert_path_msys_to_cygwin ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_path_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # See func_convert_path_msys_to_w32:
Packit Service e31359
    func_stripname : : "$1"
Packit Service e31359
    func_to_host_path_tmp1=$func_stripname_result
Packit Service e31359
    func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
Packit Service e31359
    func_cygpath -u -p "$func_convert_core_msys_to_w32_result"
Packit Service e31359
    func_to_host_path_result=$func_cygpath_result
Packit Service e31359
    func_convert_path_check : : \
Packit Service e31359
      "$func_to_host_path_tmp1" "$func_to_host_path_result"
Packit Service e31359
    func_convert_path_front_back_pathsep ":*" "*:" : "$1"
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_msys_to_cygwin
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_convert_path_nix_to_cygwin ARG
Packit Service e31359
# Convert path ARG from *nix to Cygwin format.  Requires Cygwin installed in a
Packit Service e31359
# a wine environment, working winepath, and LT_CYGPATH set.  Returns result in
Packit Service e31359
# func_to_host_file_result.
Packit Service e31359
func_convert_path_nix_to_cygwin ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_to_host_path_result=$1
Packit Service e31359
  if test -n "$1"; then
Packit Service e31359
    # Remove leading and trailing path separator characters from
Packit Service e31359
    # ARG. msys behavior is inconsistent here, cygpath turns them
Packit Service e31359
    # into '.;' and ';.', and winepath ignores them completely.
Packit Service e31359
    func_stripname : : "$1"
Packit Service e31359
    func_to_host_path_tmp1=$func_stripname_result
Packit Service e31359
    func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
Packit Service e31359
    func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result"
Packit Service e31359
    func_to_host_path_result=$func_cygpath_result
Packit Service e31359
    func_convert_path_check : : \
Packit Service e31359
      "$func_to_host_path_tmp1" "$func_to_host_path_result"
Packit Service e31359
    func_convert_path_front_back_pathsep ":*" "*:" : "$1"
Packit Service e31359
  fi
Packit Service e31359
}
Packit Service e31359
# end func_convert_path_nix_to_cygwin
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_dll_def_p FILE
Packit Service e31359
# True iff FILE is a Windows DLL '.def' file.
Packit Service e31359
# Keep in sync with _LT_DLL_DEF_P in libtool.m4
Packit Service e31359
func_dll_def_p ()
Packit Service e31359
{
Packit Service e31359
  $debug_cmd
Packit Service e31359
Packit Service e31359
  func_dll_def_p_tmp=`$SED -n \
Packit Service e31359
    -e 's/^[	 ]*//' \
Packit Service e31359
    -e '/^\(;.*\)*$/d' \
Packit Service e31359
    -e 's/^\(EXPORTS\|LIBRARY\)\([	 ].*\)*$/DEF/p' \
Packit Service e31359
    -e q \
Packit Service e31359
    "$1"`
Packit Service e31359
  test DEF = "$func_dll_def_p_tmp"
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
# func_mode_compile arg...
Packit Service e31359
func_mode_compile ()
Packit Service e31359
{
Packit Service e31359
    $debug_cmd
Packit Service e31359
Packit Service e31359
    # Get the compilation command and the source file.
Packit Service