Blame build/ltmain.sh

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