Blame ltmain.sh

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