xref: /aosp_15_r20/external/curl/ltmain.sh (revision 6236dae45794135f37c4eb022389c904c8b0090d)
1*6236dae4SAndroid Build Coastguard Worker#! /usr/bin/env sh
2*6236dae4SAndroid Build Coastguard Worker## DO NOT EDIT - This file generated from ./build-aux/ltmain.in
3*6236dae4SAndroid Build Coastguard Worker##               by inline-source v2019-02-19.15
4*6236dae4SAndroid Build Coastguard Worker
5*6236dae4SAndroid Build Coastguard Worker# libtool (GNU libtool) 2.4.7
6*6236dae4SAndroid Build Coastguard Worker# Provide generalized library-building support services.
7*6236dae4SAndroid Build Coastguard Worker# Written by Gordon Matzigkeit <[email protected]>, 1996
8*6236dae4SAndroid Build Coastguard Worker
9*6236dae4SAndroid Build Coastguard Worker# Copyright (C) 1996-2019, 2021-2022 Free Software Foundation, Inc.
10*6236dae4SAndroid Build Coastguard Worker# This is free software; see the source for copying conditions.  There is NO
11*6236dae4SAndroid Build Coastguard Worker# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
12*6236dae4SAndroid Build Coastguard Worker
13*6236dae4SAndroid Build Coastguard Worker# GNU Libtool is free software; you can redistribute it and/or modify
14*6236dae4SAndroid Build Coastguard Worker# it under the terms of the GNU General Public License as published by
15*6236dae4SAndroid Build Coastguard Worker# the Free Software Foundation; either version 2 of the License, or
16*6236dae4SAndroid Build Coastguard Worker# (at your option) any later version.
17*6236dae4SAndroid Build Coastguard Worker#
18*6236dae4SAndroid Build Coastguard Worker# As a special exception to the GNU General Public License,
19*6236dae4SAndroid Build Coastguard Worker# if you distribute this file as part of a program or library that
20*6236dae4SAndroid Build Coastguard Worker# is built using GNU Libtool, you may include this file under the
21*6236dae4SAndroid Build Coastguard Worker# same distribution terms that you use for the rest of that program.
22*6236dae4SAndroid Build Coastguard Worker#
23*6236dae4SAndroid Build Coastguard Worker# GNU Libtool is distributed in the hope that it will be useful, but
24*6236dae4SAndroid Build Coastguard Worker# WITHOUT ANY WARRANTY; without even the implied warranty of
25*6236dae4SAndroid Build Coastguard Worker# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
26*6236dae4SAndroid Build Coastguard Worker# General Public License for more details.
27*6236dae4SAndroid Build Coastguard Worker#
28*6236dae4SAndroid Build Coastguard Worker# You should have received a copy of the GNU General Public License
29*6236dae4SAndroid Build Coastguard Worker# along with this program.  If not, see <http://www.gnu.org/licenses/>.
30*6236dae4SAndroid Build Coastguard Worker
31*6236dae4SAndroid Build Coastguard Worker
32*6236dae4SAndroid Build Coastguard WorkerPROGRAM=libtool
33*6236dae4SAndroid Build Coastguard WorkerPACKAGE=libtool
34*6236dae4SAndroid Build Coastguard WorkerVERSION="2.4.7 Debian-2.4.7-7+build1"
35*6236dae4SAndroid Build Coastguard Workerpackage_revision=2.4.7
36*6236dae4SAndroid Build Coastguard Worker
37*6236dae4SAndroid Build Coastguard Worker
38*6236dae4SAndroid Build Coastguard Worker## ------ ##
39*6236dae4SAndroid Build Coastguard Worker## Usage. ##
40*6236dae4SAndroid Build Coastguard Worker## ------ ##
41*6236dae4SAndroid Build Coastguard Worker
42*6236dae4SAndroid Build Coastguard Worker# Run './libtool --help' for help with using this script from the
43*6236dae4SAndroid Build Coastguard Worker# command line.
44*6236dae4SAndroid Build Coastguard Worker
45*6236dae4SAndroid Build Coastguard Worker
46*6236dae4SAndroid Build Coastguard Worker## ------------------------------- ##
47*6236dae4SAndroid Build Coastguard Worker## User overridable command paths. ##
48*6236dae4SAndroid Build Coastguard Worker## ------------------------------- ##
49*6236dae4SAndroid Build Coastguard Worker
50*6236dae4SAndroid Build Coastguard Worker# After configure completes, it has a better idea of some of the
51*6236dae4SAndroid Build Coastguard Worker# shell tools we need than the defaults used by the functions shared
52*6236dae4SAndroid Build Coastguard Worker# with bootstrap, so set those here where they can still be over-
53*6236dae4SAndroid Build Coastguard Worker# ridden by the user, but otherwise take precedence.
54*6236dae4SAndroid Build Coastguard Worker
55*6236dae4SAndroid Build Coastguard Worker: ${AUTOCONF="autoconf"}
56*6236dae4SAndroid Build Coastguard Worker: ${AUTOMAKE="automake"}
57*6236dae4SAndroid Build Coastguard Worker
58*6236dae4SAndroid Build Coastguard Worker
59*6236dae4SAndroid Build Coastguard Worker## -------------------------- ##
60*6236dae4SAndroid Build Coastguard Worker## Source external libraries. ##
61*6236dae4SAndroid Build Coastguard Worker## -------------------------- ##
62*6236dae4SAndroid Build Coastguard Worker
63*6236dae4SAndroid Build Coastguard Worker# Much of our low-level functionality needs to be sourced from external
64*6236dae4SAndroid Build Coastguard Worker# libraries, which are installed to $pkgauxdir.
65*6236dae4SAndroid Build Coastguard Worker
66*6236dae4SAndroid Build Coastguard Worker# Set a version string for this script.
67*6236dae4SAndroid Build Coastguard Workerscriptversion=2019-02-19.15; # UTC
68*6236dae4SAndroid Build Coastguard Worker
69*6236dae4SAndroid Build Coastguard Worker# General shell script boiler plate, and helper functions.
70*6236dae4SAndroid Build Coastguard Worker# Written by Gary V. Vaughan, 2004
71*6236dae4SAndroid Build Coastguard Worker
72*6236dae4SAndroid Build Coastguard Worker# This is free software.  There is NO warranty; not even for
73*6236dae4SAndroid Build Coastguard Worker# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
74*6236dae4SAndroid Build Coastguard Worker#
75*6236dae4SAndroid Build Coastguard Worker# Copyright (C) 2004-2019, 2021 Bootstrap Authors
76*6236dae4SAndroid Build Coastguard Worker#
77*6236dae4SAndroid Build Coastguard Worker# This file is dual licensed under the terms of the MIT license
78*6236dae4SAndroid Build Coastguard Worker# <https://opensource.org/license/MIT>, and GPL version 2 or later
79*6236dae4SAndroid Build Coastguard Worker# <http://www.gnu.org/licenses/gpl-2.0.html>.  You must apply one of
80*6236dae4SAndroid Build Coastguard Worker# these licenses when using or redistributing this software or any of
81*6236dae4SAndroid Build Coastguard Worker# the files within it.  See the URLs above, or the file `LICENSE`
82*6236dae4SAndroid Build Coastguard Worker# included in the Bootstrap distribution for the full license texts.
83*6236dae4SAndroid Build Coastguard Worker
84*6236dae4SAndroid Build Coastguard Worker# Please report bugs or propose patches to:
85*6236dae4SAndroid Build Coastguard Worker# <https://github.com/gnulib-modules/bootstrap/issues>
86*6236dae4SAndroid Build Coastguard Worker
87*6236dae4SAndroid Build Coastguard Worker
88*6236dae4SAndroid Build Coastguard Worker## ------ ##
89*6236dae4SAndroid Build Coastguard Worker## Usage. ##
90*6236dae4SAndroid Build Coastguard Worker## ------ ##
91*6236dae4SAndroid Build Coastguard Worker
92*6236dae4SAndroid Build Coastguard Worker# Evaluate this file near the top of your script to gain access to
93*6236dae4SAndroid Build Coastguard Worker# the functions and variables defined here:
94*6236dae4SAndroid Build Coastguard Worker#
95*6236dae4SAndroid Build Coastguard Worker#   . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh
96*6236dae4SAndroid Build Coastguard Worker#
97*6236dae4SAndroid Build Coastguard Worker# If you need to override any of the default environment variable
98*6236dae4SAndroid Build Coastguard Worker# settings, do that before evaluating this file.
99*6236dae4SAndroid Build Coastguard Worker
100*6236dae4SAndroid Build Coastguard Worker
101*6236dae4SAndroid Build Coastguard Worker## -------------------- ##
102*6236dae4SAndroid Build Coastguard Worker## Shell normalisation. ##
103*6236dae4SAndroid Build Coastguard Worker## -------------------- ##
104*6236dae4SAndroid Build Coastguard Worker
105*6236dae4SAndroid Build Coastguard Worker# Some shells need a little help to be as Bourne compatible as possible.
106*6236dae4SAndroid Build Coastguard Worker# Before doing anything else, make sure all that help has been provided!
107*6236dae4SAndroid Build Coastguard Worker
108*6236dae4SAndroid Build Coastguard WorkerDUALCASE=1; export DUALCASE # for MKS sh
109*6236dae4SAndroid Build Coastguard Workerif test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then :
110*6236dae4SAndroid Build Coastguard Worker  emulate sh
111*6236dae4SAndroid Build Coastguard Worker  NULLCMD=:
112*6236dae4SAndroid Build Coastguard Worker  # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
113*6236dae4SAndroid Build Coastguard Worker  # is contrary to our usage.  Disable this feature.
114*6236dae4SAndroid Build Coastguard Worker  alias -g '${1+"$@"}'='"$@"'
115*6236dae4SAndroid Build Coastguard Worker  setopt NO_GLOB_SUBST
116*6236dae4SAndroid Build Coastguard Workerelse
117*6236dae4SAndroid Build Coastguard Worker  case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac
118*6236dae4SAndroid Build Coastguard Workerfi
119*6236dae4SAndroid Build Coastguard Worker
120*6236dae4SAndroid Build Coastguard Worker# NLS nuisances: We save the old values in case they are required later.
121*6236dae4SAndroid Build Coastguard Worker_G_user_locale=
122*6236dae4SAndroid Build Coastguard Worker_G_safe_locale=
123*6236dae4SAndroid Build Coastguard Workerfor _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
124*6236dae4SAndroid Build Coastguard Workerdo
125*6236dae4SAndroid Build Coastguard Worker  eval "if test set = \"\${$_G_var+set}\"; then
126*6236dae4SAndroid Build Coastguard Worker          save_$_G_var=\$$_G_var
127*6236dae4SAndroid Build Coastguard Worker          $_G_var=C
128*6236dae4SAndroid Build Coastguard Worker	  export $_G_var
129*6236dae4SAndroid Build Coastguard Worker	  _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\"
130*6236dae4SAndroid Build Coastguard Worker	  _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\"
131*6236dae4SAndroid Build Coastguard Worker	fi"
132*6236dae4SAndroid Build Coastguard Workerdone
133*6236dae4SAndroid Build Coastguard Worker# These NLS vars are set unconditionally (bootstrap issue #24).  Unset those
134*6236dae4SAndroid Build Coastguard Worker# in case the environment reset is needed later and the $save_* variant is not
135*6236dae4SAndroid Build Coastguard Worker# defined (see the code above).
136*6236dae4SAndroid Build Coastguard WorkerLC_ALL=C
137*6236dae4SAndroid Build Coastguard WorkerLANGUAGE=C
138*6236dae4SAndroid Build Coastguard Workerexport LANGUAGE LC_ALL
139*6236dae4SAndroid Build Coastguard Worker
140*6236dae4SAndroid Build Coastguard Worker# Make sure IFS has a sensible default
141*6236dae4SAndroid Build Coastguard Workersp=' '
142*6236dae4SAndroid Build Coastguard Workernl='
143*6236dae4SAndroid Build Coastguard Worker'
144*6236dae4SAndroid Build Coastguard WorkerIFS="$sp	$nl"
145*6236dae4SAndroid Build Coastguard Worker
146*6236dae4SAndroid Build Coastguard Worker# There are apparently some retarded systems that use ';' as a PATH separator!
147*6236dae4SAndroid Build Coastguard Workerif test "${PATH_SEPARATOR+set}" != set; then
148*6236dae4SAndroid Build Coastguard Worker  PATH_SEPARATOR=:
149*6236dae4SAndroid Build Coastguard Worker  (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && {
150*6236dae4SAndroid Build Coastguard Worker    (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 ||
151*6236dae4SAndroid Build Coastguard Worker      PATH_SEPARATOR=';'
152*6236dae4SAndroid Build Coastguard Worker  }
153*6236dae4SAndroid Build Coastguard Workerfi
154*6236dae4SAndroid Build Coastguard Worker
155*6236dae4SAndroid Build Coastguard Worker
156*6236dae4SAndroid Build Coastguard Worker# func_unset VAR
157*6236dae4SAndroid Build Coastguard Worker# --------------
158*6236dae4SAndroid Build Coastguard Worker# Portably unset VAR.
159*6236dae4SAndroid Build Coastguard Worker# In some shells, an 'unset VAR' statement leaves a non-zero return
160*6236dae4SAndroid Build Coastguard Worker# status if VAR is already unset, which might be problematic if the
161*6236dae4SAndroid Build Coastguard Worker# statement is used at the end of a function (thus poisoning its return
162*6236dae4SAndroid Build Coastguard Worker# value) or when 'set -e' is active (causing even a spurious abort of
163*6236dae4SAndroid Build Coastguard Worker# the script in this case).
164*6236dae4SAndroid Build Coastguard Workerfunc_unset ()
165*6236dae4SAndroid Build Coastguard Worker{
166*6236dae4SAndroid Build Coastguard Worker    { eval $1=; (eval unset $1) >/dev/null 2>&1 && eval unset $1 || : ; }
167*6236dae4SAndroid Build Coastguard Worker}
168*6236dae4SAndroid Build Coastguard Worker
169*6236dae4SAndroid Build Coastguard Worker
170*6236dae4SAndroid Build Coastguard Worker# Make sure CDPATH doesn't cause `cd` commands to output the target dir.
171*6236dae4SAndroid Build Coastguard Workerfunc_unset CDPATH
172*6236dae4SAndroid Build Coastguard Worker
173*6236dae4SAndroid Build Coastguard Worker# Make sure ${,E,F}GREP behave sanely.
174*6236dae4SAndroid Build Coastguard Workerfunc_unset GREP_OPTIONS
175*6236dae4SAndroid Build Coastguard Worker
176*6236dae4SAndroid Build Coastguard Worker
177*6236dae4SAndroid Build Coastguard Worker## ------------------------- ##
178*6236dae4SAndroid Build Coastguard Worker## Locate command utilities. ##
179*6236dae4SAndroid Build Coastguard Worker## ------------------------- ##
180*6236dae4SAndroid Build Coastguard Worker
181*6236dae4SAndroid Build Coastguard Worker
182*6236dae4SAndroid Build Coastguard Worker# func_executable_p FILE
183*6236dae4SAndroid Build Coastguard Worker# ----------------------
184*6236dae4SAndroid Build Coastguard Worker# Check that FILE is an executable regular file.
185*6236dae4SAndroid Build Coastguard Workerfunc_executable_p ()
186*6236dae4SAndroid Build Coastguard Worker{
187*6236dae4SAndroid Build Coastguard Worker    test -f "$1" && test -x "$1"
188*6236dae4SAndroid Build Coastguard Worker}
189*6236dae4SAndroid Build Coastguard Worker
190*6236dae4SAndroid Build Coastguard Worker
191*6236dae4SAndroid Build Coastguard Worker# func_path_progs PROGS_LIST CHECK_FUNC [PATH]
192*6236dae4SAndroid Build Coastguard Worker# --------------------------------------------
193*6236dae4SAndroid Build Coastguard Worker# Search for either a program that responds to --version with output
194*6236dae4SAndroid Build Coastguard Worker# containing "GNU", or else returned by CHECK_FUNC otherwise, by
195*6236dae4SAndroid Build Coastguard Worker# trying all the directories in PATH with each of the elements of
196*6236dae4SAndroid Build Coastguard Worker# PROGS_LIST.
197*6236dae4SAndroid Build Coastguard Worker#
198*6236dae4SAndroid Build Coastguard Worker# CHECK_FUNC should accept the path to a candidate program, and
199*6236dae4SAndroid Build Coastguard Worker# set $func_check_prog_result if it truncates its output less than
200*6236dae4SAndroid Build Coastguard Worker# $_G_path_prog_max characters.
201*6236dae4SAndroid Build Coastguard Workerfunc_path_progs ()
202*6236dae4SAndroid Build Coastguard Worker{
203*6236dae4SAndroid Build Coastguard Worker    _G_progs_list=$1
204*6236dae4SAndroid Build Coastguard Worker    _G_check_func=$2
205*6236dae4SAndroid Build Coastguard Worker    _G_PATH=${3-"$PATH"}
206*6236dae4SAndroid Build Coastguard Worker
207*6236dae4SAndroid Build Coastguard Worker    _G_path_prog_max=0
208*6236dae4SAndroid Build Coastguard Worker    _G_path_prog_found=false
209*6236dae4SAndroid Build Coastguard Worker    _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:}
210*6236dae4SAndroid Build Coastguard Worker    for _G_dir in $_G_PATH; do
211*6236dae4SAndroid Build Coastguard Worker      IFS=$_G_save_IFS
212*6236dae4SAndroid Build Coastguard Worker      test -z "$_G_dir" && _G_dir=.
213*6236dae4SAndroid Build Coastguard Worker      for _G_prog_name in $_G_progs_list; do
214*6236dae4SAndroid Build Coastguard Worker        for _exeext in '' .EXE; do
215*6236dae4SAndroid Build Coastguard Worker          _G_path_prog=$_G_dir/$_G_prog_name$_exeext
216*6236dae4SAndroid Build Coastguard Worker          func_executable_p "$_G_path_prog" || continue
217*6236dae4SAndroid Build Coastguard Worker          case `"$_G_path_prog" --version 2>&1` in
218*6236dae4SAndroid Build Coastguard Worker            *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;;
219*6236dae4SAndroid Build Coastguard Worker            *)     $_G_check_func $_G_path_prog
220*6236dae4SAndroid Build Coastguard Worker		   func_path_progs_result=$func_check_prog_result
221*6236dae4SAndroid Build Coastguard Worker		   ;;
222*6236dae4SAndroid Build Coastguard Worker          esac
223*6236dae4SAndroid Build Coastguard Worker          $_G_path_prog_found && break 3
224*6236dae4SAndroid Build Coastguard Worker        done
225*6236dae4SAndroid Build Coastguard Worker      done
226*6236dae4SAndroid Build Coastguard Worker    done
227*6236dae4SAndroid Build Coastguard Worker    IFS=$_G_save_IFS
228*6236dae4SAndroid Build Coastguard Worker    test -z "$func_path_progs_result" && {
229*6236dae4SAndroid Build Coastguard Worker      echo "no acceptable sed could be found in \$PATH" >&2
230*6236dae4SAndroid Build Coastguard Worker      exit 1
231*6236dae4SAndroid Build Coastguard Worker    }
232*6236dae4SAndroid Build Coastguard Worker}
233*6236dae4SAndroid Build Coastguard Worker
234*6236dae4SAndroid Build Coastguard Worker
235*6236dae4SAndroid Build Coastguard Worker# We want to be able to use the functions in this file before configure
236*6236dae4SAndroid Build Coastguard Worker# has figured out where the best binaries are kept, which means we have
237*6236dae4SAndroid Build Coastguard Worker# to search for them ourselves - except when the results are already set
238*6236dae4SAndroid Build Coastguard Worker# where we skip the searches.
239*6236dae4SAndroid Build Coastguard Worker
240*6236dae4SAndroid Build Coastguard Worker# Unless the user overrides by setting SED, search the path for either GNU
241*6236dae4SAndroid Build Coastguard Worker# sed, or the sed that truncates its output the least.
242*6236dae4SAndroid Build Coastguard Workertest -z "$SED" && {
243*6236dae4SAndroid Build Coastguard Worker  _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/
244*6236dae4SAndroid Build Coastguard Worker  for _G_i in 1 2 3 4 5 6 7; do
245*6236dae4SAndroid Build Coastguard Worker    _G_sed_script=$_G_sed_script$nl$_G_sed_script
246*6236dae4SAndroid Build Coastguard Worker  done
247*6236dae4SAndroid Build Coastguard Worker  echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed
248*6236dae4SAndroid Build Coastguard Worker  _G_sed_script=
249*6236dae4SAndroid Build Coastguard Worker
250*6236dae4SAndroid Build Coastguard Worker  func_check_prog_sed ()
251*6236dae4SAndroid Build Coastguard Worker  {
252*6236dae4SAndroid Build Coastguard Worker    _G_path_prog=$1
253*6236dae4SAndroid Build Coastguard Worker
254*6236dae4SAndroid Build Coastguard Worker    _G_count=0
255*6236dae4SAndroid Build Coastguard Worker    printf 0123456789 >conftest.in
256*6236dae4SAndroid Build Coastguard Worker    while :
257*6236dae4SAndroid Build Coastguard Worker    do
258*6236dae4SAndroid Build Coastguard Worker      cat conftest.in conftest.in >conftest.tmp
259*6236dae4SAndroid Build Coastguard Worker      mv conftest.tmp conftest.in
260*6236dae4SAndroid Build Coastguard Worker      cp conftest.in conftest.nl
261*6236dae4SAndroid Build Coastguard Worker      echo '' >> conftest.nl
262*6236dae4SAndroid Build Coastguard Worker      "$_G_path_prog" -f conftest.sed <conftest.nl >conftest.out 2>/dev/null || break
263*6236dae4SAndroid Build Coastguard Worker      diff conftest.out conftest.nl >/dev/null 2>&1 || break
264*6236dae4SAndroid Build Coastguard Worker      _G_count=`expr $_G_count + 1`
265*6236dae4SAndroid Build Coastguard Worker      if test "$_G_count" -gt "$_G_path_prog_max"; then
266*6236dae4SAndroid Build Coastguard Worker        # Best one so far, save it but keep looking for a better one
267*6236dae4SAndroid Build Coastguard Worker        func_check_prog_result=$_G_path_prog
268*6236dae4SAndroid Build Coastguard Worker        _G_path_prog_max=$_G_count
269*6236dae4SAndroid Build Coastguard Worker      fi
270*6236dae4SAndroid Build Coastguard Worker      # 10*(2^10) chars as input seems more than enough
271*6236dae4SAndroid Build Coastguard Worker      test 10 -lt "$_G_count" && break
272*6236dae4SAndroid Build Coastguard Worker    done
273*6236dae4SAndroid Build Coastguard Worker    rm -f conftest.in conftest.tmp conftest.nl conftest.out
274*6236dae4SAndroid Build Coastguard Worker  }
275*6236dae4SAndroid Build Coastguard Worker
276*6236dae4SAndroid Build Coastguard Worker  func_path_progs "sed gsed" func_check_prog_sed "$PATH:/usr/xpg4/bin"
277*6236dae4SAndroid Build Coastguard Worker  rm -f conftest.sed
278*6236dae4SAndroid Build Coastguard Worker  SED=$func_path_progs_result
279*6236dae4SAndroid Build Coastguard Worker}
280*6236dae4SAndroid Build Coastguard Worker
281*6236dae4SAndroid Build Coastguard Worker
282*6236dae4SAndroid Build Coastguard Worker# Unless the user overrides by setting GREP, search the path for either GNU
283*6236dae4SAndroid Build Coastguard Worker# grep, or the grep that truncates its output the least.
284*6236dae4SAndroid Build Coastguard Workertest -z "$GREP" && {
285*6236dae4SAndroid Build Coastguard Worker  func_check_prog_grep ()
286*6236dae4SAndroid Build Coastguard Worker  {
287*6236dae4SAndroid Build Coastguard Worker    _G_path_prog=$1
288*6236dae4SAndroid Build Coastguard Worker
289*6236dae4SAndroid Build Coastguard Worker    _G_count=0
290*6236dae4SAndroid Build Coastguard Worker    _G_path_prog_max=0
291*6236dae4SAndroid Build Coastguard Worker    printf 0123456789 >conftest.in
292*6236dae4SAndroid Build Coastguard Worker    while :
293*6236dae4SAndroid Build Coastguard Worker    do
294*6236dae4SAndroid Build Coastguard Worker      cat conftest.in conftest.in >conftest.tmp
295*6236dae4SAndroid Build Coastguard Worker      mv conftest.tmp conftest.in
296*6236dae4SAndroid Build Coastguard Worker      cp conftest.in conftest.nl
297*6236dae4SAndroid Build Coastguard Worker      echo 'GREP' >> conftest.nl
298*6236dae4SAndroid Build Coastguard Worker      "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' <conftest.nl >conftest.out 2>/dev/null || break
299*6236dae4SAndroid Build Coastguard Worker      diff conftest.out conftest.nl >/dev/null 2>&1 || break
300*6236dae4SAndroid Build Coastguard Worker      _G_count=`expr $_G_count + 1`
301*6236dae4SAndroid Build Coastguard Worker      if test "$_G_count" -gt "$_G_path_prog_max"; then
302*6236dae4SAndroid Build Coastguard Worker        # Best one so far, save it but keep looking for a better one
303*6236dae4SAndroid Build Coastguard Worker        func_check_prog_result=$_G_path_prog
304*6236dae4SAndroid Build Coastguard Worker        _G_path_prog_max=$_G_count
305*6236dae4SAndroid Build Coastguard Worker      fi
306*6236dae4SAndroid Build Coastguard Worker      # 10*(2^10) chars as input seems more than enough
307*6236dae4SAndroid Build Coastguard Worker      test 10 -lt "$_G_count" && break
308*6236dae4SAndroid Build Coastguard Worker    done
309*6236dae4SAndroid Build Coastguard Worker    rm -f conftest.in conftest.tmp conftest.nl conftest.out
310*6236dae4SAndroid Build Coastguard Worker  }
311*6236dae4SAndroid Build Coastguard Worker
312*6236dae4SAndroid Build Coastguard Worker  func_path_progs "grep ggrep" func_check_prog_grep "$PATH:/usr/xpg4/bin"
313*6236dae4SAndroid Build Coastguard Worker  GREP=$func_path_progs_result
314*6236dae4SAndroid Build Coastguard Worker}
315*6236dae4SAndroid Build Coastguard Worker
316*6236dae4SAndroid Build Coastguard Worker
317*6236dae4SAndroid Build Coastguard Worker## ------------------------------- ##
318*6236dae4SAndroid Build Coastguard Worker## User overridable command paths. ##
319*6236dae4SAndroid Build Coastguard Worker## ------------------------------- ##
320*6236dae4SAndroid Build Coastguard Worker
321*6236dae4SAndroid Build Coastguard Worker# All uppercase variable names are used for environment variables.  These
322*6236dae4SAndroid Build Coastguard Worker# variables can be overridden by the user before calling a script that
323*6236dae4SAndroid Build Coastguard Worker# uses them if a suitable command of that name is not already available
324*6236dae4SAndroid Build Coastguard Worker# in the command search PATH.
325*6236dae4SAndroid Build Coastguard Worker
326*6236dae4SAndroid Build Coastguard Worker: ${CP="cp -f"}
327*6236dae4SAndroid Build Coastguard Worker: ${ECHO="printf %s\n"}
328*6236dae4SAndroid Build Coastguard Worker: ${EGREP="$GREP -E"}
329*6236dae4SAndroid Build Coastguard Worker: ${FGREP="$GREP -F"}
330*6236dae4SAndroid Build Coastguard Worker: ${LN_S="ln -s"}
331*6236dae4SAndroid Build Coastguard Worker: ${MAKE="make"}
332*6236dae4SAndroid Build Coastguard Worker: ${MKDIR="mkdir"}
333*6236dae4SAndroid Build Coastguard Worker: ${MV="mv -f"}
334*6236dae4SAndroid Build Coastguard Worker: ${RM="rm -f"}
335*6236dae4SAndroid Build Coastguard Worker: ${SHELL="${CONFIG_SHELL-/bin/sh}"}
336*6236dae4SAndroid Build Coastguard Worker
337*6236dae4SAndroid Build Coastguard Worker
338*6236dae4SAndroid Build Coastguard Worker## -------------------- ##
339*6236dae4SAndroid Build Coastguard Worker## Useful sed snippets. ##
340*6236dae4SAndroid Build Coastguard Worker## -------------------- ##
341*6236dae4SAndroid Build Coastguard Worker
342*6236dae4SAndroid Build Coastguard Workersed_dirname='s|/[^/]*$||'
343*6236dae4SAndroid Build Coastguard Workersed_basename='s|^.*/||'
344*6236dae4SAndroid Build Coastguard Worker
345*6236dae4SAndroid Build Coastguard Worker# Sed substitution that helps us do robust quoting.  It backslashifies
346*6236dae4SAndroid Build Coastguard Worker# metacharacters that are still active within double-quoted strings.
347*6236dae4SAndroid Build Coastguard Workersed_quote_subst='s|\([`"$\\]\)|\\\1|g'
348*6236dae4SAndroid Build Coastguard Worker
349*6236dae4SAndroid Build Coastguard Worker# Same as above, but do not quote variable references.
350*6236dae4SAndroid Build Coastguard Workersed_double_quote_subst='s/\(["`\\]\)/\\\1/g'
351*6236dae4SAndroid Build Coastguard Worker
352*6236dae4SAndroid Build Coastguard Worker# Sed substitution that turns a string into a regex matching for the
353*6236dae4SAndroid Build Coastguard Worker# string literally.
354*6236dae4SAndroid Build Coastguard Workersed_make_literal_regex='s|[].[^$\\*\/]|\\&|g'
355*6236dae4SAndroid Build Coastguard Worker
356*6236dae4SAndroid Build Coastguard Worker# Sed substitution that converts a w32 file name or path
357*6236dae4SAndroid Build Coastguard Worker# that contains forward slashes, into one that contains
358*6236dae4SAndroid Build Coastguard Worker# (escaped) backslashes.  A very naive implementation.
359*6236dae4SAndroid Build Coastguard Workersed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
360*6236dae4SAndroid Build Coastguard Worker
361*6236dae4SAndroid Build Coastguard Worker# Re-'\' parameter expansions in output of sed_double_quote_subst that
362*6236dae4SAndroid Build Coastguard Worker# were '\'-ed in input to the same.  If an odd number of '\' preceded a
363*6236dae4SAndroid Build Coastguard Worker# '$' in input to sed_double_quote_subst, that '$' was protected from
364*6236dae4SAndroid Build Coastguard Worker# expansion.  Since each input '\' is now two '\'s, look for any number
365*6236dae4SAndroid Build Coastguard Worker# of runs of four '\'s followed by two '\'s and then a '$'.  '\' that '$'.
366*6236dae4SAndroid Build Coastguard Worker_G_bs='\\'
367*6236dae4SAndroid Build Coastguard Worker_G_bs2='\\\\'
368*6236dae4SAndroid Build Coastguard Worker_G_bs4='\\\\\\\\'
369*6236dae4SAndroid Build Coastguard Worker_G_dollar='\$'
370*6236dae4SAndroid Build Coastguard Workersed_double_backslash="\
371*6236dae4SAndroid Build Coastguard Worker  s/$_G_bs4/&\\
372*6236dae4SAndroid Build Coastguard Worker/g
373*6236dae4SAndroid Build Coastguard Worker  s/^$_G_bs2$_G_dollar/$_G_bs&/
374*6236dae4SAndroid Build Coastguard Worker  s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g
375*6236dae4SAndroid Build Coastguard Worker  s/\n//g"
376*6236dae4SAndroid Build Coastguard Worker
377*6236dae4SAndroid Build Coastguard Worker# require_check_ifs_backslash
378*6236dae4SAndroid Build Coastguard Worker# ---------------------------
379*6236dae4SAndroid Build Coastguard Worker# Check if we can use backslash as IFS='\' separator, and set
380*6236dae4SAndroid Build Coastguard Worker# $check_ifs_backshlash_broken to ':' or 'false'.
381*6236dae4SAndroid Build Coastguard Workerrequire_check_ifs_backslash=func_require_check_ifs_backslash
382*6236dae4SAndroid Build Coastguard Workerfunc_require_check_ifs_backslash ()
383*6236dae4SAndroid Build Coastguard Worker{
384*6236dae4SAndroid Build Coastguard Worker  _G_save_IFS=$IFS
385*6236dae4SAndroid Build Coastguard Worker  IFS='\'
386*6236dae4SAndroid Build Coastguard Worker  _G_check_ifs_backshlash='a\\b'
387*6236dae4SAndroid Build Coastguard Worker  for _G_i in $_G_check_ifs_backshlash
388*6236dae4SAndroid Build Coastguard Worker  do
389*6236dae4SAndroid Build Coastguard Worker  case $_G_i in
390*6236dae4SAndroid Build Coastguard Worker  a)
391*6236dae4SAndroid Build Coastguard Worker    check_ifs_backshlash_broken=false
392*6236dae4SAndroid Build Coastguard Worker    ;;
393*6236dae4SAndroid Build Coastguard Worker  '')
394*6236dae4SAndroid Build Coastguard Worker    break
395*6236dae4SAndroid Build Coastguard Worker    ;;
396*6236dae4SAndroid Build Coastguard Worker  *)
397*6236dae4SAndroid Build Coastguard Worker    check_ifs_backshlash_broken=:
398*6236dae4SAndroid Build Coastguard Worker    break
399*6236dae4SAndroid Build Coastguard Worker    ;;
400*6236dae4SAndroid Build Coastguard Worker  esac
401*6236dae4SAndroid Build Coastguard Worker  done
402*6236dae4SAndroid Build Coastguard Worker  IFS=$_G_save_IFS
403*6236dae4SAndroid Build Coastguard Worker  require_check_ifs_backslash=:
404*6236dae4SAndroid Build Coastguard Worker}
405*6236dae4SAndroid Build Coastguard Worker
406*6236dae4SAndroid Build Coastguard Worker
407*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
408*6236dae4SAndroid Build Coastguard Worker## Global variables. ##
409*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
410*6236dae4SAndroid Build Coastguard Worker
411*6236dae4SAndroid Build Coastguard Worker# Except for the global variables explicitly listed below, the following
412*6236dae4SAndroid Build Coastguard Worker# functions in the '^func_' namespace, and the '^require_' namespace
413*6236dae4SAndroid Build Coastguard Worker# variables initialised in the 'Resource management' section, sourcing
414*6236dae4SAndroid Build Coastguard Worker# this file will not pollute your global namespace with anything
415*6236dae4SAndroid Build Coastguard Worker# else. There's no portable way to scope variables in Bourne shell
416*6236dae4SAndroid Build Coastguard Worker# though, so actually running these functions will sometimes place
417*6236dae4SAndroid Build Coastguard Worker# results into a variable named after the function, and often use
418*6236dae4SAndroid Build Coastguard Worker# temporary variables in the '^_G_' namespace. If you are careful to
419*6236dae4SAndroid Build Coastguard Worker# avoid using those namespaces casually in your sourcing script, things
420*6236dae4SAndroid Build Coastguard Worker# should continue to work as you expect. And, of course, you can freely
421*6236dae4SAndroid Build Coastguard Worker# overwrite any of the functions or variables defined here before
422*6236dae4SAndroid Build Coastguard Worker# calling anything to customize them.
423*6236dae4SAndroid Build Coastguard Worker
424*6236dae4SAndroid Build Coastguard WorkerEXIT_SUCCESS=0
425*6236dae4SAndroid Build Coastguard WorkerEXIT_FAILURE=1
426*6236dae4SAndroid Build Coastguard WorkerEXIT_MISMATCH=63  # $? = 63 is used to indicate version mismatch to missing.
427*6236dae4SAndroid Build Coastguard WorkerEXIT_SKIP=77	  # $? = 77 is used to indicate a skipped test to automake.
428*6236dae4SAndroid Build Coastguard Worker
429*6236dae4SAndroid Build Coastguard Worker# Allow overriding, eg assuming that you follow the convention of
430*6236dae4SAndroid Build Coastguard Worker# putting '$debug_cmd' at the start of all your functions, you can get
431*6236dae4SAndroid Build Coastguard Worker# bash to show function call trace with:
432*6236dae4SAndroid Build Coastguard Worker#
433*6236dae4SAndroid Build Coastguard Worker#    debug_cmd='echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
434*6236dae4SAndroid Build Coastguard Workerdebug_cmd=${debug_cmd-":"}
435*6236dae4SAndroid Build Coastguard Workerexit_cmd=:
436*6236dae4SAndroid Build Coastguard Worker
437*6236dae4SAndroid Build Coastguard Worker# By convention, finish your script with:
438*6236dae4SAndroid Build Coastguard Worker#
439*6236dae4SAndroid Build Coastguard Worker#    exit $exit_status
440*6236dae4SAndroid Build Coastguard Worker#
441*6236dae4SAndroid Build Coastguard Worker# so that you can set exit_status to non-zero if you want to indicate
442*6236dae4SAndroid Build Coastguard Worker# something went wrong during execution without actually bailing out at
443*6236dae4SAndroid Build Coastguard Worker# the point of failure.
444*6236dae4SAndroid Build Coastguard Workerexit_status=$EXIT_SUCCESS
445*6236dae4SAndroid Build Coastguard Worker
446*6236dae4SAndroid Build Coastguard Worker# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
447*6236dae4SAndroid Build Coastguard Worker# is ksh but when the shell is invoked as "sh" and the current value of
448*6236dae4SAndroid Build Coastguard Worker# the _XPG environment variable is not equal to 1 (one), the special
449*6236dae4SAndroid Build Coastguard Worker# positional parameter $0, within a function call, is the name of the
450*6236dae4SAndroid Build Coastguard Worker# function.
451*6236dae4SAndroid Build Coastguard Workerprogpath=$0
452*6236dae4SAndroid Build Coastguard Worker
453*6236dae4SAndroid Build Coastguard Worker# The name of this program.
454*6236dae4SAndroid Build Coastguard Workerprogname=`$ECHO "$progpath" |$SED "$sed_basename"`
455*6236dae4SAndroid Build Coastguard Worker
456*6236dae4SAndroid Build Coastguard Worker# Make sure we have an absolute progpath for reexecution:
457*6236dae4SAndroid Build Coastguard Workercase $progpath in
458*6236dae4SAndroid Build Coastguard Worker  [\\/]*|[A-Za-z]:\\*) ;;
459*6236dae4SAndroid Build Coastguard Worker  *[\\/]*)
460*6236dae4SAndroid Build Coastguard Worker     progdir=`$ECHO "$progpath" |$SED "$sed_dirname"`
461*6236dae4SAndroid Build Coastguard Worker     progdir=`cd "$progdir" && pwd`
462*6236dae4SAndroid Build Coastguard Worker     progpath=$progdir/$progname
463*6236dae4SAndroid Build Coastguard Worker     ;;
464*6236dae4SAndroid Build Coastguard Worker  *)
465*6236dae4SAndroid Build Coastguard Worker     _G_IFS=$IFS
466*6236dae4SAndroid Build Coastguard Worker     IFS=${PATH_SEPARATOR-:}
467*6236dae4SAndroid Build Coastguard Worker     for progdir in $PATH; do
468*6236dae4SAndroid Build Coastguard Worker       IFS=$_G_IFS
469*6236dae4SAndroid Build Coastguard Worker       test -x "$progdir/$progname" && break
470*6236dae4SAndroid Build Coastguard Worker     done
471*6236dae4SAndroid Build Coastguard Worker     IFS=$_G_IFS
472*6236dae4SAndroid Build Coastguard Worker     test -n "$progdir" || progdir=`pwd`
473*6236dae4SAndroid Build Coastguard Worker     progpath=$progdir/$progname
474*6236dae4SAndroid Build Coastguard Worker     ;;
475*6236dae4SAndroid Build Coastguard Workeresac
476*6236dae4SAndroid Build Coastguard Worker
477*6236dae4SAndroid Build Coastguard Worker
478*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
479*6236dae4SAndroid Build Coastguard Worker## Standard options. ##
480*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
481*6236dae4SAndroid Build Coastguard Worker
482*6236dae4SAndroid Build Coastguard Worker# The following options affect the operation of the functions defined
483*6236dae4SAndroid Build Coastguard Worker# below, and should be set appropriately depending on run-time para-
484*6236dae4SAndroid Build Coastguard Worker# meters passed on the command line.
485*6236dae4SAndroid Build Coastguard Worker
486*6236dae4SAndroid Build Coastguard Workeropt_dry_run=false
487*6236dae4SAndroid Build Coastguard Workeropt_quiet=false
488*6236dae4SAndroid Build Coastguard Workeropt_verbose=false
489*6236dae4SAndroid Build Coastguard Worker
490*6236dae4SAndroid Build Coastguard Worker# Categories 'all' and 'none' are always available.  Append any others
491*6236dae4SAndroid Build Coastguard Worker# you will pass as the first argument to func_warning from your own
492*6236dae4SAndroid Build Coastguard Worker# code.
493*6236dae4SAndroid Build Coastguard Workerwarning_categories=
494*6236dae4SAndroid Build Coastguard Worker
495*6236dae4SAndroid Build Coastguard Worker# By default, display warnings according to 'opt_warning_types'.  Set
496*6236dae4SAndroid Build Coastguard Worker# 'warning_func'  to ':' to elide all warnings, or func_fatal_error to
497*6236dae4SAndroid Build Coastguard Worker# treat the next displayed warning as a fatal error.
498*6236dae4SAndroid Build Coastguard Workerwarning_func=func_warn_and_continue
499*6236dae4SAndroid Build Coastguard Worker
500*6236dae4SAndroid Build Coastguard Worker# Set to 'all' to display all warnings, 'none' to suppress all
501*6236dae4SAndroid Build Coastguard Worker# warnings, or a space delimited list of some subset of
502*6236dae4SAndroid Build Coastguard Worker# 'warning_categories' to display only the listed warnings.
503*6236dae4SAndroid Build Coastguard Workeropt_warning_types=all
504*6236dae4SAndroid Build Coastguard Worker
505*6236dae4SAndroid Build Coastguard Worker
506*6236dae4SAndroid Build Coastguard Worker## -------------------- ##
507*6236dae4SAndroid Build Coastguard Worker## Resource management. ##
508*6236dae4SAndroid Build Coastguard Worker## -------------------- ##
509*6236dae4SAndroid Build Coastguard Worker
510*6236dae4SAndroid Build Coastguard Worker# This section contains definitions for functions that each ensure a
511*6236dae4SAndroid Build Coastguard Worker# particular resource (a file, or a non-empty configuration variable for
512*6236dae4SAndroid Build Coastguard Worker# example) is available, and if appropriate to extract default values
513*6236dae4SAndroid Build Coastguard Worker# from pertinent package files. Call them using their associated
514*6236dae4SAndroid Build Coastguard Worker# 'require_*' variable to ensure that they are executed, at most, once.
515*6236dae4SAndroid Build Coastguard Worker#
516*6236dae4SAndroid Build Coastguard Worker# It's entirely deliberate that calling these functions can set
517*6236dae4SAndroid Build Coastguard Worker# variables that don't obey the namespace limitations obeyed by the rest
518*6236dae4SAndroid Build Coastguard Worker# of this file, in order that that they be as useful as possible to
519*6236dae4SAndroid Build Coastguard Worker# callers.
520*6236dae4SAndroid Build Coastguard Worker
521*6236dae4SAndroid Build Coastguard Worker
522*6236dae4SAndroid Build Coastguard Worker# require_term_colors
523*6236dae4SAndroid Build Coastguard Worker# -------------------
524*6236dae4SAndroid Build Coastguard Worker# Allow display of bold text on terminals that support it.
525*6236dae4SAndroid Build Coastguard Workerrequire_term_colors=func_require_term_colors
526*6236dae4SAndroid Build Coastguard Workerfunc_require_term_colors ()
527*6236dae4SAndroid Build Coastguard Worker{
528*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
529*6236dae4SAndroid Build Coastguard Worker
530*6236dae4SAndroid Build Coastguard Worker    test -t 1 && {
531*6236dae4SAndroid Build Coastguard Worker      # COLORTERM and USE_ANSI_COLORS environment variables take
532*6236dae4SAndroid Build Coastguard Worker      # precedence, because most terminfo databases neglect to describe
533*6236dae4SAndroid Build Coastguard Worker      # whether color sequences are supported.
534*6236dae4SAndroid Build Coastguard Worker      test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"}
535*6236dae4SAndroid Build Coastguard Worker
536*6236dae4SAndroid Build Coastguard Worker      if test 1 = "$USE_ANSI_COLORS"; then
537*6236dae4SAndroid Build Coastguard Worker        # Standard ANSI escape sequences
538*6236dae4SAndroid Build Coastguard Worker        tc_reset=''
539*6236dae4SAndroid Build Coastguard Worker        tc_bold='';   tc_standout=''
540*6236dae4SAndroid Build Coastguard Worker        tc_red='';   tc_green=''
541*6236dae4SAndroid Build Coastguard Worker        tc_blue='';  tc_cyan=''
542*6236dae4SAndroid Build Coastguard Worker      else
543*6236dae4SAndroid Build Coastguard Worker        # Otherwise trust the terminfo database after all.
544*6236dae4SAndroid Build Coastguard Worker        test -n "`tput sgr0 2>/dev/null`" && {
545*6236dae4SAndroid Build Coastguard Worker          tc_reset=`tput sgr0`
546*6236dae4SAndroid Build Coastguard Worker          test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold`
547*6236dae4SAndroid Build Coastguard Worker          tc_standout=$tc_bold
548*6236dae4SAndroid Build Coastguard Worker          test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso`
549*6236dae4SAndroid Build Coastguard Worker          test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1`
550*6236dae4SAndroid Build Coastguard Worker          test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2`
551*6236dae4SAndroid Build Coastguard Worker          test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4`
552*6236dae4SAndroid Build Coastguard Worker          test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5`
553*6236dae4SAndroid Build Coastguard Worker        }
554*6236dae4SAndroid Build Coastguard Worker      fi
555*6236dae4SAndroid Build Coastguard Worker    }
556*6236dae4SAndroid Build Coastguard Worker
557*6236dae4SAndroid Build Coastguard Worker    require_term_colors=:
558*6236dae4SAndroid Build Coastguard Worker}
559*6236dae4SAndroid Build Coastguard Worker
560*6236dae4SAndroid Build Coastguard Worker
561*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
562*6236dae4SAndroid Build Coastguard Worker## Function library. ##
563*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
564*6236dae4SAndroid Build Coastguard Worker
565*6236dae4SAndroid Build Coastguard Worker# This section contains a variety of useful functions to call in your
566*6236dae4SAndroid Build Coastguard Worker# scripts. Take note of the portable wrappers for features provided by
567*6236dae4SAndroid Build Coastguard Worker# some modern shells, which will fall back to slower equivalents on
568*6236dae4SAndroid Build Coastguard Worker# less featureful shells.
569*6236dae4SAndroid Build Coastguard Worker
570*6236dae4SAndroid Build Coastguard Worker
571*6236dae4SAndroid Build Coastguard Worker# func_append VAR VALUE
572*6236dae4SAndroid Build Coastguard Worker# ---------------------
573*6236dae4SAndroid Build Coastguard Worker# Append VALUE onto the existing contents of VAR.
574*6236dae4SAndroid Build Coastguard Worker
575*6236dae4SAndroid Build Coastguard Worker  # _G_HAVE_PLUSEQ_OP
576*6236dae4SAndroid Build Coastguard Worker  # Can be empty, in which case the shell is probed, "yes" if += is
577*6236dae4SAndroid Build Coastguard Worker  # useable or anything else if it does not work.
578*6236dae4SAndroid Build Coastguard Worker  if test -z "$_G_HAVE_PLUSEQ_OP" &&  \
579*6236dae4SAndroid Build Coastguard Worker      __PLUSEQ_TEST="a" &&  \
580*6236dae4SAndroid Build Coastguard Worker      __PLUSEQ_TEST+=" b" 2>/dev/null &&  \
581*6236dae4SAndroid Build Coastguard Worker      test "a b" = "$__PLUSEQ_TEST"; then
582*6236dae4SAndroid Build Coastguard Worker    _G_HAVE_PLUSEQ_OP=yes
583*6236dae4SAndroid Build Coastguard Worker  fi
584*6236dae4SAndroid Build Coastguard Worker
585*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_PLUSEQ_OP"
586*6236dae4SAndroid Build Coastguard Workerthen
587*6236dae4SAndroid Build Coastguard Worker  # This is an XSI compatible shell, allowing a faster implementation...
588*6236dae4SAndroid Build Coastguard Worker  eval 'func_append ()
589*6236dae4SAndroid Build Coastguard Worker  {
590*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
591*6236dae4SAndroid Build Coastguard Worker
592*6236dae4SAndroid Build Coastguard Worker    eval "$1+=\$2"
593*6236dae4SAndroid Build Coastguard Worker  }'
594*6236dae4SAndroid Build Coastguard Workerelse
595*6236dae4SAndroid Build Coastguard Worker  # ...otherwise fall back to using expr, which is often a shell builtin.
596*6236dae4SAndroid Build Coastguard Worker  func_append ()
597*6236dae4SAndroid Build Coastguard Worker  {
598*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
599*6236dae4SAndroid Build Coastguard Worker
600*6236dae4SAndroid Build Coastguard Worker    eval "$1=\$$1\$2"
601*6236dae4SAndroid Build Coastguard Worker  }
602*6236dae4SAndroid Build Coastguard Workerfi
603*6236dae4SAndroid Build Coastguard Worker
604*6236dae4SAndroid Build Coastguard Worker
605*6236dae4SAndroid Build Coastguard Worker# func_append_quoted VAR VALUE
606*6236dae4SAndroid Build Coastguard Worker# ----------------------------
607*6236dae4SAndroid Build Coastguard Worker# Quote VALUE and append to the end of shell variable VAR, separated
608*6236dae4SAndroid Build Coastguard Worker# by a space.
609*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_PLUSEQ_OP"; then
610*6236dae4SAndroid Build Coastguard Worker  eval 'func_append_quoted ()
611*6236dae4SAndroid Build Coastguard Worker  {
612*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
613*6236dae4SAndroid Build Coastguard Worker
614*6236dae4SAndroid Build Coastguard Worker    func_quote_arg pretty "$2"
615*6236dae4SAndroid Build Coastguard Worker    eval "$1+=\\ \$func_quote_arg_result"
616*6236dae4SAndroid Build Coastguard Worker  }'
617*6236dae4SAndroid Build Coastguard Workerelse
618*6236dae4SAndroid Build Coastguard Worker  func_append_quoted ()
619*6236dae4SAndroid Build Coastguard Worker  {
620*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
621*6236dae4SAndroid Build Coastguard Worker
622*6236dae4SAndroid Build Coastguard Worker    func_quote_arg pretty "$2"
623*6236dae4SAndroid Build Coastguard Worker    eval "$1=\$$1\\ \$func_quote_arg_result"
624*6236dae4SAndroid Build Coastguard Worker  }
625*6236dae4SAndroid Build Coastguard Workerfi
626*6236dae4SAndroid Build Coastguard Worker
627*6236dae4SAndroid Build Coastguard Worker
628*6236dae4SAndroid Build Coastguard Worker# func_append_uniq VAR VALUE
629*6236dae4SAndroid Build Coastguard Worker# --------------------------
630*6236dae4SAndroid Build Coastguard Worker# Append unique VALUE onto the existing contents of VAR, assuming
631*6236dae4SAndroid Build Coastguard Worker# entries are delimited by the first character of VALUE.  For example:
632*6236dae4SAndroid Build Coastguard Worker#
633*6236dae4SAndroid Build Coastguard Worker#   func_append_uniq options " --another-option option-argument"
634*6236dae4SAndroid Build Coastguard Worker#
635*6236dae4SAndroid Build Coastguard Worker# will only append to $options if " --another-option option-argument "
636*6236dae4SAndroid Build Coastguard Worker# is not already present somewhere in $options already (note spaces at
637*6236dae4SAndroid Build Coastguard Worker# each end implied by leading space in second argument).
638*6236dae4SAndroid Build Coastguard Workerfunc_append_uniq ()
639*6236dae4SAndroid Build Coastguard Worker{
640*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
641*6236dae4SAndroid Build Coastguard Worker
642*6236dae4SAndroid Build Coastguard Worker    eval _G_current_value='`$ECHO $'$1'`'
643*6236dae4SAndroid Build Coastguard Worker    _G_delim=`expr "$2" : '\(.\)'`
644*6236dae4SAndroid Build Coastguard Worker
645*6236dae4SAndroid Build Coastguard Worker    case $_G_delim$_G_current_value$_G_delim in
646*6236dae4SAndroid Build Coastguard Worker      *"$2$_G_delim"*) ;;
647*6236dae4SAndroid Build Coastguard Worker      *) func_append "$@" ;;
648*6236dae4SAndroid Build Coastguard Worker    esac
649*6236dae4SAndroid Build Coastguard Worker}
650*6236dae4SAndroid Build Coastguard Worker
651*6236dae4SAndroid Build Coastguard Worker
652*6236dae4SAndroid Build Coastguard Worker# func_arith TERM...
653*6236dae4SAndroid Build Coastguard Worker# ------------------
654*6236dae4SAndroid Build Coastguard Worker# Set func_arith_result to the result of evaluating TERMs.
655*6236dae4SAndroid Build Coastguard Worker  test -z "$_G_HAVE_ARITH_OP" \
656*6236dae4SAndroid Build Coastguard Worker    && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \
657*6236dae4SAndroid Build Coastguard Worker    && _G_HAVE_ARITH_OP=yes
658*6236dae4SAndroid Build Coastguard Worker
659*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_ARITH_OP"; then
660*6236dae4SAndroid Build Coastguard Worker  eval 'func_arith ()
661*6236dae4SAndroid Build Coastguard Worker  {
662*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
663*6236dae4SAndroid Build Coastguard Worker
664*6236dae4SAndroid Build Coastguard Worker    func_arith_result=$(( $* ))
665*6236dae4SAndroid Build Coastguard Worker  }'
666*6236dae4SAndroid Build Coastguard Workerelse
667*6236dae4SAndroid Build Coastguard Worker  func_arith ()
668*6236dae4SAndroid Build Coastguard Worker  {
669*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
670*6236dae4SAndroid Build Coastguard Worker
671*6236dae4SAndroid Build Coastguard Worker    func_arith_result=`expr "$@"`
672*6236dae4SAndroid Build Coastguard Worker  }
673*6236dae4SAndroid Build Coastguard Workerfi
674*6236dae4SAndroid Build Coastguard Worker
675*6236dae4SAndroid Build Coastguard Worker
676*6236dae4SAndroid Build Coastguard Worker# func_basename FILE
677*6236dae4SAndroid Build Coastguard Worker# ------------------
678*6236dae4SAndroid Build Coastguard Worker# Set func_basename_result to FILE with everything up to and including
679*6236dae4SAndroid Build Coastguard Worker# the last / stripped.
680*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_XSI_OPS"; then
681*6236dae4SAndroid Build Coastguard Worker  # If this shell supports suffix pattern removal, then use it to avoid
682*6236dae4SAndroid Build Coastguard Worker  # forking. Hide the definitions single quotes in case the shell chokes
683*6236dae4SAndroid Build Coastguard Worker  # on unsupported syntax...
684*6236dae4SAndroid Build Coastguard Worker  _b='func_basename_result=${1##*/}'
685*6236dae4SAndroid Build Coastguard Worker  _d='case $1 in
686*6236dae4SAndroid Build Coastguard Worker        */*) func_dirname_result=${1%/*}$2 ;;
687*6236dae4SAndroid Build Coastguard Worker        *  ) func_dirname_result=$3        ;;
688*6236dae4SAndroid Build Coastguard Worker      esac'
689*6236dae4SAndroid Build Coastguard Worker
690*6236dae4SAndroid Build Coastguard Workerelse
691*6236dae4SAndroid Build Coastguard Worker  # ...otherwise fall back to using sed.
692*6236dae4SAndroid Build Coastguard Worker  _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`'
693*6236dae4SAndroid Build Coastguard Worker  _d='func_dirname_result=`$ECHO "$1"  |$SED "$sed_dirname"`
694*6236dae4SAndroid Build Coastguard Worker      if test "X$func_dirname_result" = "X$1"; then
695*6236dae4SAndroid Build Coastguard Worker        func_dirname_result=$3
696*6236dae4SAndroid Build Coastguard Worker      else
697*6236dae4SAndroid Build Coastguard Worker        func_append func_dirname_result "$2"
698*6236dae4SAndroid Build Coastguard Worker      fi'
699*6236dae4SAndroid Build Coastguard Workerfi
700*6236dae4SAndroid Build Coastguard Worker
701*6236dae4SAndroid Build Coastguard Workereval 'func_basename ()
702*6236dae4SAndroid Build Coastguard Worker{
703*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
704*6236dae4SAndroid Build Coastguard Worker
705*6236dae4SAndroid Build Coastguard Worker    '"$_b"'
706*6236dae4SAndroid Build Coastguard Worker}'
707*6236dae4SAndroid Build Coastguard Worker
708*6236dae4SAndroid Build Coastguard Worker
709*6236dae4SAndroid Build Coastguard Worker# func_dirname FILE APPEND NONDIR_REPLACEMENT
710*6236dae4SAndroid Build Coastguard Worker# -------------------------------------------
711*6236dae4SAndroid Build Coastguard Worker# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
712*6236dae4SAndroid Build Coastguard Worker# otherwise set result to NONDIR_REPLACEMENT.
713*6236dae4SAndroid Build Coastguard Workereval 'func_dirname ()
714*6236dae4SAndroid Build Coastguard Worker{
715*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
716*6236dae4SAndroid Build Coastguard Worker
717*6236dae4SAndroid Build Coastguard Worker    '"$_d"'
718*6236dae4SAndroid Build Coastguard Worker}'
719*6236dae4SAndroid Build Coastguard Worker
720*6236dae4SAndroid Build Coastguard Worker
721*6236dae4SAndroid Build Coastguard Worker# func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT
722*6236dae4SAndroid Build Coastguard Worker# --------------------------------------------------------
723*6236dae4SAndroid Build Coastguard Worker# Perform func_basename and func_dirname in a single function
724*6236dae4SAndroid Build Coastguard Worker# call:
725*6236dae4SAndroid Build Coastguard Worker#   dirname:  Compute the dirname of FILE.  If nonempty,
726*6236dae4SAndroid Build Coastguard Worker#             add APPEND to the result, otherwise set result
727*6236dae4SAndroid Build Coastguard Worker#             to NONDIR_REPLACEMENT.
728*6236dae4SAndroid Build Coastguard Worker#             value returned in "$func_dirname_result"
729*6236dae4SAndroid Build Coastguard Worker#   basename: Compute filename of FILE.
730*6236dae4SAndroid Build Coastguard Worker#             value retuned in "$func_basename_result"
731*6236dae4SAndroid Build Coastguard Worker# For efficiency, we do not delegate to the functions above but instead
732*6236dae4SAndroid Build Coastguard Worker# duplicate the functionality here.
733*6236dae4SAndroid Build Coastguard Workereval 'func_dirname_and_basename ()
734*6236dae4SAndroid Build Coastguard Worker{
735*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
736*6236dae4SAndroid Build Coastguard Worker
737*6236dae4SAndroid Build Coastguard Worker    '"$_b"'
738*6236dae4SAndroid Build Coastguard Worker    '"$_d"'
739*6236dae4SAndroid Build Coastguard Worker}'
740*6236dae4SAndroid Build Coastguard Worker
741*6236dae4SAndroid Build Coastguard Worker
742*6236dae4SAndroid Build Coastguard Worker# func_echo ARG...
743*6236dae4SAndroid Build Coastguard Worker# ----------------
744*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message.
745*6236dae4SAndroid Build Coastguard Workerfunc_echo ()
746*6236dae4SAndroid Build Coastguard Worker{
747*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
748*6236dae4SAndroid Build Coastguard Worker
749*6236dae4SAndroid Build Coastguard Worker    _G_message=$*
750*6236dae4SAndroid Build Coastguard Worker
751*6236dae4SAndroid Build Coastguard Worker    func_echo_IFS=$IFS
752*6236dae4SAndroid Build Coastguard Worker    IFS=$nl
753*6236dae4SAndroid Build Coastguard Worker    for _G_line in $_G_message; do
754*6236dae4SAndroid Build Coastguard Worker      IFS=$func_echo_IFS
755*6236dae4SAndroid Build Coastguard Worker      $ECHO "$progname: $_G_line"
756*6236dae4SAndroid Build Coastguard Worker    done
757*6236dae4SAndroid Build Coastguard Worker    IFS=$func_echo_IFS
758*6236dae4SAndroid Build Coastguard Worker}
759*6236dae4SAndroid Build Coastguard Worker
760*6236dae4SAndroid Build Coastguard Worker
761*6236dae4SAndroid Build Coastguard Worker# func_echo_all ARG...
762*6236dae4SAndroid Build Coastguard Worker# --------------------
763*6236dae4SAndroid Build Coastguard Worker# Invoke $ECHO with all args, space-separated.
764*6236dae4SAndroid Build Coastguard Workerfunc_echo_all ()
765*6236dae4SAndroid Build Coastguard Worker{
766*6236dae4SAndroid Build Coastguard Worker    $ECHO "$*"
767*6236dae4SAndroid Build Coastguard Worker}
768*6236dae4SAndroid Build Coastguard Worker
769*6236dae4SAndroid Build Coastguard Worker
770*6236dae4SAndroid Build Coastguard Worker# func_echo_infix_1 INFIX ARG...
771*6236dae4SAndroid Build Coastguard Worker# ------------------------------
772*6236dae4SAndroid Build Coastguard Worker# Echo program name, followed by INFIX on the first line, with any
773*6236dae4SAndroid Build Coastguard Worker# additional lines not showing INFIX.
774*6236dae4SAndroid Build Coastguard Workerfunc_echo_infix_1 ()
775*6236dae4SAndroid Build Coastguard Worker{
776*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
777*6236dae4SAndroid Build Coastguard Worker
778*6236dae4SAndroid Build Coastguard Worker    $require_term_colors
779*6236dae4SAndroid Build Coastguard Worker
780*6236dae4SAndroid Build Coastguard Worker    _G_infix=$1; shift
781*6236dae4SAndroid Build Coastguard Worker    _G_indent=$_G_infix
782*6236dae4SAndroid Build Coastguard Worker    _G_prefix="$progname: $_G_infix: "
783*6236dae4SAndroid Build Coastguard Worker    _G_message=$*
784*6236dae4SAndroid Build Coastguard Worker
785*6236dae4SAndroid Build Coastguard Worker    # Strip color escape sequences before counting printable length
786*6236dae4SAndroid Build Coastguard Worker    for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan"
787*6236dae4SAndroid Build Coastguard Worker    do
788*6236dae4SAndroid Build Coastguard Worker      test -n "$_G_tc" && {
789*6236dae4SAndroid Build Coastguard Worker        _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"`
790*6236dae4SAndroid Build Coastguard Worker        _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"`
791*6236dae4SAndroid Build Coastguard Worker      }
792*6236dae4SAndroid Build Coastguard Worker    done
793*6236dae4SAndroid Build Coastguard Worker    _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`"  " ## exclude from sc_prohibit_nested_quotes
794*6236dae4SAndroid Build Coastguard Worker
795*6236dae4SAndroid Build Coastguard Worker    func_echo_infix_1_IFS=$IFS
796*6236dae4SAndroid Build Coastguard Worker    IFS=$nl
797*6236dae4SAndroid Build Coastguard Worker    for _G_line in $_G_message; do
798*6236dae4SAndroid Build Coastguard Worker      IFS=$func_echo_infix_1_IFS
799*6236dae4SAndroid Build Coastguard Worker      $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2
800*6236dae4SAndroid Build Coastguard Worker      _G_prefix=$_G_indent
801*6236dae4SAndroid Build Coastguard Worker    done
802*6236dae4SAndroid Build Coastguard Worker    IFS=$func_echo_infix_1_IFS
803*6236dae4SAndroid Build Coastguard Worker}
804*6236dae4SAndroid Build Coastguard Worker
805*6236dae4SAndroid Build Coastguard Worker
806*6236dae4SAndroid Build Coastguard Worker# func_error ARG...
807*6236dae4SAndroid Build Coastguard Worker# -----------------
808*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message to standard error.
809*6236dae4SAndroid Build Coastguard Workerfunc_error ()
810*6236dae4SAndroid Build Coastguard Worker{
811*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
812*6236dae4SAndroid Build Coastguard Worker
813*6236dae4SAndroid Build Coastguard Worker    $require_term_colors
814*6236dae4SAndroid Build Coastguard Worker
815*6236dae4SAndroid Build Coastguard Worker    func_echo_infix_1 "  $tc_standout${tc_red}error$tc_reset" "$*" >&2
816*6236dae4SAndroid Build Coastguard Worker}
817*6236dae4SAndroid Build Coastguard Worker
818*6236dae4SAndroid Build Coastguard Worker
819*6236dae4SAndroid Build Coastguard Worker# func_fatal_error ARG...
820*6236dae4SAndroid Build Coastguard Worker# -----------------------
821*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message to standard error, and exit.
822*6236dae4SAndroid Build Coastguard Workerfunc_fatal_error ()
823*6236dae4SAndroid Build Coastguard Worker{
824*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
825*6236dae4SAndroid Build Coastguard Worker
826*6236dae4SAndroid Build Coastguard Worker    func_error "$*"
827*6236dae4SAndroid Build Coastguard Worker    exit $EXIT_FAILURE
828*6236dae4SAndroid Build Coastguard Worker}
829*6236dae4SAndroid Build Coastguard Worker
830*6236dae4SAndroid Build Coastguard Worker
831*6236dae4SAndroid Build Coastguard Worker# func_grep EXPRESSION FILENAME
832*6236dae4SAndroid Build Coastguard Worker# -----------------------------
833*6236dae4SAndroid Build Coastguard Worker# Check whether EXPRESSION matches any line of FILENAME, without output.
834*6236dae4SAndroid Build Coastguard Workerfunc_grep ()
835*6236dae4SAndroid Build Coastguard Worker{
836*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
837*6236dae4SAndroid Build Coastguard Worker
838*6236dae4SAndroid Build Coastguard Worker    $GREP "$1" "$2" >/dev/null 2>&1
839*6236dae4SAndroid Build Coastguard Worker}
840*6236dae4SAndroid Build Coastguard Worker
841*6236dae4SAndroid Build Coastguard Worker
842*6236dae4SAndroid Build Coastguard Worker# func_len STRING
843*6236dae4SAndroid Build Coastguard Worker# ---------------
844*6236dae4SAndroid Build Coastguard Worker# Set func_len_result to the length of STRING. STRING may not
845*6236dae4SAndroid Build Coastguard Worker# start with a hyphen.
846*6236dae4SAndroid Build Coastguard Worker  test -z "$_G_HAVE_XSI_OPS" \
847*6236dae4SAndroid Build Coastguard Worker    && (eval 'x=a/b/c;
848*6236dae4SAndroid Build Coastguard Worker      test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
849*6236dae4SAndroid Build Coastguard Worker    && _G_HAVE_XSI_OPS=yes
850*6236dae4SAndroid Build Coastguard Worker
851*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_XSI_OPS"; then
852*6236dae4SAndroid Build Coastguard Worker  eval 'func_len ()
853*6236dae4SAndroid Build Coastguard Worker  {
854*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
855*6236dae4SAndroid Build Coastguard Worker
856*6236dae4SAndroid Build Coastguard Worker    func_len_result=${#1}
857*6236dae4SAndroid Build Coastguard Worker  }'
858*6236dae4SAndroid Build Coastguard Workerelse
859*6236dae4SAndroid Build Coastguard Worker  func_len ()
860*6236dae4SAndroid Build Coastguard Worker  {
861*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
862*6236dae4SAndroid Build Coastguard Worker
863*6236dae4SAndroid Build Coastguard Worker    func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len`
864*6236dae4SAndroid Build Coastguard Worker  }
865*6236dae4SAndroid Build Coastguard Workerfi
866*6236dae4SAndroid Build Coastguard Worker
867*6236dae4SAndroid Build Coastguard Worker
868*6236dae4SAndroid Build Coastguard Worker# func_mkdir_p DIRECTORY-PATH
869*6236dae4SAndroid Build Coastguard Worker# ---------------------------
870*6236dae4SAndroid Build Coastguard Worker# Make sure the entire path to DIRECTORY-PATH is available.
871*6236dae4SAndroid Build Coastguard Workerfunc_mkdir_p ()
872*6236dae4SAndroid Build Coastguard Worker{
873*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
874*6236dae4SAndroid Build Coastguard Worker
875*6236dae4SAndroid Build Coastguard Worker    _G_directory_path=$1
876*6236dae4SAndroid Build Coastguard Worker    _G_dir_list=
877*6236dae4SAndroid Build Coastguard Worker
878*6236dae4SAndroid Build Coastguard Worker    if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then
879*6236dae4SAndroid Build Coastguard Worker
880*6236dae4SAndroid Build Coastguard Worker      # Protect directory names starting with '-'
881*6236dae4SAndroid Build Coastguard Worker      case $_G_directory_path in
882*6236dae4SAndroid Build Coastguard Worker        -*) _G_directory_path=./$_G_directory_path ;;
883*6236dae4SAndroid Build Coastguard Worker      esac
884*6236dae4SAndroid Build Coastguard Worker
885*6236dae4SAndroid Build Coastguard Worker      # While some portion of DIR does not yet exist...
886*6236dae4SAndroid Build Coastguard Worker      while test ! -d "$_G_directory_path"; do
887*6236dae4SAndroid Build Coastguard Worker        # ...make a list in topmost first order.  Use a colon delimited
888*6236dae4SAndroid Build Coastguard Worker	# list incase some portion of path contains whitespace.
889*6236dae4SAndroid Build Coastguard Worker        _G_dir_list=$_G_directory_path:$_G_dir_list
890*6236dae4SAndroid Build Coastguard Worker
891*6236dae4SAndroid Build Coastguard Worker        # If the last portion added has no slash in it, the list is done
892*6236dae4SAndroid Build Coastguard Worker        case $_G_directory_path in */*) ;; *) break ;; esac
893*6236dae4SAndroid Build Coastguard Worker
894*6236dae4SAndroid Build Coastguard Worker        # ...otherwise throw away the child directory and loop
895*6236dae4SAndroid Build Coastguard Worker        _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"`
896*6236dae4SAndroid Build Coastguard Worker      done
897*6236dae4SAndroid Build Coastguard Worker      _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'`
898*6236dae4SAndroid Build Coastguard Worker
899*6236dae4SAndroid Build Coastguard Worker      func_mkdir_p_IFS=$IFS; IFS=:
900*6236dae4SAndroid Build Coastguard Worker      for _G_dir in $_G_dir_list; do
901*6236dae4SAndroid Build Coastguard Worker	IFS=$func_mkdir_p_IFS
902*6236dae4SAndroid Build Coastguard Worker        # mkdir can fail with a 'File exist' error if two processes
903*6236dae4SAndroid Build Coastguard Worker        # try to create one of the directories concurrently.  Don't
904*6236dae4SAndroid Build Coastguard Worker        # stop in that case!
905*6236dae4SAndroid Build Coastguard Worker        $MKDIR "$_G_dir" 2>/dev/null || :
906*6236dae4SAndroid Build Coastguard Worker      done
907*6236dae4SAndroid Build Coastguard Worker      IFS=$func_mkdir_p_IFS
908*6236dae4SAndroid Build Coastguard Worker
909*6236dae4SAndroid Build Coastguard Worker      # Bail out if we (or some other process) failed to create a directory.
910*6236dae4SAndroid Build Coastguard Worker      test -d "$_G_directory_path" || \
911*6236dae4SAndroid Build Coastguard Worker        func_fatal_error "Failed to create '$1'"
912*6236dae4SAndroid Build Coastguard Worker    fi
913*6236dae4SAndroid Build Coastguard Worker}
914*6236dae4SAndroid Build Coastguard Worker
915*6236dae4SAndroid Build Coastguard Worker
916*6236dae4SAndroid Build Coastguard Worker# func_mktempdir [BASENAME]
917*6236dae4SAndroid Build Coastguard Worker# -------------------------
918*6236dae4SAndroid Build Coastguard Worker# Make a temporary directory that won't clash with other running
919*6236dae4SAndroid Build Coastguard Worker# libtool processes, and avoids race conditions if possible.  If
920*6236dae4SAndroid Build Coastguard Worker# given, BASENAME is the basename for that directory.
921*6236dae4SAndroid Build Coastguard Workerfunc_mktempdir ()
922*6236dae4SAndroid Build Coastguard Worker{
923*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
924*6236dae4SAndroid Build Coastguard Worker
925*6236dae4SAndroid Build Coastguard Worker    _G_template=${TMPDIR-/tmp}/${1-$progname}
926*6236dae4SAndroid Build Coastguard Worker
927*6236dae4SAndroid Build Coastguard Worker    if test : = "$opt_dry_run"; then
928*6236dae4SAndroid Build Coastguard Worker      # Return a directory name, but don't create it in dry-run mode
929*6236dae4SAndroid Build Coastguard Worker      _G_tmpdir=$_G_template-$$
930*6236dae4SAndroid Build Coastguard Worker    else
931*6236dae4SAndroid Build Coastguard Worker
932*6236dae4SAndroid Build Coastguard Worker      # If mktemp works, use that first and foremost
933*6236dae4SAndroid Build Coastguard Worker      _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null`
934*6236dae4SAndroid Build Coastguard Worker
935*6236dae4SAndroid Build Coastguard Worker      if test ! -d "$_G_tmpdir"; then
936*6236dae4SAndroid Build Coastguard Worker        # Failing that, at least try and use $RANDOM to avoid a race
937*6236dae4SAndroid Build Coastguard Worker        _G_tmpdir=$_G_template-${RANDOM-0}$$
938*6236dae4SAndroid Build Coastguard Worker
939*6236dae4SAndroid Build Coastguard Worker        func_mktempdir_umask=`umask`
940*6236dae4SAndroid Build Coastguard Worker        umask 0077
941*6236dae4SAndroid Build Coastguard Worker        $MKDIR "$_G_tmpdir"
942*6236dae4SAndroid Build Coastguard Worker        umask $func_mktempdir_umask
943*6236dae4SAndroid Build Coastguard Worker      fi
944*6236dae4SAndroid Build Coastguard Worker
945*6236dae4SAndroid Build Coastguard Worker      # If we're not in dry-run mode, bomb out on failure
946*6236dae4SAndroid Build Coastguard Worker      test -d "$_G_tmpdir" || \
947*6236dae4SAndroid Build Coastguard Worker        func_fatal_error "cannot create temporary directory '$_G_tmpdir'"
948*6236dae4SAndroid Build Coastguard Worker    fi
949*6236dae4SAndroid Build Coastguard Worker
950*6236dae4SAndroid Build Coastguard Worker    $ECHO "$_G_tmpdir"
951*6236dae4SAndroid Build Coastguard Worker}
952*6236dae4SAndroid Build Coastguard Worker
953*6236dae4SAndroid Build Coastguard Worker
954*6236dae4SAndroid Build Coastguard Worker# func_normal_abspath PATH
955*6236dae4SAndroid Build Coastguard Worker# ------------------------
956*6236dae4SAndroid Build Coastguard Worker# Remove doubled-up and trailing slashes, "." path components,
957*6236dae4SAndroid Build Coastguard Worker# and cancel out any ".." path components in PATH after making
958*6236dae4SAndroid Build Coastguard Worker# it an absolute path.
959*6236dae4SAndroid Build Coastguard Workerfunc_normal_abspath ()
960*6236dae4SAndroid Build Coastguard Worker{
961*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
962*6236dae4SAndroid Build Coastguard Worker
963*6236dae4SAndroid Build Coastguard Worker    # These SED scripts presuppose an absolute path with a trailing slash.
964*6236dae4SAndroid Build Coastguard Worker    _G_pathcar='s|^/\([^/]*\).*$|\1|'
965*6236dae4SAndroid Build Coastguard Worker    _G_pathcdr='s|^/[^/]*||'
966*6236dae4SAndroid Build Coastguard Worker    _G_removedotparts=':dotsl
967*6236dae4SAndroid Build Coastguard Worker		s|/\./|/|g
968*6236dae4SAndroid Build Coastguard Worker		t dotsl
969*6236dae4SAndroid Build Coastguard Worker		s|/\.$|/|'
970*6236dae4SAndroid Build Coastguard Worker    _G_collapseslashes='s|/\{1,\}|/|g'
971*6236dae4SAndroid Build Coastguard Worker    _G_finalslash='s|/*$|/|'
972*6236dae4SAndroid Build Coastguard Worker
973*6236dae4SAndroid Build Coastguard Worker    # Start from root dir and reassemble the path.
974*6236dae4SAndroid Build Coastguard Worker    func_normal_abspath_result=
975*6236dae4SAndroid Build Coastguard Worker    func_normal_abspath_tpath=$1
976*6236dae4SAndroid Build Coastguard Worker    func_normal_abspath_altnamespace=
977*6236dae4SAndroid Build Coastguard Worker    case $func_normal_abspath_tpath in
978*6236dae4SAndroid Build Coastguard Worker      "")
979*6236dae4SAndroid Build Coastguard Worker        # Empty path, that just means $cwd.
980*6236dae4SAndroid Build Coastguard Worker        func_stripname '' '/' "`pwd`"
981*6236dae4SAndroid Build Coastguard Worker        func_normal_abspath_result=$func_stripname_result
982*6236dae4SAndroid Build Coastguard Worker        return
983*6236dae4SAndroid Build Coastguard Worker        ;;
984*6236dae4SAndroid Build Coastguard Worker      # The next three entries are used to spot a run of precisely
985*6236dae4SAndroid Build Coastguard Worker      # two leading slashes without using negated character classes;
986*6236dae4SAndroid Build Coastguard Worker      # we take advantage of case's first-match behaviour.
987*6236dae4SAndroid Build Coastguard Worker      ///*)
988*6236dae4SAndroid Build Coastguard Worker        # Unusual form of absolute path, do nothing.
989*6236dae4SAndroid Build Coastguard Worker        ;;
990*6236dae4SAndroid Build Coastguard Worker      //*)
991*6236dae4SAndroid Build Coastguard Worker        # Not necessarily an ordinary path; POSIX reserves leading '//'
992*6236dae4SAndroid Build Coastguard Worker        # and for example Cygwin uses it to access remote file shares
993*6236dae4SAndroid Build Coastguard Worker        # over CIFS/SMB, so we conserve a leading double slash if found.
994*6236dae4SAndroid Build Coastguard Worker        func_normal_abspath_altnamespace=/
995*6236dae4SAndroid Build Coastguard Worker        ;;
996*6236dae4SAndroid Build Coastguard Worker      /*)
997*6236dae4SAndroid Build Coastguard Worker        # Absolute path, do nothing.
998*6236dae4SAndroid Build Coastguard Worker        ;;
999*6236dae4SAndroid Build Coastguard Worker      *)
1000*6236dae4SAndroid Build Coastguard Worker        # Relative path, prepend $cwd.
1001*6236dae4SAndroid Build Coastguard Worker        func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath
1002*6236dae4SAndroid Build Coastguard Worker        ;;
1003*6236dae4SAndroid Build Coastguard Worker    esac
1004*6236dae4SAndroid Build Coastguard Worker
1005*6236dae4SAndroid Build Coastguard Worker    # Cancel out all the simple stuff to save iterations.  We also want
1006*6236dae4SAndroid Build Coastguard Worker    # the path to end with a slash for ease of parsing, so make sure
1007*6236dae4SAndroid Build Coastguard Worker    # there is one (and only one) here.
1008*6236dae4SAndroid Build Coastguard Worker    func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
1009*6236dae4SAndroid Build Coastguard Worker          -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"`
1010*6236dae4SAndroid Build Coastguard Worker    while :; do
1011*6236dae4SAndroid Build Coastguard Worker      # Processed it all yet?
1012*6236dae4SAndroid Build Coastguard Worker      if test / = "$func_normal_abspath_tpath"; then
1013*6236dae4SAndroid Build Coastguard Worker        # If we ascended to the root using ".." the result may be empty now.
1014*6236dae4SAndroid Build Coastguard Worker        if test -z "$func_normal_abspath_result"; then
1015*6236dae4SAndroid Build Coastguard Worker          func_normal_abspath_result=/
1016*6236dae4SAndroid Build Coastguard Worker        fi
1017*6236dae4SAndroid Build Coastguard Worker        break
1018*6236dae4SAndroid Build Coastguard Worker      fi
1019*6236dae4SAndroid Build Coastguard Worker      func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \
1020*6236dae4SAndroid Build Coastguard Worker          -e "$_G_pathcar"`
1021*6236dae4SAndroid Build Coastguard Worker      func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
1022*6236dae4SAndroid Build Coastguard Worker          -e "$_G_pathcdr"`
1023*6236dae4SAndroid Build Coastguard Worker      # Figure out what to do with it
1024*6236dae4SAndroid Build Coastguard Worker      case $func_normal_abspath_tcomponent in
1025*6236dae4SAndroid Build Coastguard Worker        "")
1026*6236dae4SAndroid Build Coastguard Worker          # Trailing empty path component, ignore it.
1027*6236dae4SAndroid Build Coastguard Worker          ;;
1028*6236dae4SAndroid Build Coastguard Worker        ..)
1029*6236dae4SAndroid Build Coastguard Worker          # Parent dir; strip last assembled component from result.
1030*6236dae4SAndroid Build Coastguard Worker          func_dirname "$func_normal_abspath_result"
1031*6236dae4SAndroid Build Coastguard Worker          func_normal_abspath_result=$func_dirname_result
1032*6236dae4SAndroid Build Coastguard Worker          ;;
1033*6236dae4SAndroid Build Coastguard Worker        *)
1034*6236dae4SAndroid Build Coastguard Worker          # Actual path component, append it.
1035*6236dae4SAndroid Build Coastguard Worker          func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent"
1036*6236dae4SAndroid Build Coastguard Worker          ;;
1037*6236dae4SAndroid Build Coastguard Worker      esac
1038*6236dae4SAndroid Build Coastguard Worker    done
1039*6236dae4SAndroid Build Coastguard Worker    # Restore leading double-slash if one was found on entry.
1040*6236dae4SAndroid Build Coastguard Worker    func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result
1041*6236dae4SAndroid Build Coastguard Worker}
1042*6236dae4SAndroid Build Coastguard Worker
1043*6236dae4SAndroid Build Coastguard Worker
1044*6236dae4SAndroid Build Coastguard Worker# func_notquiet ARG...
1045*6236dae4SAndroid Build Coastguard Worker# --------------------
1046*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message only when not in quiet mode.
1047*6236dae4SAndroid Build Coastguard Workerfunc_notquiet ()
1048*6236dae4SAndroid Build Coastguard Worker{
1049*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1050*6236dae4SAndroid Build Coastguard Worker
1051*6236dae4SAndroid Build Coastguard Worker    $opt_quiet || func_echo ${1+"$@"}
1052*6236dae4SAndroid Build Coastguard Worker
1053*6236dae4SAndroid Build Coastguard Worker    # A bug in bash halts the script if the last line of a function
1054*6236dae4SAndroid Build Coastguard Worker    # fails when set -e is in force, so we need another command to
1055*6236dae4SAndroid Build Coastguard Worker    # work around that:
1056*6236dae4SAndroid Build Coastguard Worker    :
1057*6236dae4SAndroid Build Coastguard Worker}
1058*6236dae4SAndroid Build Coastguard Worker
1059*6236dae4SAndroid Build Coastguard Worker
1060*6236dae4SAndroid Build Coastguard Worker# func_relative_path SRCDIR DSTDIR
1061*6236dae4SAndroid Build Coastguard Worker# --------------------------------
1062*6236dae4SAndroid Build Coastguard Worker# Set func_relative_path_result to the relative path from SRCDIR to DSTDIR.
1063*6236dae4SAndroid Build Coastguard Workerfunc_relative_path ()
1064*6236dae4SAndroid Build Coastguard Worker{
1065*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1066*6236dae4SAndroid Build Coastguard Worker
1067*6236dae4SAndroid Build Coastguard Worker    func_relative_path_result=
1068*6236dae4SAndroid Build Coastguard Worker    func_normal_abspath "$1"
1069*6236dae4SAndroid Build Coastguard Worker    func_relative_path_tlibdir=$func_normal_abspath_result
1070*6236dae4SAndroid Build Coastguard Worker    func_normal_abspath "$2"
1071*6236dae4SAndroid Build Coastguard Worker    func_relative_path_tbindir=$func_normal_abspath_result
1072*6236dae4SAndroid Build Coastguard Worker
1073*6236dae4SAndroid Build Coastguard Worker    # Ascend the tree starting from libdir
1074*6236dae4SAndroid Build Coastguard Worker    while :; do
1075*6236dae4SAndroid Build Coastguard Worker      # check if we have found a prefix of bindir
1076*6236dae4SAndroid Build Coastguard Worker      case $func_relative_path_tbindir in
1077*6236dae4SAndroid Build Coastguard Worker        $func_relative_path_tlibdir)
1078*6236dae4SAndroid Build Coastguard Worker          # found an exact match
1079*6236dae4SAndroid Build Coastguard Worker          func_relative_path_tcancelled=
1080*6236dae4SAndroid Build Coastguard Worker          break
1081*6236dae4SAndroid Build Coastguard Worker          ;;
1082*6236dae4SAndroid Build Coastguard Worker        $func_relative_path_tlibdir*)
1083*6236dae4SAndroid Build Coastguard Worker          # found a matching prefix
1084*6236dae4SAndroid Build Coastguard Worker          func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir"
1085*6236dae4SAndroid Build Coastguard Worker          func_relative_path_tcancelled=$func_stripname_result
1086*6236dae4SAndroid Build Coastguard Worker          if test -z "$func_relative_path_result"; then
1087*6236dae4SAndroid Build Coastguard Worker            func_relative_path_result=.
1088*6236dae4SAndroid Build Coastguard Worker          fi
1089*6236dae4SAndroid Build Coastguard Worker          break
1090*6236dae4SAndroid Build Coastguard Worker          ;;
1091*6236dae4SAndroid Build Coastguard Worker        *)
1092*6236dae4SAndroid Build Coastguard Worker          func_dirname $func_relative_path_tlibdir
1093*6236dae4SAndroid Build Coastguard Worker          func_relative_path_tlibdir=$func_dirname_result
1094*6236dae4SAndroid Build Coastguard Worker          if test -z "$func_relative_path_tlibdir"; then
1095*6236dae4SAndroid Build Coastguard Worker            # Have to descend all the way to the root!
1096*6236dae4SAndroid Build Coastguard Worker            func_relative_path_result=../$func_relative_path_result
1097*6236dae4SAndroid Build Coastguard Worker            func_relative_path_tcancelled=$func_relative_path_tbindir
1098*6236dae4SAndroid Build Coastguard Worker            break
1099*6236dae4SAndroid Build Coastguard Worker          fi
1100*6236dae4SAndroid Build Coastguard Worker          func_relative_path_result=../$func_relative_path_result
1101*6236dae4SAndroid Build Coastguard Worker          ;;
1102*6236dae4SAndroid Build Coastguard Worker      esac
1103*6236dae4SAndroid Build Coastguard Worker    done
1104*6236dae4SAndroid Build Coastguard Worker
1105*6236dae4SAndroid Build Coastguard Worker    # Now calculate path; take care to avoid doubling-up slashes.
1106*6236dae4SAndroid Build Coastguard Worker    func_stripname '' '/' "$func_relative_path_result"
1107*6236dae4SAndroid Build Coastguard Worker    func_relative_path_result=$func_stripname_result
1108*6236dae4SAndroid Build Coastguard Worker    func_stripname '/' '/' "$func_relative_path_tcancelled"
1109*6236dae4SAndroid Build Coastguard Worker    if test -n "$func_stripname_result"; then
1110*6236dae4SAndroid Build Coastguard Worker      func_append func_relative_path_result "/$func_stripname_result"
1111*6236dae4SAndroid Build Coastguard Worker    fi
1112*6236dae4SAndroid Build Coastguard Worker
1113*6236dae4SAndroid Build Coastguard Worker    # Normalisation. If bindir is libdir, return '.' else relative path.
1114*6236dae4SAndroid Build Coastguard Worker    if test -n "$func_relative_path_result"; then
1115*6236dae4SAndroid Build Coastguard Worker      func_stripname './' '' "$func_relative_path_result"
1116*6236dae4SAndroid Build Coastguard Worker      func_relative_path_result=$func_stripname_result
1117*6236dae4SAndroid Build Coastguard Worker    fi
1118*6236dae4SAndroid Build Coastguard Worker
1119*6236dae4SAndroid Build Coastguard Worker    test -n "$func_relative_path_result" || func_relative_path_result=.
1120*6236dae4SAndroid Build Coastguard Worker
1121*6236dae4SAndroid Build Coastguard Worker    :
1122*6236dae4SAndroid Build Coastguard Worker}
1123*6236dae4SAndroid Build Coastguard Worker
1124*6236dae4SAndroid Build Coastguard Worker
1125*6236dae4SAndroid Build Coastguard Worker# func_quote_portable EVAL ARG
1126*6236dae4SAndroid Build Coastguard Worker# ----------------------------
1127*6236dae4SAndroid Build Coastguard Worker# Internal function to portably implement func_quote_arg.  Note that we still
1128*6236dae4SAndroid Build Coastguard Worker# keep attention to performance here so we as much as possible try to avoid
1129*6236dae4SAndroid Build Coastguard Worker# calling sed binary (so far O(N) complexity as long as func_append is O(1)).
1130*6236dae4SAndroid Build Coastguard Workerfunc_quote_portable ()
1131*6236dae4SAndroid Build Coastguard Worker{
1132*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1133*6236dae4SAndroid Build Coastguard Worker
1134*6236dae4SAndroid Build Coastguard Worker    $require_check_ifs_backslash
1135*6236dae4SAndroid Build Coastguard Worker
1136*6236dae4SAndroid Build Coastguard Worker    func_quote_portable_result=$2
1137*6236dae4SAndroid Build Coastguard Worker
1138*6236dae4SAndroid Build Coastguard Worker    # one-time-loop (easy break)
1139*6236dae4SAndroid Build Coastguard Worker    while true
1140*6236dae4SAndroid Build Coastguard Worker    do
1141*6236dae4SAndroid Build Coastguard Worker      if $1; then
1142*6236dae4SAndroid Build Coastguard Worker        func_quote_portable_result=`$ECHO "$2" | $SED \
1143*6236dae4SAndroid Build Coastguard Worker          -e "$sed_double_quote_subst" -e "$sed_double_backslash"`
1144*6236dae4SAndroid Build Coastguard Worker        break
1145*6236dae4SAndroid Build Coastguard Worker      fi
1146*6236dae4SAndroid Build Coastguard Worker
1147*6236dae4SAndroid Build Coastguard Worker      # Quote for eval.
1148*6236dae4SAndroid Build Coastguard Worker      case $func_quote_portable_result in
1149*6236dae4SAndroid Build Coastguard Worker        *[\\\`\"\$]*)
1150*6236dae4SAndroid Build Coastguard Worker          # Fallback to sed for $func_check_bs_ifs_broken=:, or when the string
1151*6236dae4SAndroid Build Coastguard Worker          # contains the shell wildcard characters.
1152*6236dae4SAndroid Build Coastguard Worker          case $check_ifs_backshlash_broken$func_quote_portable_result in
1153*6236dae4SAndroid Build Coastguard Worker            :*|*[\[\*\?]*)
1154*6236dae4SAndroid Build Coastguard Worker              func_quote_portable_result=`$ECHO "$func_quote_portable_result" \
1155*6236dae4SAndroid Build Coastguard Worker                  | $SED "$sed_quote_subst"`
1156*6236dae4SAndroid Build Coastguard Worker              break
1157*6236dae4SAndroid Build Coastguard Worker              ;;
1158*6236dae4SAndroid Build Coastguard Worker          esac
1159*6236dae4SAndroid Build Coastguard Worker
1160*6236dae4SAndroid Build Coastguard Worker          func_quote_portable_old_IFS=$IFS
1161*6236dae4SAndroid Build Coastguard Worker          for _G_char in '\' '`' '"' '$'
1162*6236dae4SAndroid Build Coastguard Worker          do
1163*6236dae4SAndroid Build Coastguard Worker            # STATE($1) PREV($2) SEPARATOR($3)
1164*6236dae4SAndroid Build Coastguard Worker            set start "" ""
1165*6236dae4SAndroid Build Coastguard Worker            func_quote_portable_result=dummy"$_G_char$func_quote_portable_result$_G_char"dummy
1166*6236dae4SAndroid Build Coastguard Worker            IFS=$_G_char
1167*6236dae4SAndroid Build Coastguard Worker            for _G_part in $func_quote_portable_result
1168*6236dae4SAndroid Build Coastguard Worker            do
1169*6236dae4SAndroid Build Coastguard Worker              case $1 in
1170*6236dae4SAndroid Build Coastguard Worker              quote)
1171*6236dae4SAndroid Build Coastguard Worker                func_append func_quote_portable_result "$3$2"
1172*6236dae4SAndroid Build Coastguard Worker                set quote "$_G_part" "\\$_G_char"
1173*6236dae4SAndroid Build Coastguard Worker                ;;
1174*6236dae4SAndroid Build Coastguard Worker              start)
1175*6236dae4SAndroid Build Coastguard Worker                set first "" ""
1176*6236dae4SAndroid Build Coastguard Worker                func_quote_portable_result=
1177*6236dae4SAndroid Build Coastguard Worker                ;;
1178*6236dae4SAndroid Build Coastguard Worker              first)
1179*6236dae4SAndroid Build Coastguard Worker                set quote "$_G_part" ""
1180*6236dae4SAndroid Build Coastguard Worker                ;;
1181*6236dae4SAndroid Build Coastguard Worker              esac
1182*6236dae4SAndroid Build Coastguard Worker            done
1183*6236dae4SAndroid Build Coastguard Worker          done
1184*6236dae4SAndroid Build Coastguard Worker          IFS=$func_quote_portable_old_IFS
1185*6236dae4SAndroid Build Coastguard Worker          ;;
1186*6236dae4SAndroid Build Coastguard Worker        *) ;;
1187*6236dae4SAndroid Build Coastguard Worker      esac
1188*6236dae4SAndroid Build Coastguard Worker      break
1189*6236dae4SAndroid Build Coastguard Worker    done
1190*6236dae4SAndroid Build Coastguard Worker
1191*6236dae4SAndroid Build Coastguard Worker    func_quote_portable_unquoted_result=$func_quote_portable_result
1192*6236dae4SAndroid Build Coastguard Worker    case $func_quote_portable_result in
1193*6236dae4SAndroid Build Coastguard Worker      # double-quote args containing shell metacharacters to delay
1194*6236dae4SAndroid Build Coastguard Worker      # word splitting, command substitution and variable expansion
1195*6236dae4SAndroid Build Coastguard Worker      # for a subsequent eval.
1196*6236dae4SAndroid Build Coastguard Worker      # many bourne shells cannot handle close brackets correctly
1197*6236dae4SAndroid Build Coastguard Worker      # in scan sets, so we specify it separately.
1198*6236dae4SAndroid Build Coastguard Worker      *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \	]*|*]*|"")
1199*6236dae4SAndroid Build Coastguard Worker        func_quote_portable_result=\"$func_quote_portable_result\"
1200*6236dae4SAndroid Build Coastguard Worker        ;;
1201*6236dae4SAndroid Build Coastguard Worker    esac
1202*6236dae4SAndroid Build Coastguard Worker}
1203*6236dae4SAndroid Build Coastguard Worker
1204*6236dae4SAndroid Build Coastguard Worker
1205*6236dae4SAndroid Build Coastguard Worker# func_quotefast_eval ARG
1206*6236dae4SAndroid Build Coastguard Worker# -----------------------
1207*6236dae4SAndroid Build Coastguard Worker# Quote one ARG (internal).  This is equivalent to 'func_quote_arg eval ARG',
1208*6236dae4SAndroid Build Coastguard Worker# but optimized for speed.  Result is stored in $func_quotefast_eval.
1209*6236dae4SAndroid Build Coastguard Workerif test xyes = `(x=; printf -v x %q yes; echo x"$x") 2>/dev/null`; then
1210*6236dae4SAndroid Build Coastguard Worker  printf -v _GL_test_printf_tilde %q '~'
1211*6236dae4SAndroid Build Coastguard Worker  if test '\~' = "$_GL_test_printf_tilde"; then
1212*6236dae4SAndroid Build Coastguard Worker    func_quotefast_eval ()
1213*6236dae4SAndroid Build Coastguard Worker    {
1214*6236dae4SAndroid Build Coastguard Worker      printf -v func_quotefast_eval_result %q "$1"
1215*6236dae4SAndroid Build Coastguard Worker    }
1216*6236dae4SAndroid Build Coastguard Worker  else
1217*6236dae4SAndroid Build Coastguard Worker    # Broken older Bash implementations.  Make those faster too if possible.
1218*6236dae4SAndroid Build Coastguard Worker    func_quotefast_eval ()
1219*6236dae4SAndroid Build Coastguard Worker    {
1220*6236dae4SAndroid Build Coastguard Worker      case $1 in
1221*6236dae4SAndroid Build Coastguard Worker        '~'*)
1222*6236dae4SAndroid Build Coastguard Worker          func_quote_portable false "$1"
1223*6236dae4SAndroid Build Coastguard Worker          func_quotefast_eval_result=$func_quote_portable_result
1224*6236dae4SAndroid Build Coastguard Worker          ;;
1225*6236dae4SAndroid Build Coastguard Worker        *)
1226*6236dae4SAndroid Build Coastguard Worker          printf -v func_quotefast_eval_result %q "$1"
1227*6236dae4SAndroid Build Coastguard Worker          ;;
1228*6236dae4SAndroid Build Coastguard Worker      esac
1229*6236dae4SAndroid Build Coastguard Worker    }
1230*6236dae4SAndroid Build Coastguard Worker  fi
1231*6236dae4SAndroid Build Coastguard Workerelse
1232*6236dae4SAndroid Build Coastguard Worker  func_quotefast_eval ()
1233*6236dae4SAndroid Build Coastguard Worker  {
1234*6236dae4SAndroid Build Coastguard Worker    func_quote_portable false "$1"
1235*6236dae4SAndroid Build Coastguard Worker    func_quotefast_eval_result=$func_quote_portable_result
1236*6236dae4SAndroid Build Coastguard Worker  }
1237*6236dae4SAndroid Build Coastguard Workerfi
1238*6236dae4SAndroid Build Coastguard Worker
1239*6236dae4SAndroid Build Coastguard Worker
1240*6236dae4SAndroid Build Coastguard Worker# func_quote_arg MODEs ARG
1241*6236dae4SAndroid Build Coastguard Worker# ------------------------
1242*6236dae4SAndroid Build Coastguard Worker# Quote one ARG to be evaled later.  MODEs argument may contain zero or more
1243*6236dae4SAndroid Build Coastguard Worker# specifiers listed below separated by ',' character.  This function returns two
1244*6236dae4SAndroid Build Coastguard Worker# values:
1245*6236dae4SAndroid Build Coastguard Worker#   i) func_quote_arg_result
1246*6236dae4SAndroid Build Coastguard Worker#      double-quoted (when needed), suitable for a subsequent eval
1247*6236dae4SAndroid Build Coastguard Worker#  ii) func_quote_arg_unquoted_result
1248*6236dae4SAndroid Build Coastguard Worker#      has all characters that are still active within double
1249*6236dae4SAndroid Build Coastguard Worker#      quotes backslashified.  Available only if 'unquoted' is specified.
1250*6236dae4SAndroid Build Coastguard Worker#
1251*6236dae4SAndroid Build Coastguard Worker# Available modes:
1252*6236dae4SAndroid Build Coastguard Worker# ----------------
1253*6236dae4SAndroid Build Coastguard Worker# 'eval' (default)
1254*6236dae4SAndroid Build Coastguard Worker#       - escape shell special characters
1255*6236dae4SAndroid Build Coastguard Worker# 'expand'
1256*6236dae4SAndroid Build Coastguard Worker#       - the same as 'eval';  but do not quote variable references
1257*6236dae4SAndroid Build Coastguard Worker# 'pretty'
1258*6236dae4SAndroid Build Coastguard Worker#       - request aesthetic output, i.e. '"a b"' instead of 'a\ b'.  This might
1259*6236dae4SAndroid Build Coastguard Worker#         be used later in func_quote to get output like: 'echo "a b"' instead
1260*6236dae4SAndroid Build Coastguard Worker#         of 'echo a\ b'.  This is slower than default on some shells.
1261*6236dae4SAndroid Build Coastguard Worker# 'unquoted'
1262*6236dae4SAndroid Build Coastguard Worker#       - produce also $func_quote_arg_unquoted_result which does not contain
1263*6236dae4SAndroid Build Coastguard Worker#         wrapping double-quotes.
1264*6236dae4SAndroid Build Coastguard Worker#
1265*6236dae4SAndroid Build Coastguard Worker# Examples for 'func_quote_arg pretty,unquoted string':
1266*6236dae4SAndroid Build Coastguard Worker#
1267*6236dae4SAndroid Build Coastguard Worker#   string      | *_result              | *_unquoted_result
1268*6236dae4SAndroid Build Coastguard Worker#   ------------+-----------------------+-------------------
1269*6236dae4SAndroid Build Coastguard Worker#   "           | \"                    | \"
1270*6236dae4SAndroid Build Coastguard Worker#   a b         | "a b"                 | a b
1271*6236dae4SAndroid Build Coastguard Worker#   "a b"       | "\"a b\""             | \"a b\"
1272*6236dae4SAndroid Build Coastguard Worker#   *           | "*"                   | *
1273*6236dae4SAndroid Build Coastguard Worker#   z="${x-$y}" | "z=\"\${x-\$y}\""     | z=\"\${x-\$y}\"
1274*6236dae4SAndroid Build Coastguard Worker#
1275*6236dae4SAndroid Build Coastguard Worker# Examples for 'func_quote_arg pretty,unquoted,expand string':
1276*6236dae4SAndroid Build Coastguard Worker#
1277*6236dae4SAndroid Build Coastguard Worker#   string        |   *_result          |  *_unquoted_result
1278*6236dae4SAndroid Build Coastguard Worker#   --------------+---------------------+--------------------
1279*6236dae4SAndroid Build Coastguard Worker#   z="${x-$y}"   | "z=\"${x-$y}\""     | z=\"${x-$y}\"
1280*6236dae4SAndroid Build Coastguard Workerfunc_quote_arg ()
1281*6236dae4SAndroid Build Coastguard Worker{
1282*6236dae4SAndroid Build Coastguard Worker    _G_quote_expand=false
1283*6236dae4SAndroid Build Coastguard Worker    case ,$1, in
1284*6236dae4SAndroid Build Coastguard Worker      *,expand,*)
1285*6236dae4SAndroid Build Coastguard Worker        _G_quote_expand=:
1286*6236dae4SAndroid Build Coastguard Worker        ;;
1287*6236dae4SAndroid Build Coastguard Worker    esac
1288*6236dae4SAndroid Build Coastguard Worker
1289*6236dae4SAndroid Build Coastguard Worker    case ,$1, in
1290*6236dae4SAndroid Build Coastguard Worker      *,pretty,*|*,expand,*|*,unquoted,*)
1291*6236dae4SAndroid Build Coastguard Worker        func_quote_portable $_G_quote_expand "$2"
1292*6236dae4SAndroid Build Coastguard Worker        func_quote_arg_result=$func_quote_portable_result
1293*6236dae4SAndroid Build Coastguard Worker        func_quote_arg_unquoted_result=$func_quote_portable_unquoted_result
1294*6236dae4SAndroid Build Coastguard Worker        ;;
1295*6236dae4SAndroid Build Coastguard Worker      *)
1296*6236dae4SAndroid Build Coastguard Worker        # Faster quote-for-eval for some shells.
1297*6236dae4SAndroid Build Coastguard Worker        func_quotefast_eval "$2"
1298*6236dae4SAndroid Build Coastguard Worker        func_quote_arg_result=$func_quotefast_eval_result
1299*6236dae4SAndroid Build Coastguard Worker        ;;
1300*6236dae4SAndroid Build Coastguard Worker    esac
1301*6236dae4SAndroid Build Coastguard Worker}
1302*6236dae4SAndroid Build Coastguard Worker
1303*6236dae4SAndroid Build Coastguard Worker
1304*6236dae4SAndroid Build Coastguard Worker# func_quote MODEs ARGs...
1305*6236dae4SAndroid Build Coastguard Worker# ------------------------
1306*6236dae4SAndroid Build Coastguard Worker# Quote all ARGs to be evaled later and join them into single command.  See
1307*6236dae4SAndroid Build Coastguard Worker# func_quote_arg's description for more info.
1308*6236dae4SAndroid Build Coastguard Workerfunc_quote ()
1309*6236dae4SAndroid Build Coastguard Worker{
1310*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1311*6236dae4SAndroid Build Coastguard Worker    _G_func_quote_mode=$1 ; shift
1312*6236dae4SAndroid Build Coastguard Worker    func_quote_result=
1313*6236dae4SAndroid Build Coastguard Worker    while test 0 -lt $#; do
1314*6236dae4SAndroid Build Coastguard Worker      func_quote_arg "$_G_func_quote_mode" "$1"
1315*6236dae4SAndroid Build Coastguard Worker      if test -n "$func_quote_result"; then
1316*6236dae4SAndroid Build Coastguard Worker        func_append func_quote_result " $func_quote_arg_result"
1317*6236dae4SAndroid Build Coastguard Worker      else
1318*6236dae4SAndroid Build Coastguard Worker        func_append func_quote_result "$func_quote_arg_result"
1319*6236dae4SAndroid Build Coastguard Worker      fi
1320*6236dae4SAndroid Build Coastguard Worker      shift
1321*6236dae4SAndroid Build Coastguard Worker    done
1322*6236dae4SAndroid Build Coastguard Worker}
1323*6236dae4SAndroid Build Coastguard Worker
1324*6236dae4SAndroid Build Coastguard Worker
1325*6236dae4SAndroid Build Coastguard Worker# func_stripname PREFIX SUFFIX NAME
1326*6236dae4SAndroid Build Coastguard Worker# ---------------------------------
1327*6236dae4SAndroid Build Coastguard Worker# strip PREFIX and SUFFIX from NAME, and store in func_stripname_result.
1328*6236dae4SAndroid Build Coastguard Worker# PREFIX and SUFFIX must not contain globbing or regex special
1329*6236dae4SAndroid Build Coastguard Worker# characters, hashes, percent signs, but SUFFIX may contain a leading
1330*6236dae4SAndroid Build Coastguard Worker# dot (in which case that matches only a dot).
1331*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_XSI_OPS"; then
1332*6236dae4SAndroid Build Coastguard Worker  eval 'func_stripname ()
1333*6236dae4SAndroid Build Coastguard Worker  {
1334*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1335*6236dae4SAndroid Build Coastguard Worker
1336*6236dae4SAndroid Build Coastguard Worker    # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
1337*6236dae4SAndroid Build Coastguard Worker    # positional parameters, so assign one to ordinary variable first.
1338*6236dae4SAndroid Build Coastguard Worker    func_stripname_result=$3
1339*6236dae4SAndroid Build Coastguard Worker    func_stripname_result=${func_stripname_result#"$1"}
1340*6236dae4SAndroid Build Coastguard Worker    func_stripname_result=${func_stripname_result%"$2"}
1341*6236dae4SAndroid Build Coastguard Worker  }'
1342*6236dae4SAndroid Build Coastguard Workerelse
1343*6236dae4SAndroid Build Coastguard Worker  func_stripname ()
1344*6236dae4SAndroid Build Coastguard Worker  {
1345*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1346*6236dae4SAndroid Build Coastguard Worker
1347*6236dae4SAndroid Build Coastguard Worker    case $2 in
1348*6236dae4SAndroid Build Coastguard Worker      .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;;
1349*6236dae4SAndroid Build Coastguard Worker      *)  func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;;
1350*6236dae4SAndroid Build Coastguard Worker    esac
1351*6236dae4SAndroid Build Coastguard Worker  }
1352*6236dae4SAndroid Build Coastguard Workerfi
1353*6236dae4SAndroid Build Coastguard Worker
1354*6236dae4SAndroid Build Coastguard Worker
1355*6236dae4SAndroid Build Coastguard Worker# func_show_eval CMD [FAIL_EXP]
1356*6236dae4SAndroid Build Coastguard Worker# -----------------------------
1357*6236dae4SAndroid Build Coastguard Worker# Unless opt_quiet is true, then output CMD.  Then, if opt_dryrun is
1358*6236dae4SAndroid Build Coastguard Worker# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
1359*6236dae4SAndroid Build Coastguard Worker# is given, then evaluate it.
1360*6236dae4SAndroid Build Coastguard Workerfunc_show_eval ()
1361*6236dae4SAndroid Build Coastguard Worker{
1362*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1363*6236dae4SAndroid Build Coastguard Worker
1364*6236dae4SAndroid Build Coastguard Worker    _G_cmd=$1
1365*6236dae4SAndroid Build Coastguard Worker    _G_fail_exp=${2-':'}
1366*6236dae4SAndroid Build Coastguard Worker
1367*6236dae4SAndroid Build Coastguard Worker    func_quote_arg pretty,expand "$_G_cmd"
1368*6236dae4SAndroid Build Coastguard Worker    eval "func_notquiet $func_quote_arg_result"
1369*6236dae4SAndroid Build Coastguard Worker
1370*6236dae4SAndroid Build Coastguard Worker    $opt_dry_run || {
1371*6236dae4SAndroid Build Coastguard Worker      eval "$_G_cmd"
1372*6236dae4SAndroid Build Coastguard Worker      _G_status=$?
1373*6236dae4SAndroid Build Coastguard Worker      if test 0 -ne "$_G_status"; then
1374*6236dae4SAndroid Build Coastguard Worker	eval "(exit $_G_status); $_G_fail_exp"
1375*6236dae4SAndroid Build Coastguard Worker      fi
1376*6236dae4SAndroid Build Coastguard Worker    }
1377*6236dae4SAndroid Build Coastguard Worker}
1378*6236dae4SAndroid Build Coastguard Worker
1379*6236dae4SAndroid Build Coastguard Worker
1380*6236dae4SAndroid Build Coastguard Worker# func_show_eval_locale CMD [FAIL_EXP]
1381*6236dae4SAndroid Build Coastguard Worker# ------------------------------------
1382*6236dae4SAndroid Build Coastguard Worker# Unless opt_quiet is true, then output CMD.  Then, if opt_dryrun is
1383*6236dae4SAndroid Build Coastguard Worker# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
1384*6236dae4SAndroid Build Coastguard Worker# is given, then evaluate it.  Use the saved locale for evaluation.
1385*6236dae4SAndroid Build Coastguard Workerfunc_show_eval_locale ()
1386*6236dae4SAndroid Build Coastguard Worker{
1387*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1388*6236dae4SAndroid Build Coastguard Worker
1389*6236dae4SAndroid Build Coastguard Worker    _G_cmd=$1
1390*6236dae4SAndroid Build Coastguard Worker    _G_fail_exp=${2-':'}
1391*6236dae4SAndroid Build Coastguard Worker
1392*6236dae4SAndroid Build Coastguard Worker    $opt_quiet || {
1393*6236dae4SAndroid Build Coastguard Worker      func_quote_arg expand,pretty "$_G_cmd"
1394*6236dae4SAndroid Build Coastguard Worker      eval "func_echo $func_quote_arg_result"
1395*6236dae4SAndroid Build Coastguard Worker    }
1396*6236dae4SAndroid Build Coastguard Worker
1397*6236dae4SAndroid Build Coastguard Worker    $opt_dry_run || {
1398*6236dae4SAndroid Build Coastguard Worker      eval "$_G_user_locale
1399*6236dae4SAndroid Build Coastguard Worker	    $_G_cmd"
1400*6236dae4SAndroid Build Coastguard Worker      _G_status=$?
1401*6236dae4SAndroid Build Coastguard Worker      eval "$_G_safe_locale"
1402*6236dae4SAndroid Build Coastguard Worker      if test 0 -ne "$_G_status"; then
1403*6236dae4SAndroid Build Coastguard Worker	eval "(exit $_G_status); $_G_fail_exp"
1404*6236dae4SAndroid Build Coastguard Worker      fi
1405*6236dae4SAndroid Build Coastguard Worker    }
1406*6236dae4SAndroid Build Coastguard Worker}
1407*6236dae4SAndroid Build Coastguard Worker
1408*6236dae4SAndroid Build Coastguard Worker
1409*6236dae4SAndroid Build Coastguard Worker# func_tr_sh
1410*6236dae4SAndroid Build Coastguard Worker# ----------
1411*6236dae4SAndroid Build Coastguard Worker# Turn $1 into a string suitable for a shell variable name.
1412*6236dae4SAndroid Build Coastguard Worker# Result is stored in $func_tr_sh_result.  All characters
1413*6236dae4SAndroid Build Coastguard Worker# not in the set a-zA-Z0-9_ are replaced with '_'. Further,
1414*6236dae4SAndroid Build Coastguard Worker# if $1 begins with a digit, a '_' is prepended as well.
1415*6236dae4SAndroid Build Coastguard Workerfunc_tr_sh ()
1416*6236dae4SAndroid Build Coastguard Worker{
1417*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1418*6236dae4SAndroid Build Coastguard Worker
1419*6236dae4SAndroid Build Coastguard Worker    case $1 in
1420*6236dae4SAndroid Build Coastguard Worker    [0-9]* | *[!a-zA-Z0-9_]*)
1421*6236dae4SAndroid Build Coastguard Worker      func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'`
1422*6236dae4SAndroid Build Coastguard Worker      ;;
1423*6236dae4SAndroid Build Coastguard Worker    * )
1424*6236dae4SAndroid Build Coastguard Worker      func_tr_sh_result=$1
1425*6236dae4SAndroid Build Coastguard Worker      ;;
1426*6236dae4SAndroid Build Coastguard Worker    esac
1427*6236dae4SAndroid Build Coastguard Worker}
1428*6236dae4SAndroid Build Coastguard Worker
1429*6236dae4SAndroid Build Coastguard Worker
1430*6236dae4SAndroid Build Coastguard Worker# func_verbose ARG...
1431*6236dae4SAndroid Build Coastguard Worker# -------------------
1432*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message in verbose mode only.
1433*6236dae4SAndroid Build Coastguard Workerfunc_verbose ()
1434*6236dae4SAndroid Build Coastguard Worker{
1435*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1436*6236dae4SAndroid Build Coastguard Worker
1437*6236dae4SAndroid Build Coastguard Worker    $opt_verbose && func_echo "$*"
1438*6236dae4SAndroid Build Coastguard Worker
1439*6236dae4SAndroid Build Coastguard Worker    :
1440*6236dae4SAndroid Build Coastguard Worker}
1441*6236dae4SAndroid Build Coastguard Worker
1442*6236dae4SAndroid Build Coastguard Worker
1443*6236dae4SAndroid Build Coastguard Worker# func_warn_and_continue ARG...
1444*6236dae4SAndroid Build Coastguard Worker# -----------------------------
1445*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed warning message to standard error.
1446*6236dae4SAndroid Build Coastguard Workerfunc_warn_and_continue ()
1447*6236dae4SAndroid Build Coastguard Worker{
1448*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1449*6236dae4SAndroid Build Coastguard Worker
1450*6236dae4SAndroid Build Coastguard Worker    $require_term_colors
1451*6236dae4SAndroid Build Coastguard Worker
1452*6236dae4SAndroid Build Coastguard Worker    func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2
1453*6236dae4SAndroid Build Coastguard Worker}
1454*6236dae4SAndroid Build Coastguard Worker
1455*6236dae4SAndroid Build Coastguard Worker
1456*6236dae4SAndroid Build Coastguard Worker# func_warning CATEGORY ARG...
1457*6236dae4SAndroid Build Coastguard Worker# ----------------------------
1458*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed warning message to standard error. Warning
1459*6236dae4SAndroid Build Coastguard Worker# messages can be filtered according to CATEGORY, where this function
1460*6236dae4SAndroid Build Coastguard Worker# elides messages where CATEGORY is not listed in the global variable
1461*6236dae4SAndroid Build Coastguard Worker# 'opt_warning_types'.
1462*6236dae4SAndroid Build Coastguard Workerfunc_warning ()
1463*6236dae4SAndroid Build Coastguard Worker{
1464*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1465*6236dae4SAndroid Build Coastguard Worker
1466*6236dae4SAndroid Build Coastguard Worker    # CATEGORY must be in the warning_categories list!
1467*6236dae4SAndroid Build Coastguard Worker    case " $warning_categories " in
1468*6236dae4SAndroid Build Coastguard Worker      *" $1 "*) ;;
1469*6236dae4SAndroid Build Coastguard Worker      *) func_internal_error "invalid warning category '$1'" ;;
1470*6236dae4SAndroid Build Coastguard Worker    esac
1471*6236dae4SAndroid Build Coastguard Worker
1472*6236dae4SAndroid Build Coastguard Worker    _G_category=$1
1473*6236dae4SAndroid Build Coastguard Worker    shift
1474*6236dae4SAndroid Build Coastguard Worker
1475*6236dae4SAndroid Build Coastguard Worker    case " $opt_warning_types " in
1476*6236dae4SAndroid Build Coastguard Worker      *" $_G_category "*) $warning_func ${1+"$@"} ;;
1477*6236dae4SAndroid Build Coastguard Worker    esac
1478*6236dae4SAndroid Build Coastguard Worker}
1479*6236dae4SAndroid Build Coastguard Worker
1480*6236dae4SAndroid Build Coastguard Worker
1481*6236dae4SAndroid Build Coastguard Worker# func_sort_ver VER1 VER2
1482*6236dae4SAndroid Build Coastguard Worker# -----------------------
1483*6236dae4SAndroid Build Coastguard Worker# 'sort -V' is not generally available.
1484*6236dae4SAndroid Build Coastguard Worker# Note this deviates from the version comparison in automake
1485*6236dae4SAndroid Build Coastguard Worker# in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
1486*6236dae4SAndroid Build Coastguard Worker# but this should suffice as we won't be specifying old
1487*6236dae4SAndroid Build Coastguard Worker# version formats or redundant trailing .0 in bootstrap.conf.
1488*6236dae4SAndroid Build Coastguard Worker# If we did want full compatibility then we should probably
1489*6236dae4SAndroid Build Coastguard Worker# use m4_version_compare from autoconf.
1490*6236dae4SAndroid Build Coastguard Workerfunc_sort_ver ()
1491*6236dae4SAndroid Build Coastguard Worker{
1492*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1493*6236dae4SAndroid Build Coastguard Worker
1494*6236dae4SAndroid Build Coastguard Worker    printf '%s\n%s\n' "$1" "$2" \
1495*6236dae4SAndroid Build Coastguard Worker      | 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
1496*6236dae4SAndroid Build Coastguard Worker}
1497*6236dae4SAndroid Build Coastguard Worker
1498*6236dae4SAndroid Build Coastguard Worker# func_lt_ver PREV CURR
1499*6236dae4SAndroid Build Coastguard Worker# ---------------------
1500*6236dae4SAndroid Build Coastguard Worker# Return true if PREV and CURR are in the correct order according to
1501*6236dae4SAndroid Build Coastguard Worker# func_sort_ver, otherwise false.  Use it like this:
1502*6236dae4SAndroid Build Coastguard Worker#
1503*6236dae4SAndroid Build Coastguard Worker#  func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..."
1504*6236dae4SAndroid Build Coastguard Workerfunc_lt_ver ()
1505*6236dae4SAndroid Build Coastguard Worker{
1506*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1507*6236dae4SAndroid Build Coastguard Worker
1508*6236dae4SAndroid Build Coastguard Worker    test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q`
1509*6236dae4SAndroid Build Coastguard Worker}
1510*6236dae4SAndroid Build Coastguard Worker
1511*6236dae4SAndroid Build Coastguard Worker
1512*6236dae4SAndroid Build Coastguard Worker# Local variables:
1513*6236dae4SAndroid Build Coastguard Worker# mode: shell-script
1514*6236dae4SAndroid Build Coastguard Worker# sh-indentation: 2
1515*6236dae4SAndroid Build Coastguard Worker# eval: (add-hook 'before-save-hook 'time-stamp)
1516*6236dae4SAndroid Build Coastguard Worker# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
1517*6236dae4SAndroid Build Coastguard Worker# time-stamp-time-zone: "UTC"
1518*6236dae4SAndroid Build Coastguard Worker# End:
1519*6236dae4SAndroid Build Coastguard Worker#! /bin/sh
1520*6236dae4SAndroid Build Coastguard Worker
1521*6236dae4SAndroid Build Coastguard Worker# A portable, pluggable option parser for Bourne shell.
1522*6236dae4SAndroid Build Coastguard Worker# Written by Gary V. Vaughan, 2010
1523*6236dae4SAndroid Build Coastguard Worker
1524*6236dae4SAndroid Build Coastguard Worker# This is free software.  There is NO warranty; not even for
1525*6236dae4SAndroid Build Coastguard Worker# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
1526*6236dae4SAndroid Build Coastguard Worker#
1527*6236dae4SAndroid Build Coastguard Worker# Copyright (C) 2010-2019, 2021 Bootstrap Authors
1528*6236dae4SAndroid Build Coastguard Worker#
1529*6236dae4SAndroid Build Coastguard Worker# This file is dual licensed under the terms of the MIT license
1530*6236dae4SAndroid Build Coastguard Worker# <https://opensource.org/license/MIT>, and GPL version 2 or later
1531*6236dae4SAndroid Build Coastguard Worker# <http://www.gnu.org/licenses/gpl-2.0.html>.  You must apply one of
1532*6236dae4SAndroid Build Coastguard Worker# these licenses when using or redistributing this software or any of
1533*6236dae4SAndroid Build Coastguard Worker# the files within it.  See the URLs above, or the file `LICENSE`
1534*6236dae4SAndroid Build Coastguard Worker# included in the Bootstrap distribution for the full license texts.
1535*6236dae4SAndroid Build Coastguard Worker
1536*6236dae4SAndroid Build Coastguard Worker# Please report bugs or propose patches to:
1537*6236dae4SAndroid Build Coastguard Worker# <https://github.com/gnulib-modules/bootstrap/issues>
1538*6236dae4SAndroid Build Coastguard Worker
1539*6236dae4SAndroid Build Coastguard Worker# Set a version string for this script.
1540*6236dae4SAndroid Build Coastguard Workerscriptversion=2019-02-19.15; # UTC
1541*6236dae4SAndroid Build Coastguard Worker
1542*6236dae4SAndroid Build Coastguard Worker
1543*6236dae4SAndroid Build Coastguard Worker## ------ ##
1544*6236dae4SAndroid Build Coastguard Worker## Usage. ##
1545*6236dae4SAndroid Build Coastguard Worker## ------ ##
1546*6236dae4SAndroid Build Coastguard Worker
1547*6236dae4SAndroid Build Coastguard Worker# This file is a library for parsing options in your shell scripts along
1548*6236dae4SAndroid Build Coastguard Worker# with assorted other useful supporting features that you can make use
1549*6236dae4SAndroid Build Coastguard Worker# of too.
1550*6236dae4SAndroid Build Coastguard Worker#
1551*6236dae4SAndroid Build Coastguard Worker# For the simplest scripts you might need only:
1552*6236dae4SAndroid Build Coastguard Worker#
1553*6236dae4SAndroid Build Coastguard Worker#   #!/bin/sh
1554*6236dae4SAndroid Build Coastguard Worker#   . relative/path/to/funclib.sh
1555*6236dae4SAndroid Build Coastguard Worker#   . relative/path/to/options-parser
1556*6236dae4SAndroid Build Coastguard Worker#   scriptversion=1.0
1557*6236dae4SAndroid Build Coastguard Worker#   func_options ${1+"$@"}
1558*6236dae4SAndroid Build Coastguard Worker#   eval set dummy "$func_options_result"; shift
1559*6236dae4SAndroid Build Coastguard Worker#   ...rest of your script...
1560*6236dae4SAndroid Build Coastguard Worker#
1561*6236dae4SAndroid Build Coastguard Worker# In order for the '--version' option to work, you will need to have a
1562*6236dae4SAndroid Build Coastguard Worker# suitably formatted comment like the one at the top of this file
1563*6236dae4SAndroid Build Coastguard Worker# starting with '# Written by ' and ending with '# Copyright'.
1564*6236dae4SAndroid Build Coastguard Worker#
1565*6236dae4SAndroid Build Coastguard Worker# For '-h' and '--help' to work, you will also need a one line
1566*6236dae4SAndroid Build Coastguard Worker# description of your script's purpose in a comment directly above the
1567*6236dae4SAndroid Build Coastguard Worker# '# Written by ' line, like the one at the top of this file.
1568*6236dae4SAndroid Build Coastguard Worker#
1569*6236dae4SAndroid Build Coastguard Worker# The default options also support '--debug', which will turn on shell
1570*6236dae4SAndroid Build Coastguard Worker# execution tracing (see the comment above debug_cmd below for another
1571*6236dae4SAndroid Build Coastguard Worker# use), and '--verbose' and the func_verbose function to allow your script
1572*6236dae4SAndroid Build Coastguard Worker# to display verbose messages only when your user has specified
1573*6236dae4SAndroid Build Coastguard Worker# '--verbose'.
1574*6236dae4SAndroid Build Coastguard Worker#
1575*6236dae4SAndroid Build Coastguard Worker# After sourcing this file, you can plug in processing for additional
1576*6236dae4SAndroid Build Coastguard Worker# options by amending the variables from the 'Configuration' section
1577*6236dae4SAndroid Build Coastguard Worker# below, and following the instructions in the 'Option parsing'
1578*6236dae4SAndroid Build Coastguard Worker# section further down.
1579*6236dae4SAndroid Build Coastguard Worker
1580*6236dae4SAndroid Build Coastguard Worker## -------------- ##
1581*6236dae4SAndroid Build Coastguard Worker## Configuration. ##
1582*6236dae4SAndroid Build Coastguard Worker## -------------- ##
1583*6236dae4SAndroid Build Coastguard Worker
1584*6236dae4SAndroid Build Coastguard Worker# You should override these variables in your script after sourcing this
1585*6236dae4SAndroid Build Coastguard Worker# file so that they reflect the customisations you have added to the
1586*6236dae4SAndroid Build Coastguard Worker# option parser.
1587*6236dae4SAndroid Build Coastguard Worker
1588*6236dae4SAndroid Build Coastguard Worker# The usage line for option parsing errors and the start of '-h' and
1589*6236dae4SAndroid Build Coastguard Worker# '--help' output messages. You can embed shell variables for delayed
1590*6236dae4SAndroid Build Coastguard Worker# expansion at the time the message is displayed, but you will need to
1591*6236dae4SAndroid Build Coastguard Worker# quote other shell meta-characters carefully to prevent them being
1592*6236dae4SAndroid Build Coastguard Worker# expanded when the contents are evaled.
1593*6236dae4SAndroid Build Coastguard Workerusage='$progpath [OPTION]...'
1594*6236dae4SAndroid Build Coastguard Worker
1595*6236dae4SAndroid Build Coastguard Worker# Short help message in response to '-h' and '--help'.  Add to this or
1596*6236dae4SAndroid Build Coastguard Worker# override it after sourcing this library to reflect the full set of
1597*6236dae4SAndroid Build Coastguard Worker# options your script accepts.
1598*6236dae4SAndroid Build Coastguard Workerusage_message="\
1599*6236dae4SAndroid Build Coastguard Worker       --debug        enable verbose shell tracing
1600*6236dae4SAndroid Build Coastguard Worker   -W, --warnings=CATEGORY
1601*6236dae4SAndroid Build Coastguard Worker                      report the warnings falling in CATEGORY [all]
1602*6236dae4SAndroid Build Coastguard Worker   -v, --verbose      verbosely report processing
1603*6236dae4SAndroid Build Coastguard Worker       --version      print version information and exit
1604*6236dae4SAndroid Build Coastguard Worker   -h, --help         print short or long help message and exit
1605*6236dae4SAndroid Build Coastguard Worker"
1606*6236dae4SAndroid Build Coastguard Worker
1607*6236dae4SAndroid Build Coastguard Worker# Additional text appended to 'usage_message' in response to '--help'.
1608*6236dae4SAndroid Build Coastguard Workerlong_help_message="
1609*6236dae4SAndroid Build Coastguard WorkerWarning categories include:
1610*6236dae4SAndroid Build Coastguard Worker       'all'          show all warnings
1611*6236dae4SAndroid Build Coastguard Worker       'none'         turn off all the warnings
1612*6236dae4SAndroid Build Coastguard Worker       'error'        warnings are treated as fatal errors"
1613*6236dae4SAndroid Build Coastguard Worker
1614*6236dae4SAndroid Build Coastguard Worker# Help message printed before fatal option parsing errors.
1615*6236dae4SAndroid Build Coastguard Workerfatal_help="Try '\$progname --help' for more information."
1616*6236dae4SAndroid Build Coastguard Worker
1617*6236dae4SAndroid Build Coastguard Worker
1618*6236dae4SAndroid Build Coastguard Worker
1619*6236dae4SAndroid Build Coastguard Worker## ------------------------- ##
1620*6236dae4SAndroid Build Coastguard Worker## Hook function management. ##
1621*6236dae4SAndroid Build Coastguard Worker## ------------------------- ##
1622*6236dae4SAndroid Build Coastguard Worker
1623*6236dae4SAndroid Build Coastguard Worker# This section contains functions for adding, removing, and running hooks
1624*6236dae4SAndroid Build Coastguard Worker# in the main code.  A hook is just a list of function names that can be
1625*6236dae4SAndroid Build Coastguard Worker# run in order later on.
1626*6236dae4SAndroid Build Coastguard Worker
1627*6236dae4SAndroid Build Coastguard Worker# func_hookable FUNC_NAME
1628*6236dae4SAndroid Build Coastguard Worker# -----------------------
1629*6236dae4SAndroid Build Coastguard Worker# Declare that FUNC_NAME will run hooks added with
1630*6236dae4SAndroid Build Coastguard Worker# 'func_add_hook FUNC_NAME ...'.
1631*6236dae4SAndroid Build Coastguard Workerfunc_hookable ()
1632*6236dae4SAndroid Build Coastguard Worker{
1633*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1634*6236dae4SAndroid Build Coastguard Worker
1635*6236dae4SAndroid Build Coastguard Worker    func_append hookable_fns " $1"
1636*6236dae4SAndroid Build Coastguard Worker}
1637*6236dae4SAndroid Build Coastguard Worker
1638*6236dae4SAndroid Build Coastguard Worker
1639*6236dae4SAndroid Build Coastguard Worker# func_add_hook FUNC_NAME HOOK_FUNC
1640*6236dae4SAndroid Build Coastguard Worker# ---------------------------------
1641*6236dae4SAndroid Build Coastguard Worker# Request that FUNC_NAME call HOOK_FUNC before it returns.  FUNC_NAME must
1642*6236dae4SAndroid Build Coastguard Worker# first have been declared "hookable" by a call to 'func_hookable'.
1643*6236dae4SAndroid Build Coastguard Workerfunc_add_hook ()
1644*6236dae4SAndroid Build Coastguard Worker{
1645*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1646*6236dae4SAndroid Build Coastguard Worker
1647*6236dae4SAndroid Build Coastguard Worker    case " $hookable_fns " in
1648*6236dae4SAndroid Build Coastguard Worker      *" $1 "*) ;;
1649*6236dae4SAndroid Build Coastguard Worker      *) func_fatal_error "'$1' does not accept hook functions." ;;
1650*6236dae4SAndroid Build Coastguard Worker    esac
1651*6236dae4SAndroid Build Coastguard Worker
1652*6236dae4SAndroid Build Coastguard Worker    eval func_append ${1}_hooks '" $2"'
1653*6236dae4SAndroid Build Coastguard Worker}
1654*6236dae4SAndroid Build Coastguard Worker
1655*6236dae4SAndroid Build Coastguard Worker
1656*6236dae4SAndroid Build Coastguard Worker# func_remove_hook FUNC_NAME HOOK_FUNC
1657*6236dae4SAndroid Build Coastguard Worker# ------------------------------------
1658*6236dae4SAndroid Build Coastguard Worker# Remove HOOK_FUNC from the list of hook functions to be called by
1659*6236dae4SAndroid Build Coastguard Worker# FUNC_NAME.
1660*6236dae4SAndroid Build Coastguard Workerfunc_remove_hook ()
1661*6236dae4SAndroid Build Coastguard Worker{
1662*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1663*6236dae4SAndroid Build Coastguard Worker
1664*6236dae4SAndroid Build Coastguard Worker    eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`'
1665*6236dae4SAndroid Build Coastguard Worker}
1666*6236dae4SAndroid Build Coastguard Worker
1667*6236dae4SAndroid Build Coastguard Worker
1668*6236dae4SAndroid Build Coastguard Worker# func_propagate_result FUNC_NAME_A FUNC_NAME_B
1669*6236dae4SAndroid Build Coastguard Worker# ---------------------------------------------
1670*6236dae4SAndroid Build Coastguard Worker# If the *_result variable of FUNC_NAME_A _is set_, assign its value to
1671*6236dae4SAndroid Build Coastguard Worker# *_result variable of FUNC_NAME_B.
1672*6236dae4SAndroid Build Coastguard Workerfunc_propagate_result ()
1673*6236dae4SAndroid Build Coastguard Worker{
1674*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1675*6236dae4SAndroid Build Coastguard Worker
1676*6236dae4SAndroid Build Coastguard Worker    func_propagate_result_result=:
1677*6236dae4SAndroid Build Coastguard Worker    if eval "test \"\${${1}_result+set}\" = set"
1678*6236dae4SAndroid Build Coastguard Worker    then
1679*6236dae4SAndroid Build Coastguard Worker      eval "${2}_result=\$${1}_result"
1680*6236dae4SAndroid Build Coastguard Worker    else
1681*6236dae4SAndroid Build Coastguard Worker      func_propagate_result_result=false
1682*6236dae4SAndroid Build Coastguard Worker    fi
1683*6236dae4SAndroid Build Coastguard Worker}
1684*6236dae4SAndroid Build Coastguard Worker
1685*6236dae4SAndroid Build Coastguard Worker
1686*6236dae4SAndroid Build Coastguard Worker# func_run_hooks FUNC_NAME [ARG]...
1687*6236dae4SAndroid Build Coastguard Worker# ---------------------------------
1688*6236dae4SAndroid Build Coastguard Worker# Run all hook functions registered to FUNC_NAME.
1689*6236dae4SAndroid Build Coastguard Worker# It's assumed that the list of hook functions contains nothing more
1690*6236dae4SAndroid Build Coastguard Worker# than a whitespace-delimited list of legal shell function names, and
1691*6236dae4SAndroid Build Coastguard Worker# no effort is wasted trying to catch shell meta-characters or preserve
1692*6236dae4SAndroid Build Coastguard Worker# whitespace.
1693*6236dae4SAndroid Build Coastguard Workerfunc_run_hooks ()
1694*6236dae4SAndroid Build Coastguard Worker{
1695*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1696*6236dae4SAndroid Build Coastguard Worker
1697*6236dae4SAndroid Build Coastguard Worker    _G_rc_run_hooks=false
1698*6236dae4SAndroid Build Coastguard Worker
1699*6236dae4SAndroid Build Coastguard Worker    case " $hookable_fns " in
1700*6236dae4SAndroid Build Coastguard Worker      *" $1 "*) ;;
1701*6236dae4SAndroid Build Coastguard Worker      *) func_fatal_error "'$1' does not support hook functions." ;;
1702*6236dae4SAndroid Build Coastguard Worker    esac
1703*6236dae4SAndroid Build Coastguard Worker
1704*6236dae4SAndroid Build Coastguard Worker    eval _G_hook_fns=\$$1_hooks; shift
1705*6236dae4SAndroid Build Coastguard Worker
1706*6236dae4SAndroid Build Coastguard Worker    for _G_hook in $_G_hook_fns; do
1707*6236dae4SAndroid Build Coastguard Worker      func_unset "${_G_hook}_result"
1708*6236dae4SAndroid Build Coastguard Worker      eval $_G_hook '${1+"$@"}'
1709*6236dae4SAndroid Build Coastguard Worker      func_propagate_result $_G_hook func_run_hooks
1710*6236dae4SAndroid Build Coastguard Worker      if $func_propagate_result_result; then
1711*6236dae4SAndroid Build Coastguard Worker        eval set dummy "$func_run_hooks_result"; shift
1712*6236dae4SAndroid Build Coastguard Worker      fi
1713*6236dae4SAndroid Build Coastguard Worker    done
1714*6236dae4SAndroid Build Coastguard Worker}
1715*6236dae4SAndroid Build Coastguard Worker
1716*6236dae4SAndroid Build Coastguard Worker
1717*6236dae4SAndroid Build Coastguard Worker
1718*6236dae4SAndroid Build Coastguard Worker## --------------- ##
1719*6236dae4SAndroid Build Coastguard Worker## Option parsing. ##
1720*6236dae4SAndroid Build Coastguard Worker## --------------- ##
1721*6236dae4SAndroid Build Coastguard Worker
1722*6236dae4SAndroid Build Coastguard Worker# In order to add your own option parsing hooks, you must accept the
1723*6236dae4SAndroid Build Coastguard Worker# full positional parameter list from your hook function.  You may remove
1724*6236dae4SAndroid Build Coastguard Worker# or edit any options that you action, and then pass back the remaining
1725*6236dae4SAndroid Build Coastguard Worker# unprocessed options in '<hooked_function_name>_result', escaped
1726*6236dae4SAndroid Build Coastguard Worker# suitably for 'eval'.
1727*6236dae4SAndroid Build Coastguard Worker#
1728*6236dae4SAndroid Build Coastguard Worker# The '<hooked_function_name>_result' variable is automatically unset
1729*6236dae4SAndroid Build Coastguard Worker# before your hook gets called; for best performance, only set the
1730*6236dae4SAndroid Build Coastguard Worker# *_result variable when necessary (i.e. don't call the 'func_quote'
1731*6236dae4SAndroid Build Coastguard Worker# function unnecessarily because it can be an expensive operation on some
1732*6236dae4SAndroid Build Coastguard Worker# machines).
1733*6236dae4SAndroid Build Coastguard Worker#
1734*6236dae4SAndroid Build Coastguard Worker# Like this:
1735*6236dae4SAndroid Build Coastguard Worker#
1736*6236dae4SAndroid Build Coastguard Worker#    my_options_prep ()
1737*6236dae4SAndroid Build Coastguard Worker#    {
1738*6236dae4SAndroid Build Coastguard Worker#        $debug_cmd
1739*6236dae4SAndroid Build Coastguard Worker#
1740*6236dae4SAndroid Build Coastguard Worker#        # Extend the existing usage message.
1741*6236dae4SAndroid Build Coastguard Worker#        usage_message=$usage_message'
1742*6236dae4SAndroid Build Coastguard Worker#      -s, --silent       don'\''t print informational messages
1743*6236dae4SAndroid Build Coastguard Worker#    '
1744*6236dae4SAndroid Build Coastguard Worker#        # No change in '$@' (ignored completely by this hook).  Leave
1745*6236dae4SAndroid Build Coastguard Worker#        # my_options_prep_result variable intact.
1746*6236dae4SAndroid Build Coastguard Worker#    }
1747*6236dae4SAndroid Build Coastguard Worker#    func_add_hook func_options_prep my_options_prep
1748*6236dae4SAndroid Build Coastguard Worker#
1749*6236dae4SAndroid Build Coastguard Worker#
1750*6236dae4SAndroid Build Coastguard Worker#    my_silent_option ()
1751*6236dae4SAndroid Build Coastguard Worker#    {
1752*6236dae4SAndroid Build Coastguard Worker#        $debug_cmd
1753*6236dae4SAndroid Build Coastguard Worker#
1754*6236dae4SAndroid Build Coastguard Worker#        args_changed=false
1755*6236dae4SAndroid Build Coastguard Worker#
1756*6236dae4SAndroid Build Coastguard Worker#        # Note that, for efficiency, we parse as many options as we can
1757*6236dae4SAndroid Build Coastguard Worker#        # recognise in a loop before passing the remainder back to the
1758*6236dae4SAndroid Build Coastguard Worker#        # caller on the first unrecognised argument we encounter.
1759*6236dae4SAndroid Build Coastguard Worker#        while test $# -gt 0; do
1760*6236dae4SAndroid Build Coastguard Worker#          opt=$1; shift
1761*6236dae4SAndroid Build Coastguard Worker#          case $opt in
1762*6236dae4SAndroid Build Coastguard Worker#            --silent|-s) opt_silent=:
1763*6236dae4SAndroid Build Coastguard Worker#                         args_changed=:
1764*6236dae4SAndroid Build Coastguard Worker#                         ;;
1765*6236dae4SAndroid Build Coastguard Worker#            # Separate non-argument short options:
1766*6236dae4SAndroid Build Coastguard Worker#            -s*)         func_split_short_opt "$_G_opt"
1767*6236dae4SAndroid Build Coastguard Worker#                         set dummy "$func_split_short_opt_name" \
1768*6236dae4SAndroid Build Coastguard Worker#                             "-$func_split_short_opt_arg" ${1+"$@"}
1769*6236dae4SAndroid Build Coastguard Worker#                         shift
1770*6236dae4SAndroid Build Coastguard Worker#                         args_changed=:
1771*6236dae4SAndroid Build Coastguard Worker#                         ;;
1772*6236dae4SAndroid Build Coastguard Worker#            *)           # Make sure the first unrecognised option "$_G_opt"
1773*6236dae4SAndroid Build Coastguard Worker#                         # is added back to "$@" in case we need it later,
1774*6236dae4SAndroid Build Coastguard Worker#                         # if $args_changed was set to 'true'.
1775*6236dae4SAndroid Build Coastguard Worker#                         set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
1776*6236dae4SAndroid Build Coastguard Worker#          esac
1777*6236dae4SAndroid Build Coastguard Worker#        done
1778*6236dae4SAndroid Build Coastguard Worker#
1779*6236dae4SAndroid Build Coastguard Worker#        # Only call 'func_quote' here if we processed at least one argument.
1780*6236dae4SAndroid Build Coastguard Worker#        if $args_changed; then
1781*6236dae4SAndroid Build Coastguard Worker#          func_quote eval ${1+"$@"}
1782*6236dae4SAndroid Build Coastguard Worker#          my_silent_option_result=$func_quote_result
1783*6236dae4SAndroid Build Coastguard Worker#        fi
1784*6236dae4SAndroid Build Coastguard Worker#    }
1785*6236dae4SAndroid Build Coastguard Worker#    func_add_hook func_parse_options my_silent_option
1786*6236dae4SAndroid Build Coastguard Worker#
1787*6236dae4SAndroid Build Coastguard Worker#
1788*6236dae4SAndroid Build Coastguard Worker#    my_option_validation ()
1789*6236dae4SAndroid Build Coastguard Worker#    {
1790*6236dae4SAndroid Build Coastguard Worker#        $debug_cmd
1791*6236dae4SAndroid Build Coastguard Worker#
1792*6236dae4SAndroid Build Coastguard Worker#        $opt_silent && $opt_verbose && func_fatal_help "\
1793*6236dae4SAndroid Build Coastguard Worker#    '--silent' and '--verbose' options are mutually exclusive."
1794*6236dae4SAndroid Build Coastguard Worker#    }
1795*6236dae4SAndroid Build Coastguard Worker#    func_add_hook func_validate_options my_option_validation
1796*6236dae4SAndroid Build Coastguard Worker#
1797*6236dae4SAndroid Build Coastguard Worker# You'll also need to manually amend $usage_message to reflect the extra
1798*6236dae4SAndroid Build Coastguard Worker# options you parse.  It's preferable to append if you can, so that
1799*6236dae4SAndroid Build Coastguard Worker# multiple option parsing hooks can be added safely.
1800*6236dae4SAndroid Build Coastguard Worker
1801*6236dae4SAndroid Build Coastguard Worker
1802*6236dae4SAndroid Build Coastguard Worker# func_options_finish [ARG]...
1803*6236dae4SAndroid Build Coastguard Worker# ----------------------------
1804*6236dae4SAndroid Build Coastguard Worker# Finishing the option parse loop (call 'func_options' hooks ATM).
1805*6236dae4SAndroid Build Coastguard Workerfunc_options_finish ()
1806*6236dae4SAndroid Build Coastguard Worker{
1807*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1808*6236dae4SAndroid Build Coastguard Worker
1809*6236dae4SAndroid Build Coastguard Worker    func_run_hooks func_options ${1+"$@"}
1810*6236dae4SAndroid Build Coastguard Worker    func_propagate_result func_run_hooks func_options_finish
1811*6236dae4SAndroid Build Coastguard Worker}
1812*6236dae4SAndroid Build Coastguard Worker
1813*6236dae4SAndroid Build Coastguard Worker
1814*6236dae4SAndroid Build Coastguard Worker# func_options [ARG]...
1815*6236dae4SAndroid Build Coastguard Worker# ---------------------
1816*6236dae4SAndroid Build Coastguard Worker# All the functions called inside func_options are hookable. See the
1817*6236dae4SAndroid Build Coastguard Worker# individual implementations for details.
1818*6236dae4SAndroid Build Coastguard Workerfunc_hookable func_options
1819*6236dae4SAndroid Build Coastguard Workerfunc_options ()
1820*6236dae4SAndroid Build Coastguard Worker{
1821*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1822*6236dae4SAndroid Build Coastguard Worker
1823*6236dae4SAndroid Build Coastguard Worker    _G_options_quoted=false
1824*6236dae4SAndroid Build Coastguard Worker
1825*6236dae4SAndroid Build Coastguard Worker    for my_func in options_prep parse_options validate_options options_finish
1826*6236dae4SAndroid Build Coastguard Worker    do
1827*6236dae4SAndroid Build Coastguard Worker      func_unset func_${my_func}_result
1828*6236dae4SAndroid Build Coastguard Worker      func_unset func_run_hooks_result
1829*6236dae4SAndroid Build Coastguard Worker      eval func_$my_func '${1+"$@"}'
1830*6236dae4SAndroid Build Coastguard Worker      func_propagate_result func_$my_func func_options
1831*6236dae4SAndroid Build Coastguard Worker      if $func_propagate_result_result; then
1832*6236dae4SAndroid Build Coastguard Worker        eval set dummy "$func_options_result"; shift
1833*6236dae4SAndroid Build Coastguard Worker        _G_options_quoted=:
1834*6236dae4SAndroid Build Coastguard Worker      fi
1835*6236dae4SAndroid Build Coastguard Worker    done
1836*6236dae4SAndroid Build Coastguard Worker
1837*6236dae4SAndroid Build Coastguard Worker    $_G_options_quoted || {
1838*6236dae4SAndroid Build Coastguard Worker      # As we (func_options) are top-level options-parser function and
1839*6236dae4SAndroid Build Coastguard Worker      # nobody quoted "$@" for us yet, we need to do it explicitly for
1840*6236dae4SAndroid Build Coastguard Worker      # caller.
1841*6236dae4SAndroid Build Coastguard Worker      func_quote eval ${1+"$@"}
1842*6236dae4SAndroid Build Coastguard Worker      func_options_result=$func_quote_result
1843*6236dae4SAndroid Build Coastguard Worker    }
1844*6236dae4SAndroid Build Coastguard Worker}
1845*6236dae4SAndroid Build Coastguard Worker
1846*6236dae4SAndroid Build Coastguard Worker
1847*6236dae4SAndroid Build Coastguard Worker# func_options_prep [ARG]...
1848*6236dae4SAndroid Build Coastguard Worker# --------------------------
1849*6236dae4SAndroid Build Coastguard Worker# All initialisations required before starting the option parse loop.
1850*6236dae4SAndroid Build Coastguard Worker# Note that when calling hook functions, we pass through the list of
1851*6236dae4SAndroid Build Coastguard Worker# positional parameters.  If a hook function modifies that list, and
1852*6236dae4SAndroid Build Coastguard Worker# needs to propagate that back to rest of this script, then the complete
1853*6236dae4SAndroid Build Coastguard Worker# modified list must be put in 'func_run_hooks_result' before returning.
1854*6236dae4SAndroid Build Coastguard Workerfunc_hookable func_options_prep
1855*6236dae4SAndroid Build Coastguard Workerfunc_options_prep ()
1856*6236dae4SAndroid Build Coastguard Worker{
1857*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1858*6236dae4SAndroid Build Coastguard Worker
1859*6236dae4SAndroid Build Coastguard Worker    # Option defaults:
1860*6236dae4SAndroid Build Coastguard Worker    opt_verbose=false
1861*6236dae4SAndroid Build Coastguard Worker    opt_warning_types=
1862*6236dae4SAndroid Build Coastguard Worker
1863*6236dae4SAndroid Build Coastguard Worker    func_run_hooks func_options_prep ${1+"$@"}
1864*6236dae4SAndroid Build Coastguard Worker    func_propagate_result func_run_hooks func_options_prep
1865*6236dae4SAndroid Build Coastguard Worker}
1866*6236dae4SAndroid Build Coastguard Worker
1867*6236dae4SAndroid Build Coastguard Worker
1868*6236dae4SAndroid Build Coastguard Worker# func_parse_options [ARG]...
1869*6236dae4SAndroid Build Coastguard Worker# ---------------------------
1870*6236dae4SAndroid Build Coastguard Worker# The main option parsing loop.
1871*6236dae4SAndroid Build Coastguard Workerfunc_hookable func_parse_options
1872*6236dae4SAndroid Build Coastguard Workerfunc_parse_options ()
1873*6236dae4SAndroid Build Coastguard Worker{
1874*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1875*6236dae4SAndroid Build Coastguard Worker
1876*6236dae4SAndroid Build Coastguard Worker    _G_parse_options_requote=false
1877*6236dae4SAndroid Build Coastguard Worker    # this just eases exit handling
1878*6236dae4SAndroid Build Coastguard Worker    while test $# -gt 0; do
1879*6236dae4SAndroid Build Coastguard Worker      # Defer to hook functions for initial option parsing, so they
1880*6236dae4SAndroid Build Coastguard Worker      # get priority in the event of reusing an option name.
1881*6236dae4SAndroid Build Coastguard Worker      func_run_hooks func_parse_options ${1+"$@"}
1882*6236dae4SAndroid Build Coastguard Worker      func_propagate_result func_run_hooks func_parse_options
1883*6236dae4SAndroid Build Coastguard Worker      if $func_propagate_result_result; then
1884*6236dae4SAndroid Build Coastguard Worker        eval set dummy "$func_parse_options_result"; shift
1885*6236dae4SAndroid Build Coastguard Worker        # Even though we may have changed "$@", we passed the "$@" array
1886*6236dae4SAndroid Build Coastguard Worker        # down into the hook and it quoted it for us (because we are in
1887*6236dae4SAndroid Build Coastguard Worker        # this if-branch).  No need to quote it again.
1888*6236dae4SAndroid Build Coastguard Worker        _G_parse_options_requote=false
1889*6236dae4SAndroid Build Coastguard Worker      fi
1890*6236dae4SAndroid Build Coastguard Worker
1891*6236dae4SAndroid Build Coastguard Worker      # Break out of the loop if we already parsed every option.
1892*6236dae4SAndroid Build Coastguard Worker      test $# -gt 0 || break
1893*6236dae4SAndroid Build Coastguard Worker
1894*6236dae4SAndroid Build Coastguard Worker      # We expect that one of the options parsed in this function matches
1895*6236dae4SAndroid Build Coastguard Worker      # and thus we remove _G_opt from "$@" and need to re-quote.
1896*6236dae4SAndroid Build Coastguard Worker      _G_match_parse_options=:
1897*6236dae4SAndroid Build Coastguard Worker      _G_opt=$1
1898*6236dae4SAndroid Build Coastguard Worker      shift
1899*6236dae4SAndroid Build Coastguard Worker      case $_G_opt in
1900*6236dae4SAndroid Build Coastguard Worker        --debug|-x)   debug_cmd='set -x'
1901*6236dae4SAndroid Build Coastguard Worker                      func_echo "enabling shell trace mode" >&2
1902*6236dae4SAndroid Build Coastguard Worker                      $debug_cmd
1903*6236dae4SAndroid Build Coastguard Worker                      ;;
1904*6236dae4SAndroid Build Coastguard Worker
1905*6236dae4SAndroid Build Coastguard Worker        --no-warnings|--no-warning|--no-warn)
1906*6236dae4SAndroid Build Coastguard Worker                      set dummy --warnings none ${1+"$@"}
1907*6236dae4SAndroid Build Coastguard Worker                      shift
1908*6236dae4SAndroid Build Coastguard Worker		      ;;
1909*6236dae4SAndroid Build Coastguard Worker
1910*6236dae4SAndroid Build Coastguard Worker        --warnings|--warning|-W)
1911*6236dae4SAndroid Build Coastguard Worker                      if test $# = 0 && func_missing_arg $_G_opt; then
1912*6236dae4SAndroid Build Coastguard Worker                        _G_parse_options_requote=:
1913*6236dae4SAndroid Build Coastguard Worker                        break
1914*6236dae4SAndroid Build Coastguard Worker                      fi
1915*6236dae4SAndroid Build Coastguard Worker                      case " $warning_categories $1" in
1916*6236dae4SAndroid Build Coastguard Worker                        *" $1 "*)
1917*6236dae4SAndroid Build Coastguard Worker                          # trailing space prevents matching last $1 above
1918*6236dae4SAndroid Build Coastguard Worker                          func_append_uniq opt_warning_types " $1"
1919*6236dae4SAndroid Build Coastguard Worker                          ;;
1920*6236dae4SAndroid Build Coastguard Worker                        *all)
1921*6236dae4SAndroid Build Coastguard Worker                          opt_warning_types=$warning_categories
1922*6236dae4SAndroid Build Coastguard Worker                          ;;
1923*6236dae4SAndroid Build Coastguard Worker                        *none)
1924*6236dae4SAndroid Build Coastguard Worker                          opt_warning_types=none
1925*6236dae4SAndroid Build Coastguard Worker                          warning_func=:
1926*6236dae4SAndroid Build Coastguard Worker                          ;;
1927*6236dae4SAndroid Build Coastguard Worker                        *error)
1928*6236dae4SAndroid Build Coastguard Worker                          opt_warning_types=$warning_categories
1929*6236dae4SAndroid Build Coastguard Worker                          warning_func=func_fatal_error
1930*6236dae4SAndroid Build Coastguard Worker                          ;;
1931*6236dae4SAndroid Build Coastguard Worker                        *)
1932*6236dae4SAndroid Build Coastguard Worker                          func_fatal_error \
1933*6236dae4SAndroid Build Coastguard Worker                             "unsupported warning category: '$1'"
1934*6236dae4SAndroid Build Coastguard Worker                          ;;
1935*6236dae4SAndroid Build Coastguard Worker                      esac
1936*6236dae4SAndroid Build Coastguard Worker                      shift
1937*6236dae4SAndroid Build Coastguard Worker                      ;;
1938*6236dae4SAndroid Build Coastguard Worker
1939*6236dae4SAndroid Build Coastguard Worker        --verbose|-v) opt_verbose=: ;;
1940*6236dae4SAndroid Build Coastguard Worker        --version)    func_version ;;
1941*6236dae4SAndroid Build Coastguard Worker        -\?|-h)       func_usage ;;
1942*6236dae4SAndroid Build Coastguard Worker        --help)       func_help ;;
1943*6236dae4SAndroid Build Coastguard Worker
1944*6236dae4SAndroid Build Coastguard Worker	# Separate optargs to long options (plugins may need this):
1945*6236dae4SAndroid Build Coastguard Worker	--*=*)        func_split_equals "$_G_opt"
1946*6236dae4SAndroid Build Coastguard Worker	              set dummy "$func_split_equals_lhs" \
1947*6236dae4SAndroid Build Coastguard Worker                          "$func_split_equals_rhs" ${1+"$@"}
1948*6236dae4SAndroid Build Coastguard Worker                      shift
1949*6236dae4SAndroid Build Coastguard Worker                      ;;
1950*6236dae4SAndroid Build Coastguard Worker
1951*6236dae4SAndroid Build Coastguard Worker       # Separate optargs to short options:
1952*6236dae4SAndroid Build Coastguard Worker        -W*)
1953*6236dae4SAndroid Build Coastguard Worker                      func_split_short_opt "$_G_opt"
1954*6236dae4SAndroid Build Coastguard Worker                      set dummy "$func_split_short_opt_name" \
1955*6236dae4SAndroid Build Coastguard Worker                          "$func_split_short_opt_arg" ${1+"$@"}
1956*6236dae4SAndroid Build Coastguard Worker                      shift
1957*6236dae4SAndroid Build Coastguard Worker                      ;;
1958*6236dae4SAndroid Build Coastguard Worker
1959*6236dae4SAndroid Build Coastguard Worker        # Separate non-argument short options:
1960*6236dae4SAndroid Build Coastguard Worker        -\?*|-h*|-v*|-x*)
1961*6236dae4SAndroid Build Coastguard Worker                      func_split_short_opt "$_G_opt"
1962*6236dae4SAndroid Build Coastguard Worker                      set dummy "$func_split_short_opt_name" \
1963*6236dae4SAndroid Build Coastguard Worker                          "-$func_split_short_opt_arg" ${1+"$@"}
1964*6236dae4SAndroid Build Coastguard Worker                      shift
1965*6236dae4SAndroid Build Coastguard Worker                      ;;
1966*6236dae4SAndroid Build Coastguard Worker
1967*6236dae4SAndroid Build Coastguard Worker        --)           _G_parse_options_requote=: ; break ;;
1968*6236dae4SAndroid Build Coastguard Worker        -*)           func_fatal_help "unrecognised option: '$_G_opt'" ;;
1969*6236dae4SAndroid Build Coastguard Worker        *)            set dummy "$_G_opt" ${1+"$@"}; shift
1970*6236dae4SAndroid Build Coastguard Worker                      _G_match_parse_options=false
1971*6236dae4SAndroid Build Coastguard Worker                      break
1972*6236dae4SAndroid Build Coastguard Worker                      ;;
1973*6236dae4SAndroid Build Coastguard Worker      esac
1974*6236dae4SAndroid Build Coastguard Worker
1975*6236dae4SAndroid Build Coastguard Worker      if $_G_match_parse_options; then
1976*6236dae4SAndroid Build Coastguard Worker        _G_parse_options_requote=:
1977*6236dae4SAndroid Build Coastguard Worker      fi
1978*6236dae4SAndroid Build Coastguard Worker    done
1979*6236dae4SAndroid Build Coastguard Worker
1980*6236dae4SAndroid Build Coastguard Worker    if $_G_parse_options_requote; then
1981*6236dae4SAndroid Build Coastguard Worker      # save modified positional parameters for caller
1982*6236dae4SAndroid Build Coastguard Worker      func_quote eval ${1+"$@"}
1983*6236dae4SAndroid Build Coastguard Worker      func_parse_options_result=$func_quote_result
1984*6236dae4SAndroid Build Coastguard Worker    fi
1985*6236dae4SAndroid Build Coastguard Worker}
1986*6236dae4SAndroid Build Coastguard Worker
1987*6236dae4SAndroid Build Coastguard Worker
1988*6236dae4SAndroid Build Coastguard Worker# func_validate_options [ARG]...
1989*6236dae4SAndroid Build Coastguard Worker# ------------------------------
1990*6236dae4SAndroid Build Coastguard Worker# Perform any sanity checks on option settings and/or unconsumed
1991*6236dae4SAndroid Build Coastguard Worker# arguments.
1992*6236dae4SAndroid Build Coastguard Workerfunc_hookable func_validate_options
1993*6236dae4SAndroid Build Coastguard Workerfunc_validate_options ()
1994*6236dae4SAndroid Build Coastguard Worker{
1995*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
1996*6236dae4SAndroid Build Coastguard Worker
1997*6236dae4SAndroid Build Coastguard Worker    # Display all warnings if -W was not given.
1998*6236dae4SAndroid Build Coastguard Worker    test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
1999*6236dae4SAndroid Build Coastguard Worker
2000*6236dae4SAndroid Build Coastguard Worker    func_run_hooks func_validate_options ${1+"$@"}
2001*6236dae4SAndroid Build Coastguard Worker    func_propagate_result func_run_hooks func_validate_options
2002*6236dae4SAndroid Build Coastguard Worker
2003*6236dae4SAndroid Build Coastguard Worker    # Bail if the options were screwed!
2004*6236dae4SAndroid Build Coastguard Worker    $exit_cmd $EXIT_FAILURE
2005*6236dae4SAndroid Build Coastguard Worker}
2006*6236dae4SAndroid Build Coastguard Worker
2007*6236dae4SAndroid Build Coastguard Worker
2008*6236dae4SAndroid Build Coastguard Worker
2009*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
2010*6236dae4SAndroid Build Coastguard Worker## Helper functions. ##
2011*6236dae4SAndroid Build Coastguard Worker## ----------------- ##
2012*6236dae4SAndroid Build Coastguard Worker
2013*6236dae4SAndroid Build Coastguard Worker# This section contains the helper functions used by the rest of the
2014*6236dae4SAndroid Build Coastguard Worker# hookable option parser framework in ascii-betical order.
2015*6236dae4SAndroid Build Coastguard Worker
2016*6236dae4SAndroid Build Coastguard Worker
2017*6236dae4SAndroid Build Coastguard Worker# func_fatal_help ARG...
2018*6236dae4SAndroid Build Coastguard Worker# ----------------------
2019*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message to standard error, followed by
2020*6236dae4SAndroid Build Coastguard Worker# a help hint, and exit.
2021*6236dae4SAndroid Build Coastguard Workerfunc_fatal_help ()
2022*6236dae4SAndroid Build Coastguard Worker{
2023*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2024*6236dae4SAndroid Build Coastguard Worker
2025*6236dae4SAndroid Build Coastguard Worker    eval \$ECHO \""Usage: $usage"\"
2026*6236dae4SAndroid Build Coastguard Worker    eval \$ECHO \""$fatal_help"\"
2027*6236dae4SAndroid Build Coastguard Worker    func_error ${1+"$@"}
2028*6236dae4SAndroid Build Coastguard Worker    exit $EXIT_FAILURE
2029*6236dae4SAndroid Build Coastguard Worker}
2030*6236dae4SAndroid Build Coastguard Worker
2031*6236dae4SAndroid Build Coastguard Worker
2032*6236dae4SAndroid Build Coastguard Worker# func_help
2033*6236dae4SAndroid Build Coastguard Worker# ---------
2034*6236dae4SAndroid Build Coastguard Worker# Echo long help message to standard output and exit.
2035*6236dae4SAndroid Build Coastguard Workerfunc_help ()
2036*6236dae4SAndroid Build Coastguard Worker{
2037*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2038*6236dae4SAndroid Build Coastguard Worker
2039*6236dae4SAndroid Build Coastguard Worker    func_usage_message
2040*6236dae4SAndroid Build Coastguard Worker    $ECHO "$long_help_message"
2041*6236dae4SAndroid Build Coastguard Worker    exit 0
2042*6236dae4SAndroid Build Coastguard Worker}
2043*6236dae4SAndroid Build Coastguard Worker
2044*6236dae4SAndroid Build Coastguard Worker
2045*6236dae4SAndroid Build Coastguard Worker# func_missing_arg ARGNAME
2046*6236dae4SAndroid Build Coastguard Worker# ------------------------
2047*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message to standard error and set global
2048*6236dae4SAndroid Build Coastguard Worker# exit_cmd.
2049*6236dae4SAndroid Build Coastguard Workerfunc_missing_arg ()
2050*6236dae4SAndroid Build Coastguard Worker{
2051*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2052*6236dae4SAndroid Build Coastguard Worker
2053*6236dae4SAndroid Build Coastguard Worker    func_error "Missing argument for '$1'."
2054*6236dae4SAndroid Build Coastguard Worker    exit_cmd=exit
2055*6236dae4SAndroid Build Coastguard Worker}
2056*6236dae4SAndroid Build Coastguard Worker
2057*6236dae4SAndroid Build Coastguard Worker
2058*6236dae4SAndroid Build Coastguard Worker# func_split_equals STRING
2059*6236dae4SAndroid Build Coastguard Worker# ------------------------
2060*6236dae4SAndroid Build Coastguard Worker# Set func_split_equals_lhs and func_split_equals_rhs shell variables
2061*6236dae4SAndroid Build Coastguard Worker# after splitting STRING at the '=' sign.
2062*6236dae4SAndroid Build Coastguard Workertest -z "$_G_HAVE_XSI_OPS" \
2063*6236dae4SAndroid Build Coastguard Worker    && (eval 'x=a/b/c;
2064*6236dae4SAndroid Build Coastguard Worker      test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
2065*6236dae4SAndroid Build Coastguard Worker    && _G_HAVE_XSI_OPS=yes
2066*6236dae4SAndroid Build Coastguard Worker
2067*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_XSI_OPS"
2068*6236dae4SAndroid Build Coastguard Workerthen
2069*6236dae4SAndroid Build Coastguard Worker  # This is an XSI compatible shell, allowing a faster implementation...
2070*6236dae4SAndroid Build Coastguard Worker  eval 'func_split_equals ()
2071*6236dae4SAndroid Build Coastguard Worker  {
2072*6236dae4SAndroid Build Coastguard Worker      $debug_cmd
2073*6236dae4SAndroid Build Coastguard Worker
2074*6236dae4SAndroid Build Coastguard Worker      func_split_equals_lhs=${1%%=*}
2075*6236dae4SAndroid Build Coastguard Worker      func_split_equals_rhs=${1#*=}
2076*6236dae4SAndroid Build Coastguard Worker      if test "x$func_split_equals_lhs" = "x$1"; then
2077*6236dae4SAndroid Build Coastguard Worker        func_split_equals_rhs=
2078*6236dae4SAndroid Build Coastguard Worker      fi
2079*6236dae4SAndroid Build Coastguard Worker  }'
2080*6236dae4SAndroid Build Coastguard Workerelse
2081*6236dae4SAndroid Build Coastguard Worker  # ...otherwise fall back to using expr, which is often a shell builtin.
2082*6236dae4SAndroid Build Coastguard Worker  func_split_equals ()
2083*6236dae4SAndroid Build Coastguard Worker  {
2084*6236dae4SAndroid Build Coastguard Worker      $debug_cmd
2085*6236dae4SAndroid Build Coastguard Worker
2086*6236dae4SAndroid Build Coastguard Worker      func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'`
2087*6236dae4SAndroid Build Coastguard Worker      func_split_equals_rhs=
2088*6236dae4SAndroid Build Coastguard Worker      test "x$func_split_equals_lhs=" = "x$1" \
2089*6236dae4SAndroid Build Coastguard Worker        || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'`
2090*6236dae4SAndroid Build Coastguard Worker  }
2091*6236dae4SAndroid Build Coastguard Workerfi #func_split_equals
2092*6236dae4SAndroid Build Coastguard Worker
2093*6236dae4SAndroid Build Coastguard Worker
2094*6236dae4SAndroid Build Coastguard Worker# func_split_short_opt SHORTOPT
2095*6236dae4SAndroid Build Coastguard Worker# -----------------------------
2096*6236dae4SAndroid Build Coastguard Worker# Set func_split_short_opt_name and func_split_short_opt_arg shell
2097*6236dae4SAndroid Build Coastguard Worker# variables after splitting SHORTOPT after the 2nd character.
2098*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_XSI_OPS"
2099*6236dae4SAndroid Build Coastguard Workerthen
2100*6236dae4SAndroid Build Coastguard Worker  # This is an XSI compatible shell, allowing a faster implementation...
2101*6236dae4SAndroid Build Coastguard Worker  eval 'func_split_short_opt ()
2102*6236dae4SAndroid Build Coastguard Worker  {
2103*6236dae4SAndroid Build Coastguard Worker      $debug_cmd
2104*6236dae4SAndroid Build Coastguard Worker
2105*6236dae4SAndroid Build Coastguard Worker      func_split_short_opt_arg=${1#??}
2106*6236dae4SAndroid Build Coastguard Worker      func_split_short_opt_name=${1%"$func_split_short_opt_arg"}
2107*6236dae4SAndroid Build Coastguard Worker  }'
2108*6236dae4SAndroid Build Coastguard Workerelse
2109*6236dae4SAndroid Build Coastguard Worker  # ...otherwise fall back to using expr, which is often a shell builtin.
2110*6236dae4SAndroid Build Coastguard Worker  func_split_short_opt ()
2111*6236dae4SAndroid Build Coastguard Worker  {
2112*6236dae4SAndroid Build Coastguard Worker      $debug_cmd
2113*6236dae4SAndroid Build Coastguard Worker
2114*6236dae4SAndroid Build Coastguard Worker      func_split_short_opt_name=`expr "x$1" : 'x\(-.\)'`
2115*6236dae4SAndroid Build Coastguard Worker      func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'`
2116*6236dae4SAndroid Build Coastguard Worker  }
2117*6236dae4SAndroid Build Coastguard Workerfi #func_split_short_opt
2118*6236dae4SAndroid Build Coastguard Worker
2119*6236dae4SAndroid Build Coastguard Worker
2120*6236dae4SAndroid Build Coastguard Worker# func_usage
2121*6236dae4SAndroid Build Coastguard Worker# ----------
2122*6236dae4SAndroid Build Coastguard Worker# Echo short help message to standard output and exit.
2123*6236dae4SAndroid Build Coastguard Workerfunc_usage ()
2124*6236dae4SAndroid Build Coastguard Worker{
2125*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2126*6236dae4SAndroid Build Coastguard Worker
2127*6236dae4SAndroid Build Coastguard Worker    func_usage_message
2128*6236dae4SAndroid Build Coastguard Worker    $ECHO "Run '$progname --help |${PAGER-more}' for full usage"
2129*6236dae4SAndroid Build Coastguard Worker    exit 0
2130*6236dae4SAndroid Build Coastguard Worker}
2131*6236dae4SAndroid Build Coastguard Worker
2132*6236dae4SAndroid Build Coastguard Worker
2133*6236dae4SAndroid Build Coastguard Worker# func_usage_message
2134*6236dae4SAndroid Build Coastguard Worker# ------------------
2135*6236dae4SAndroid Build Coastguard Worker# Echo short help message to standard output.
2136*6236dae4SAndroid Build Coastguard Workerfunc_usage_message ()
2137*6236dae4SAndroid Build Coastguard Worker{
2138*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2139*6236dae4SAndroid Build Coastguard Worker
2140*6236dae4SAndroid Build Coastguard Worker    eval \$ECHO \""Usage: $usage"\"
2141*6236dae4SAndroid Build Coastguard Worker    echo
2142*6236dae4SAndroid Build Coastguard Worker    $SED -n 's|^# ||
2143*6236dae4SAndroid Build Coastguard Worker        /^Written by/{
2144*6236dae4SAndroid Build Coastguard Worker          x;p;x
2145*6236dae4SAndroid Build Coastguard Worker        }
2146*6236dae4SAndroid Build Coastguard Worker	h
2147*6236dae4SAndroid Build Coastguard Worker	/^Written by/q' < "$progpath"
2148*6236dae4SAndroid Build Coastguard Worker    echo
2149*6236dae4SAndroid Build Coastguard Worker    eval \$ECHO \""$usage_message"\"
2150*6236dae4SAndroid Build Coastguard Worker}
2151*6236dae4SAndroid Build Coastguard Worker
2152*6236dae4SAndroid Build Coastguard Worker
2153*6236dae4SAndroid Build Coastguard Worker# func_version
2154*6236dae4SAndroid Build Coastguard Worker# ------------
2155*6236dae4SAndroid Build Coastguard Worker# Echo version message to standard output and exit.
2156*6236dae4SAndroid Build Coastguard Worker# The version message is extracted from the calling file's header
2157*6236dae4SAndroid Build Coastguard Worker# comments, with leading '# ' stripped:
2158*6236dae4SAndroid Build Coastguard Worker#   1. First display the progname and version
2159*6236dae4SAndroid Build Coastguard Worker#   2. Followed by the header comment line matching  /^# Written by /
2160*6236dae4SAndroid Build Coastguard Worker#   3. Then a blank line followed by the first following line matching
2161*6236dae4SAndroid Build Coastguard Worker#      /^# Copyright /
2162*6236dae4SAndroid Build Coastguard Worker#   4. Immediately followed by any lines between the previous matches,
2163*6236dae4SAndroid Build Coastguard Worker#      except lines preceding the intervening completely blank line.
2164*6236dae4SAndroid Build Coastguard Worker# For example, see the header comments of this file.
2165*6236dae4SAndroid Build Coastguard Workerfunc_version ()
2166*6236dae4SAndroid Build Coastguard Worker{
2167*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2168*6236dae4SAndroid Build Coastguard Worker
2169*6236dae4SAndroid Build Coastguard Worker    printf '%s\n' "$progname $scriptversion"
2170*6236dae4SAndroid Build Coastguard Worker    $SED -n '
2171*6236dae4SAndroid Build Coastguard Worker        /^# Written by /!b
2172*6236dae4SAndroid Build Coastguard Worker        s|^# ||; p; n
2173*6236dae4SAndroid Build Coastguard Worker
2174*6236dae4SAndroid Build Coastguard Worker        :fwd2blnk
2175*6236dae4SAndroid Build Coastguard Worker        /./ {
2176*6236dae4SAndroid Build Coastguard Worker          n
2177*6236dae4SAndroid Build Coastguard Worker          b fwd2blnk
2178*6236dae4SAndroid Build Coastguard Worker        }
2179*6236dae4SAndroid Build Coastguard Worker        p; n
2180*6236dae4SAndroid Build Coastguard Worker
2181*6236dae4SAndroid Build Coastguard Worker        :holdwrnt
2182*6236dae4SAndroid Build Coastguard Worker        s|^# ||
2183*6236dae4SAndroid Build Coastguard Worker        s|^# *$||
2184*6236dae4SAndroid Build Coastguard Worker        /^Copyright /!{
2185*6236dae4SAndroid Build Coastguard Worker          /./H
2186*6236dae4SAndroid Build Coastguard Worker          n
2187*6236dae4SAndroid Build Coastguard Worker          b holdwrnt
2188*6236dae4SAndroid Build Coastguard Worker        }
2189*6236dae4SAndroid Build Coastguard Worker
2190*6236dae4SAndroid Build Coastguard Worker        s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2|
2191*6236dae4SAndroid Build Coastguard Worker        G
2192*6236dae4SAndroid Build Coastguard Worker        s|\(\n\)\n*|\1|g
2193*6236dae4SAndroid Build Coastguard Worker        p; q' < "$progpath"
2194*6236dae4SAndroid Build Coastguard Worker
2195*6236dae4SAndroid Build Coastguard Worker    exit $?
2196*6236dae4SAndroid Build Coastguard Worker}
2197*6236dae4SAndroid Build Coastguard Worker
2198*6236dae4SAndroid Build Coastguard Worker
2199*6236dae4SAndroid Build Coastguard Worker# Local variables:
2200*6236dae4SAndroid Build Coastguard Worker# mode: shell-script
2201*6236dae4SAndroid Build Coastguard Worker# sh-indentation: 2
2202*6236dae4SAndroid Build Coastguard Worker# eval: (add-hook 'before-save-hook 'time-stamp)
2203*6236dae4SAndroid Build Coastguard Worker# time-stamp-pattern: "30/scriptversion=%:y-%02m-%02d.%02H; # UTC"
2204*6236dae4SAndroid Build Coastguard Worker# time-stamp-time-zone: "UTC"
2205*6236dae4SAndroid Build Coastguard Worker# End:
2206*6236dae4SAndroid Build Coastguard Worker
2207*6236dae4SAndroid Build Coastguard Worker# Set a version string.
2208*6236dae4SAndroid Build Coastguard Workerscriptversion='(GNU libtool) 2.4.7'
2209*6236dae4SAndroid Build Coastguard Worker
2210*6236dae4SAndroid Build Coastguard Worker
2211*6236dae4SAndroid Build Coastguard Worker# func_echo ARG...
2212*6236dae4SAndroid Build Coastguard Worker# ----------------
2213*6236dae4SAndroid Build Coastguard Worker# Libtool also displays the current mode in messages, so override
2214*6236dae4SAndroid Build Coastguard Worker# funclib.sh func_echo with this custom definition.
2215*6236dae4SAndroid Build Coastguard Workerfunc_echo ()
2216*6236dae4SAndroid Build Coastguard Worker{
2217*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2218*6236dae4SAndroid Build Coastguard Worker
2219*6236dae4SAndroid Build Coastguard Worker    _G_message=$*
2220*6236dae4SAndroid Build Coastguard Worker
2221*6236dae4SAndroid Build Coastguard Worker    func_echo_IFS=$IFS
2222*6236dae4SAndroid Build Coastguard Worker    IFS=$nl
2223*6236dae4SAndroid Build Coastguard Worker    for _G_line in $_G_message; do
2224*6236dae4SAndroid Build Coastguard Worker      IFS=$func_echo_IFS
2225*6236dae4SAndroid Build Coastguard Worker      $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line"
2226*6236dae4SAndroid Build Coastguard Worker    done
2227*6236dae4SAndroid Build Coastguard Worker    IFS=$func_echo_IFS
2228*6236dae4SAndroid Build Coastguard Worker}
2229*6236dae4SAndroid Build Coastguard Worker
2230*6236dae4SAndroid Build Coastguard Worker
2231*6236dae4SAndroid Build Coastguard Worker# func_warning ARG...
2232*6236dae4SAndroid Build Coastguard Worker# -------------------
2233*6236dae4SAndroid Build Coastguard Worker# Libtool warnings are not categorized, so override funclib.sh
2234*6236dae4SAndroid Build Coastguard Worker# func_warning with this simpler definition.
2235*6236dae4SAndroid Build Coastguard Workerfunc_warning ()
2236*6236dae4SAndroid Build Coastguard Worker{
2237*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2238*6236dae4SAndroid Build Coastguard Worker
2239*6236dae4SAndroid Build Coastguard Worker    $warning_func ${1+"$@"}
2240*6236dae4SAndroid Build Coastguard Worker}
2241*6236dae4SAndroid Build Coastguard Worker
2242*6236dae4SAndroid Build Coastguard Worker
2243*6236dae4SAndroid Build Coastguard Worker## ---------------- ##
2244*6236dae4SAndroid Build Coastguard Worker## Options parsing. ##
2245*6236dae4SAndroid Build Coastguard Worker## ---------------- ##
2246*6236dae4SAndroid Build Coastguard Worker
2247*6236dae4SAndroid Build Coastguard Worker# Hook in the functions to make sure our own options are parsed during
2248*6236dae4SAndroid Build Coastguard Worker# the option parsing loop.
2249*6236dae4SAndroid Build Coastguard Worker
2250*6236dae4SAndroid Build Coastguard Workerusage='$progpath [OPTION]... [MODE-ARG]...'
2251*6236dae4SAndroid Build Coastguard Worker
2252*6236dae4SAndroid Build Coastguard Worker# Short help message in response to '-h'.
2253*6236dae4SAndroid Build Coastguard Workerusage_message="Options:
2254*6236dae4SAndroid Build Coastguard Worker       --config             show all configuration variables
2255*6236dae4SAndroid Build Coastguard Worker       --debug              enable verbose shell tracing
2256*6236dae4SAndroid Build Coastguard Worker   -n, --dry-run            display commands without modifying any files
2257*6236dae4SAndroid Build Coastguard Worker       --features           display basic configuration information and exit
2258*6236dae4SAndroid Build Coastguard Worker       --mode=MODE          use operation mode MODE
2259*6236dae4SAndroid Build Coastguard Worker       --no-warnings        equivalent to '-Wnone'
2260*6236dae4SAndroid Build Coastguard Worker       --preserve-dup-deps  don't remove duplicate dependency libraries
2261*6236dae4SAndroid Build Coastguard Worker       --quiet, --silent    don't print informational messages
2262*6236dae4SAndroid Build Coastguard Worker       --tag=TAG            use configuration variables from tag TAG
2263*6236dae4SAndroid Build Coastguard Worker   -v, --verbose            print more informational messages than default
2264*6236dae4SAndroid Build Coastguard Worker       --version            print version information
2265*6236dae4SAndroid Build Coastguard Worker   -W, --warnings=CATEGORY  report the warnings falling in CATEGORY [all]
2266*6236dae4SAndroid Build Coastguard Worker   -h, --help, --help-all   print short, long, or detailed help message
2267*6236dae4SAndroid Build Coastguard Worker"
2268*6236dae4SAndroid Build Coastguard Worker
2269*6236dae4SAndroid Build Coastguard Worker# Additional text appended to 'usage_message' in response to '--help'.
2270*6236dae4SAndroid Build Coastguard Workerfunc_help ()
2271*6236dae4SAndroid Build Coastguard Worker{
2272*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2273*6236dae4SAndroid Build Coastguard Worker
2274*6236dae4SAndroid Build Coastguard Worker    func_usage_message
2275*6236dae4SAndroid Build Coastguard Worker    $ECHO "$long_help_message
2276*6236dae4SAndroid Build Coastguard Worker
2277*6236dae4SAndroid Build Coastguard WorkerMODE must be one of the following:
2278*6236dae4SAndroid Build Coastguard Worker
2279*6236dae4SAndroid Build Coastguard Worker       clean           remove files from the build directory
2280*6236dae4SAndroid Build Coastguard Worker       compile         compile a source file into a libtool object
2281*6236dae4SAndroid Build Coastguard Worker       execute         automatically set library path, then run a program
2282*6236dae4SAndroid Build Coastguard Worker       finish          complete the installation of libtool libraries
2283*6236dae4SAndroid Build Coastguard Worker       install         install libraries or executables
2284*6236dae4SAndroid Build Coastguard Worker       link            create a library or an executable
2285*6236dae4SAndroid Build Coastguard Worker       uninstall       remove libraries from an installed directory
2286*6236dae4SAndroid Build Coastguard Worker
2287*6236dae4SAndroid Build Coastguard WorkerMODE-ARGS vary depending on the MODE.  When passed as first option,
2288*6236dae4SAndroid Build Coastguard Worker'--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that.
2289*6236dae4SAndroid Build Coastguard WorkerTry '$progname --help --mode=MODE' for a more detailed description of MODE.
2290*6236dae4SAndroid Build Coastguard Worker
2291*6236dae4SAndroid Build Coastguard WorkerWhen reporting a bug, please describe a test case to reproduce it and
2292*6236dae4SAndroid Build Coastguard Workerinclude the following information:
2293*6236dae4SAndroid Build Coastguard Worker
2294*6236dae4SAndroid Build Coastguard Worker       host-triplet:   $host
2295*6236dae4SAndroid Build Coastguard Worker       shell:          $SHELL
2296*6236dae4SAndroid Build Coastguard Worker       compiler:       $LTCC
2297*6236dae4SAndroid Build Coastguard Worker       compiler flags: $LTCFLAGS
2298*6236dae4SAndroid Build Coastguard Worker       linker:         $LD (gnu? $with_gnu_ld)
2299*6236dae4SAndroid Build Coastguard Worker       version:        $progname $scriptversion Debian-2.4.7-7+build1
2300*6236dae4SAndroid Build Coastguard Worker       automake:       `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
2301*6236dae4SAndroid Build Coastguard Worker       autoconf:       `($AUTOCONF --version) 2>/dev/null |$SED 1q`
2302*6236dae4SAndroid Build Coastguard Worker
2303*6236dae4SAndroid Build Coastguard WorkerReport bugs to <[email protected]>.
2304*6236dae4SAndroid Build Coastguard WorkerGNU libtool home page: <http://www.gnu.org/s/libtool/>.
2305*6236dae4SAndroid Build Coastguard WorkerGeneral help using GNU software: <http://www.gnu.org/gethelp/>."
2306*6236dae4SAndroid Build Coastguard Worker    exit 0
2307*6236dae4SAndroid Build Coastguard Worker}
2308*6236dae4SAndroid Build Coastguard Worker
2309*6236dae4SAndroid Build Coastguard Worker
2310*6236dae4SAndroid Build Coastguard Worker# func_lo2o OBJECT-NAME
2311*6236dae4SAndroid Build Coastguard Worker# ---------------------
2312*6236dae4SAndroid Build Coastguard Worker# Transform OBJECT-NAME from a '.lo' suffix to the platform specific
2313*6236dae4SAndroid Build Coastguard Worker# object suffix.
2314*6236dae4SAndroid Build Coastguard Worker
2315*6236dae4SAndroid Build Coastguard Workerlo2o=s/\\.lo\$/.$objext/
2316*6236dae4SAndroid Build Coastguard Workero2lo=s/\\.$objext\$/.lo/
2317*6236dae4SAndroid Build Coastguard Worker
2318*6236dae4SAndroid Build Coastguard Workerif test yes = "$_G_HAVE_XSI_OPS"; then
2319*6236dae4SAndroid Build Coastguard Worker  eval 'func_lo2o ()
2320*6236dae4SAndroid Build Coastguard Worker  {
2321*6236dae4SAndroid Build Coastguard Worker    case $1 in
2322*6236dae4SAndroid Build Coastguard Worker      *.lo) func_lo2o_result=${1%.lo}.$objext ;;
2323*6236dae4SAndroid Build Coastguard Worker      *   ) func_lo2o_result=$1               ;;
2324*6236dae4SAndroid Build Coastguard Worker    esac
2325*6236dae4SAndroid Build Coastguard Worker  }'
2326*6236dae4SAndroid Build Coastguard Worker
2327*6236dae4SAndroid Build Coastguard Worker  # func_xform LIBOBJ-OR-SOURCE
2328*6236dae4SAndroid Build Coastguard Worker  # ---------------------------
2329*6236dae4SAndroid Build Coastguard Worker  # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise)
2330*6236dae4SAndroid Build Coastguard Worker  # suffix to a '.lo' libtool-object suffix.
2331*6236dae4SAndroid Build Coastguard Worker  eval 'func_xform ()
2332*6236dae4SAndroid Build Coastguard Worker  {
2333*6236dae4SAndroid Build Coastguard Worker    func_xform_result=${1%.*}.lo
2334*6236dae4SAndroid Build Coastguard Worker  }'
2335*6236dae4SAndroid Build Coastguard Workerelse
2336*6236dae4SAndroid Build Coastguard Worker  # ...otherwise fall back to using sed.
2337*6236dae4SAndroid Build Coastguard Worker  func_lo2o ()
2338*6236dae4SAndroid Build Coastguard Worker  {
2339*6236dae4SAndroid Build Coastguard Worker    func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"`
2340*6236dae4SAndroid Build Coastguard Worker  }
2341*6236dae4SAndroid Build Coastguard Worker
2342*6236dae4SAndroid Build Coastguard Worker  func_xform ()
2343*6236dae4SAndroid Build Coastguard Worker  {
2344*6236dae4SAndroid Build Coastguard Worker    func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'`
2345*6236dae4SAndroid Build Coastguard Worker  }
2346*6236dae4SAndroid Build Coastguard Workerfi
2347*6236dae4SAndroid Build Coastguard Worker
2348*6236dae4SAndroid Build Coastguard Worker
2349*6236dae4SAndroid Build Coastguard Worker# func_fatal_configuration ARG...
2350*6236dae4SAndroid Build Coastguard Worker# -------------------------------
2351*6236dae4SAndroid Build Coastguard Worker# Echo program name prefixed message to standard error, followed by
2352*6236dae4SAndroid Build Coastguard Worker# a configuration failure hint, and exit.
2353*6236dae4SAndroid Build Coastguard Workerfunc_fatal_configuration ()
2354*6236dae4SAndroid Build Coastguard Worker{
2355*6236dae4SAndroid Build Coastguard Worker    func_fatal_error ${1+"$@"} \
2356*6236dae4SAndroid Build Coastguard Worker      "See the $PACKAGE documentation for more information." \
2357*6236dae4SAndroid Build Coastguard Worker      "Fatal configuration error."
2358*6236dae4SAndroid Build Coastguard Worker}
2359*6236dae4SAndroid Build Coastguard Worker
2360*6236dae4SAndroid Build Coastguard Worker
2361*6236dae4SAndroid Build Coastguard Worker# func_config
2362*6236dae4SAndroid Build Coastguard Worker# -----------
2363*6236dae4SAndroid Build Coastguard Worker# Display the configuration for all the tags in this script.
2364*6236dae4SAndroid Build Coastguard Workerfunc_config ()
2365*6236dae4SAndroid Build Coastguard Worker{
2366*6236dae4SAndroid Build Coastguard Worker    re_begincf='^# ### BEGIN LIBTOOL'
2367*6236dae4SAndroid Build Coastguard Worker    re_endcf='^# ### END LIBTOOL'
2368*6236dae4SAndroid Build Coastguard Worker
2369*6236dae4SAndroid Build Coastguard Worker    # Default configuration.
2370*6236dae4SAndroid Build Coastguard Worker    $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath"
2371*6236dae4SAndroid Build Coastguard Worker
2372*6236dae4SAndroid Build Coastguard Worker    # Now print the configurations for the tags.
2373*6236dae4SAndroid Build Coastguard Worker    for tagname in $taglist; do
2374*6236dae4SAndroid Build Coastguard Worker      $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath"
2375*6236dae4SAndroid Build Coastguard Worker    done
2376*6236dae4SAndroid Build Coastguard Worker
2377*6236dae4SAndroid Build Coastguard Worker    exit $?
2378*6236dae4SAndroid Build Coastguard Worker}
2379*6236dae4SAndroid Build Coastguard Worker
2380*6236dae4SAndroid Build Coastguard Worker
2381*6236dae4SAndroid Build Coastguard Worker# func_features
2382*6236dae4SAndroid Build Coastguard Worker# -------------
2383*6236dae4SAndroid Build Coastguard Worker# Display the features supported by this script.
2384*6236dae4SAndroid Build Coastguard Workerfunc_features ()
2385*6236dae4SAndroid Build Coastguard Worker{
2386*6236dae4SAndroid Build Coastguard Worker    echo "host: $host"
2387*6236dae4SAndroid Build Coastguard Worker    if test yes = "$build_libtool_libs"; then
2388*6236dae4SAndroid Build Coastguard Worker      echo "enable shared libraries"
2389*6236dae4SAndroid Build Coastguard Worker    else
2390*6236dae4SAndroid Build Coastguard Worker      echo "disable shared libraries"
2391*6236dae4SAndroid Build Coastguard Worker    fi
2392*6236dae4SAndroid Build Coastguard Worker    if test yes = "$build_old_libs"; then
2393*6236dae4SAndroid Build Coastguard Worker      echo "enable static libraries"
2394*6236dae4SAndroid Build Coastguard Worker    else
2395*6236dae4SAndroid Build Coastguard Worker      echo "disable static libraries"
2396*6236dae4SAndroid Build Coastguard Worker    fi
2397*6236dae4SAndroid Build Coastguard Worker
2398*6236dae4SAndroid Build Coastguard Worker    exit $?
2399*6236dae4SAndroid Build Coastguard Worker}
2400*6236dae4SAndroid Build Coastguard Worker
2401*6236dae4SAndroid Build Coastguard Worker
2402*6236dae4SAndroid Build Coastguard Worker# func_enable_tag TAGNAME
2403*6236dae4SAndroid Build Coastguard Worker# -----------------------
2404*6236dae4SAndroid Build Coastguard Worker# Verify that TAGNAME is valid, and either flag an error and exit, or
2405*6236dae4SAndroid Build Coastguard Worker# enable the TAGNAME tag.  We also add TAGNAME to the global $taglist
2406*6236dae4SAndroid Build Coastguard Worker# variable here.
2407*6236dae4SAndroid Build Coastguard Workerfunc_enable_tag ()
2408*6236dae4SAndroid Build Coastguard Worker{
2409*6236dae4SAndroid Build Coastguard Worker    # Global variable:
2410*6236dae4SAndroid Build Coastguard Worker    tagname=$1
2411*6236dae4SAndroid Build Coastguard Worker
2412*6236dae4SAndroid Build Coastguard Worker    re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
2413*6236dae4SAndroid Build Coastguard Worker    re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
2414*6236dae4SAndroid Build Coastguard Worker    sed_extractcf=/$re_begincf/,/$re_endcf/p
2415*6236dae4SAndroid Build Coastguard Worker
2416*6236dae4SAndroid Build Coastguard Worker    # Validate tagname.
2417*6236dae4SAndroid Build Coastguard Worker    case $tagname in
2418*6236dae4SAndroid Build Coastguard Worker      *[!-_A-Za-z0-9,/]*)
2419*6236dae4SAndroid Build Coastguard Worker        func_fatal_error "invalid tag name: $tagname"
2420*6236dae4SAndroid Build Coastguard Worker        ;;
2421*6236dae4SAndroid Build Coastguard Worker    esac
2422*6236dae4SAndroid Build Coastguard Worker
2423*6236dae4SAndroid Build Coastguard Worker    # Don't test for the "default" C tag, as we know it's
2424*6236dae4SAndroid Build Coastguard Worker    # there but not specially marked.
2425*6236dae4SAndroid Build Coastguard Worker    case $tagname in
2426*6236dae4SAndroid Build Coastguard Worker        CC) ;;
2427*6236dae4SAndroid Build Coastguard Worker    *)
2428*6236dae4SAndroid Build Coastguard Worker        if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
2429*6236dae4SAndroid Build Coastguard Worker	  taglist="$taglist $tagname"
2430*6236dae4SAndroid Build Coastguard Worker
2431*6236dae4SAndroid Build Coastguard Worker	  # Evaluate the configuration.  Be careful to quote the path
2432*6236dae4SAndroid Build Coastguard Worker	  # and the sed script, to avoid splitting on whitespace, but
2433*6236dae4SAndroid Build Coastguard Worker	  # also don't use non-portable quotes within backquotes within
2434*6236dae4SAndroid Build Coastguard Worker	  # quotes we have to do it in 2 steps:
2435*6236dae4SAndroid Build Coastguard Worker	  extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
2436*6236dae4SAndroid Build Coastguard Worker	  eval "$extractedcf"
2437*6236dae4SAndroid Build Coastguard Worker        else
2438*6236dae4SAndroid Build Coastguard Worker	  func_error "ignoring unknown tag $tagname"
2439*6236dae4SAndroid Build Coastguard Worker        fi
2440*6236dae4SAndroid Build Coastguard Worker        ;;
2441*6236dae4SAndroid Build Coastguard Worker    esac
2442*6236dae4SAndroid Build Coastguard Worker}
2443*6236dae4SAndroid Build Coastguard Worker
2444*6236dae4SAndroid Build Coastguard Worker
2445*6236dae4SAndroid Build Coastguard Worker# func_check_version_match
2446*6236dae4SAndroid Build Coastguard Worker# ------------------------
2447*6236dae4SAndroid Build Coastguard Worker# Ensure that we are using m4 macros, and libtool script from the same
2448*6236dae4SAndroid Build Coastguard Worker# release of libtool.
2449*6236dae4SAndroid Build Coastguard Workerfunc_check_version_match ()
2450*6236dae4SAndroid Build Coastguard Worker{
2451*6236dae4SAndroid Build Coastguard Worker    if test "$package_revision" != "$macro_revision"; then
2452*6236dae4SAndroid Build Coastguard Worker      if test "$VERSION" != "$macro_version"; then
2453*6236dae4SAndroid Build Coastguard Worker        if test -z "$macro_version"; then
2454*6236dae4SAndroid Build Coastguard Worker          cat >&2 <<_LT_EOF
2455*6236dae4SAndroid Build Coastguard Worker$progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
2456*6236dae4SAndroid Build Coastguard Worker$progname: definition of this LT_INIT comes from an older release.
2457*6236dae4SAndroid Build Coastguard Worker$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
2458*6236dae4SAndroid Build Coastguard Worker$progname: and run autoconf again.
2459*6236dae4SAndroid Build Coastguard Worker_LT_EOF
2460*6236dae4SAndroid Build Coastguard Worker        else
2461*6236dae4SAndroid Build Coastguard Worker          cat >&2 <<_LT_EOF
2462*6236dae4SAndroid Build Coastguard Worker$progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
2463*6236dae4SAndroid Build Coastguard Worker$progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
2464*6236dae4SAndroid Build Coastguard Worker$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
2465*6236dae4SAndroid Build Coastguard Worker$progname: and run autoconf again.
2466*6236dae4SAndroid Build Coastguard Worker_LT_EOF
2467*6236dae4SAndroid Build Coastguard Worker        fi
2468*6236dae4SAndroid Build Coastguard Worker      else
2469*6236dae4SAndroid Build Coastguard Worker        cat >&2 <<_LT_EOF
2470*6236dae4SAndroid Build Coastguard Worker$progname: Version mismatch error.  This is $PACKAGE $VERSION, revision $package_revision,
2471*6236dae4SAndroid Build Coastguard Worker$progname: but the definition of this LT_INIT comes from revision $macro_revision.
2472*6236dae4SAndroid Build Coastguard Worker$progname: You should recreate aclocal.m4 with macros from revision $package_revision
2473*6236dae4SAndroid Build Coastguard Worker$progname: of $PACKAGE $VERSION and run autoconf again.
2474*6236dae4SAndroid Build Coastguard Worker_LT_EOF
2475*6236dae4SAndroid Build Coastguard Worker      fi
2476*6236dae4SAndroid Build Coastguard Worker
2477*6236dae4SAndroid Build Coastguard Worker      exit $EXIT_MISMATCH
2478*6236dae4SAndroid Build Coastguard Worker    fi
2479*6236dae4SAndroid Build Coastguard Worker}
2480*6236dae4SAndroid Build Coastguard Worker
2481*6236dae4SAndroid Build Coastguard Worker
2482*6236dae4SAndroid Build Coastguard Worker# libtool_options_prep [ARG]...
2483*6236dae4SAndroid Build Coastguard Worker# -----------------------------
2484*6236dae4SAndroid Build Coastguard Worker# Preparation for options parsed by libtool.
2485*6236dae4SAndroid Build Coastguard Workerlibtool_options_prep ()
2486*6236dae4SAndroid Build Coastguard Worker{
2487*6236dae4SAndroid Build Coastguard Worker    $debug_mode
2488*6236dae4SAndroid Build Coastguard Worker
2489*6236dae4SAndroid Build Coastguard Worker    # Option defaults:
2490*6236dae4SAndroid Build Coastguard Worker    opt_config=false
2491*6236dae4SAndroid Build Coastguard Worker    opt_dlopen=
2492*6236dae4SAndroid Build Coastguard Worker    opt_dry_run=false
2493*6236dae4SAndroid Build Coastguard Worker    opt_help=false
2494*6236dae4SAndroid Build Coastguard Worker    opt_mode=
2495*6236dae4SAndroid Build Coastguard Worker    opt_preserve_dup_deps=false
2496*6236dae4SAndroid Build Coastguard Worker    opt_quiet=false
2497*6236dae4SAndroid Build Coastguard Worker
2498*6236dae4SAndroid Build Coastguard Worker    nonopt=
2499*6236dae4SAndroid Build Coastguard Worker    preserve_args=
2500*6236dae4SAndroid Build Coastguard Worker
2501*6236dae4SAndroid Build Coastguard Worker    _G_rc_lt_options_prep=:
2502*6236dae4SAndroid Build Coastguard Worker
2503*6236dae4SAndroid Build Coastguard Worker    _G_rc_lt_options_prep=:
2504*6236dae4SAndroid Build Coastguard Worker
2505*6236dae4SAndroid Build Coastguard Worker    # Shorthand for --mode=foo, only valid as the first argument
2506*6236dae4SAndroid Build Coastguard Worker    case $1 in
2507*6236dae4SAndroid Build Coastguard Worker    clean|clea|cle|cl)
2508*6236dae4SAndroid Build Coastguard Worker      shift; set dummy --mode clean ${1+"$@"}; shift
2509*6236dae4SAndroid Build Coastguard Worker      ;;
2510*6236dae4SAndroid Build Coastguard Worker    compile|compil|compi|comp|com|co|c)
2511*6236dae4SAndroid Build Coastguard Worker      shift; set dummy --mode compile ${1+"$@"}; shift
2512*6236dae4SAndroid Build Coastguard Worker      ;;
2513*6236dae4SAndroid Build Coastguard Worker    execute|execut|execu|exec|exe|ex|e)
2514*6236dae4SAndroid Build Coastguard Worker      shift; set dummy --mode execute ${1+"$@"}; shift
2515*6236dae4SAndroid Build Coastguard Worker      ;;
2516*6236dae4SAndroid Build Coastguard Worker    finish|finis|fini|fin|fi|f)
2517*6236dae4SAndroid Build Coastguard Worker      shift; set dummy --mode finish ${1+"$@"}; shift
2518*6236dae4SAndroid Build Coastguard Worker      ;;
2519*6236dae4SAndroid Build Coastguard Worker    install|instal|insta|inst|ins|in|i)
2520*6236dae4SAndroid Build Coastguard Worker      shift; set dummy --mode install ${1+"$@"}; shift
2521*6236dae4SAndroid Build Coastguard Worker      ;;
2522*6236dae4SAndroid Build Coastguard Worker    link|lin|li|l)
2523*6236dae4SAndroid Build Coastguard Worker      shift; set dummy --mode link ${1+"$@"}; shift
2524*6236dae4SAndroid Build Coastguard Worker      ;;
2525*6236dae4SAndroid Build Coastguard Worker    uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
2526*6236dae4SAndroid Build Coastguard Worker      shift; set dummy --mode uninstall ${1+"$@"}; shift
2527*6236dae4SAndroid Build Coastguard Worker      ;;
2528*6236dae4SAndroid Build Coastguard Worker    *)
2529*6236dae4SAndroid Build Coastguard Worker      _G_rc_lt_options_prep=false
2530*6236dae4SAndroid Build Coastguard Worker      ;;
2531*6236dae4SAndroid Build Coastguard Worker    esac
2532*6236dae4SAndroid Build Coastguard Worker
2533*6236dae4SAndroid Build Coastguard Worker    if $_G_rc_lt_options_prep; then
2534*6236dae4SAndroid Build Coastguard Worker      # Pass back the list of options.
2535*6236dae4SAndroid Build Coastguard Worker      func_quote eval ${1+"$@"}
2536*6236dae4SAndroid Build Coastguard Worker      libtool_options_prep_result=$func_quote_result
2537*6236dae4SAndroid Build Coastguard Worker    fi
2538*6236dae4SAndroid Build Coastguard Worker}
2539*6236dae4SAndroid Build Coastguard Workerfunc_add_hook func_options_prep libtool_options_prep
2540*6236dae4SAndroid Build Coastguard Worker
2541*6236dae4SAndroid Build Coastguard Worker
2542*6236dae4SAndroid Build Coastguard Worker# libtool_parse_options [ARG]...
2543*6236dae4SAndroid Build Coastguard Worker# ---------------------------------
2544*6236dae4SAndroid Build Coastguard Worker# Provide handling for libtool specific options.
2545*6236dae4SAndroid Build Coastguard Workerlibtool_parse_options ()
2546*6236dae4SAndroid Build Coastguard Worker{
2547*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2548*6236dae4SAndroid Build Coastguard Worker
2549*6236dae4SAndroid Build Coastguard Worker    _G_rc_lt_parse_options=false
2550*6236dae4SAndroid Build Coastguard Worker
2551*6236dae4SAndroid Build Coastguard Worker    # Perform our own loop to consume as many options as possible in
2552*6236dae4SAndroid Build Coastguard Worker    # each iteration.
2553*6236dae4SAndroid Build Coastguard Worker    while test $# -gt 0; do
2554*6236dae4SAndroid Build Coastguard Worker      _G_match_lt_parse_options=:
2555*6236dae4SAndroid Build Coastguard Worker      _G_opt=$1
2556*6236dae4SAndroid Build Coastguard Worker      shift
2557*6236dae4SAndroid Build Coastguard Worker      case $_G_opt in
2558*6236dae4SAndroid Build Coastguard Worker        --dry-run|--dryrun|-n)
2559*6236dae4SAndroid Build Coastguard Worker                        opt_dry_run=:
2560*6236dae4SAndroid Build Coastguard Worker                        ;;
2561*6236dae4SAndroid Build Coastguard Worker
2562*6236dae4SAndroid Build Coastguard Worker        --config)       func_config ;;
2563*6236dae4SAndroid Build Coastguard Worker
2564*6236dae4SAndroid Build Coastguard Worker        --dlopen|-dlopen)
2565*6236dae4SAndroid Build Coastguard Worker                        opt_dlopen="${opt_dlopen+$opt_dlopen
2566*6236dae4SAndroid Build Coastguard Worker}$1"
2567*6236dae4SAndroid Build Coastguard Worker                        shift
2568*6236dae4SAndroid Build Coastguard Worker                        ;;
2569*6236dae4SAndroid Build Coastguard Worker
2570*6236dae4SAndroid Build Coastguard Worker        --preserve-dup-deps)
2571*6236dae4SAndroid Build Coastguard Worker                        opt_preserve_dup_deps=: ;;
2572*6236dae4SAndroid Build Coastguard Worker
2573*6236dae4SAndroid Build Coastguard Worker        --features)     func_features ;;
2574*6236dae4SAndroid Build Coastguard Worker
2575*6236dae4SAndroid Build Coastguard Worker        --finish)       set dummy --mode finish ${1+"$@"}; shift ;;
2576*6236dae4SAndroid Build Coastguard Worker
2577*6236dae4SAndroid Build Coastguard Worker        --help)         opt_help=: ;;
2578*6236dae4SAndroid Build Coastguard Worker
2579*6236dae4SAndroid Build Coastguard Worker        --help-all)     opt_help=': help-all' ;;
2580*6236dae4SAndroid Build Coastguard Worker
2581*6236dae4SAndroid Build Coastguard Worker        --mode)         test $# = 0 && func_missing_arg $_G_opt && break
2582*6236dae4SAndroid Build Coastguard Worker                        opt_mode=$1
2583*6236dae4SAndroid Build Coastguard Worker                        case $1 in
2584*6236dae4SAndroid Build Coastguard Worker                          # Valid mode arguments:
2585*6236dae4SAndroid Build Coastguard Worker                          clean|compile|execute|finish|install|link|relink|uninstall) ;;
2586*6236dae4SAndroid Build Coastguard Worker
2587*6236dae4SAndroid Build Coastguard Worker                          # Catch anything else as an error
2588*6236dae4SAndroid Build Coastguard Worker                          *) func_error "invalid argument for $_G_opt"
2589*6236dae4SAndroid Build Coastguard Worker                             exit_cmd=exit
2590*6236dae4SAndroid Build Coastguard Worker                             break
2591*6236dae4SAndroid Build Coastguard Worker                             ;;
2592*6236dae4SAndroid Build Coastguard Worker                        esac
2593*6236dae4SAndroid Build Coastguard Worker                        shift
2594*6236dae4SAndroid Build Coastguard Worker                        ;;
2595*6236dae4SAndroid Build Coastguard Worker
2596*6236dae4SAndroid Build Coastguard Worker        --no-silent|--no-quiet)
2597*6236dae4SAndroid Build Coastguard Worker                        opt_quiet=false
2598*6236dae4SAndroid Build Coastguard Worker                        func_append preserve_args " $_G_opt"
2599*6236dae4SAndroid Build Coastguard Worker                        ;;
2600*6236dae4SAndroid Build Coastguard Worker
2601*6236dae4SAndroid Build Coastguard Worker        --no-warnings|--no-warning|--no-warn)
2602*6236dae4SAndroid Build Coastguard Worker                        opt_warning=false
2603*6236dae4SAndroid Build Coastguard Worker                        func_append preserve_args " $_G_opt"
2604*6236dae4SAndroid Build Coastguard Worker                        ;;
2605*6236dae4SAndroid Build Coastguard Worker
2606*6236dae4SAndroid Build Coastguard Worker        --no-verbose)
2607*6236dae4SAndroid Build Coastguard Worker                        opt_verbose=false
2608*6236dae4SAndroid Build Coastguard Worker                        func_append preserve_args " $_G_opt"
2609*6236dae4SAndroid Build Coastguard Worker                        ;;
2610*6236dae4SAndroid Build Coastguard Worker
2611*6236dae4SAndroid Build Coastguard Worker        --silent|--quiet)
2612*6236dae4SAndroid Build Coastguard Worker                        opt_quiet=:
2613*6236dae4SAndroid Build Coastguard Worker                        opt_verbose=false
2614*6236dae4SAndroid Build Coastguard Worker                        func_append preserve_args " $_G_opt"
2615*6236dae4SAndroid Build Coastguard Worker                        ;;
2616*6236dae4SAndroid Build Coastguard Worker
2617*6236dae4SAndroid Build Coastguard Worker        --tag)          test $# = 0 && func_missing_arg $_G_opt && break
2618*6236dae4SAndroid Build Coastguard Worker                        opt_tag=$1
2619*6236dae4SAndroid Build Coastguard Worker                        func_append preserve_args " $_G_opt $1"
2620*6236dae4SAndroid Build Coastguard Worker                        func_enable_tag "$1"
2621*6236dae4SAndroid Build Coastguard Worker                        shift
2622*6236dae4SAndroid Build Coastguard Worker                        ;;
2623*6236dae4SAndroid Build Coastguard Worker
2624*6236dae4SAndroid Build Coastguard Worker        --verbose|-v)   opt_quiet=false
2625*6236dae4SAndroid Build Coastguard Worker                        opt_verbose=:
2626*6236dae4SAndroid Build Coastguard Worker                        func_append preserve_args " $_G_opt"
2627*6236dae4SAndroid Build Coastguard Worker                        ;;
2628*6236dae4SAndroid Build Coastguard Worker
2629*6236dae4SAndroid Build Coastguard Worker        # An option not handled by this hook function:
2630*6236dae4SAndroid Build Coastguard Worker        *)              set dummy "$_G_opt" ${1+"$@"} ; shift
2631*6236dae4SAndroid Build Coastguard Worker                        _G_match_lt_parse_options=false
2632*6236dae4SAndroid Build Coastguard Worker                        break
2633*6236dae4SAndroid Build Coastguard Worker                        ;;
2634*6236dae4SAndroid Build Coastguard Worker      esac
2635*6236dae4SAndroid Build Coastguard Worker      $_G_match_lt_parse_options && _G_rc_lt_parse_options=:
2636*6236dae4SAndroid Build Coastguard Worker    done
2637*6236dae4SAndroid Build Coastguard Worker
2638*6236dae4SAndroid Build Coastguard Worker    if $_G_rc_lt_parse_options; then
2639*6236dae4SAndroid Build Coastguard Worker      # save modified positional parameters for caller
2640*6236dae4SAndroid Build Coastguard Worker      func_quote eval ${1+"$@"}
2641*6236dae4SAndroid Build Coastguard Worker      libtool_parse_options_result=$func_quote_result
2642*6236dae4SAndroid Build Coastguard Worker    fi
2643*6236dae4SAndroid Build Coastguard Worker}
2644*6236dae4SAndroid Build Coastguard Workerfunc_add_hook func_parse_options libtool_parse_options
2645*6236dae4SAndroid Build Coastguard Worker
2646*6236dae4SAndroid Build Coastguard Worker
2647*6236dae4SAndroid Build Coastguard Worker
2648*6236dae4SAndroid Build Coastguard Worker# libtool_validate_options [ARG]...
2649*6236dae4SAndroid Build Coastguard Worker# ---------------------------------
2650*6236dae4SAndroid Build Coastguard Worker# Perform any sanity checks on option settings and/or unconsumed
2651*6236dae4SAndroid Build Coastguard Worker# arguments.
2652*6236dae4SAndroid Build Coastguard Workerlibtool_validate_options ()
2653*6236dae4SAndroid Build Coastguard Worker{
2654*6236dae4SAndroid Build Coastguard Worker    # save first non-option argument
2655*6236dae4SAndroid Build Coastguard Worker    if test 0 -lt $#; then
2656*6236dae4SAndroid Build Coastguard Worker      nonopt=$1
2657*6236dae4SAndroid Build Coastguard Worker      shift
2658*6236dae4SAndroid Build Coastguard Worker    fi
2659*6236dae4SAndroid Build Coastguard Worker
2660*6236dae4SAndroid Build Coastguard Worker    # preserve --debug
2661*6236dae4SAndroid Build Coastguard Worker    test : = "$debug_cmd" || func_append preserve_args " --debug"
2662*6236dae4SAndroid Build Coastguard Worker
2663*6236dae4SAndroid Build Coastguard Worker    case $host in
2664*6236dae4SAndroid Build Coastguard Worker      # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452
2665*6236dae4SAndroid Build Coastguard Worker      # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788
2666*6236dae4SAndroid Build Coastguard Worker      *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*)
2667*6236dae4SAndroid Build Coastguard Worker        # don't eliminate duplications in $postdeps and $predeps
2668*6236dae4SAndroid Build Coastguard Worker        opt_duplicate_compiler_generated_deps=:
2669*6236dae4SAndroid Build Coastguard Worker        ;;
2670*6236dae4SAndroid Build Coastguard Worker      *)
2671*6236dae4SAndroid Build Coastguard Worker        opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
2672*6236dae4SAndroid Build Coastguard Worker        ;;
2673*6236dae4SAndroid Build Coastguard Worker    esac
2674*6236dae4SAndroid Build Coastguard Worker
2675*6236dae4SAndroid Build Coastguard Worker    $opt_help || {
2676*6236dae4SAndroid Build Coastguard Worker      # Sanity checks first:
2677*6236dae4SAndroid Build Coastguard Worker      func_check_version_match
2678*6236dae4SAndroid Build Coastguard Worker
2679*6236dae4SAndroid Build Coastguard Worker      test yes != "$build_libtool_libs" \
2680*6236dae4SAndroid Build Coastguard Worker        && test yes != "$build_old_libs" \
2681*6236dae4SAndroid Build Coastguard Worker        && func_fatal_configuration "not configured to build any kind of library"
2682*6236dae4SAndroid Build Coastguard Worker
2683*6236dae4SAndroid Build Coastguard Worker      # Darwin sucks
2684*6236dae4SAndroid Build Coastguard Worker      eval std_shrext=\"$shrext_cmds\"
2685*6236dae4SAndroid Build Coastguard Worker
2686*6236dae4SAndroid Build Coastguard Worker      # Only execute mode is allowed to have -dlopen flags.
2687*6236dae4SAndroid Build Coastguard Worker      if test -n "$opt_dlopen" && test execute != "$opt_mode"; then
2688*6236dae4SAndroid Build Coastguard Worker        func_error "unrecognized option '-dlopen'"
2689*6236dae4SAndroid Build Coastguard Worker        $ECHO "$help" 1>&2
2690*6236dae4SAndroid Build Coastguard Worker        exit $EXIT_FAILURE
2691*6236dae4SAndroid Build Coastguard Worker      fi
2692*6236dae4SAndroid Build Coastguard Worker
2693*6236dae4SAndroid Build Coastguard Worker      # Change the help message to a mode-specific one.
2694*6236dae4SAndroid Build Coastguard Worker      generic_help=$help
2695*6236dae4SAndroid Build Coastguard Worker      help="Try '$progname --help --mode=$opt_mode' for more information."
2696*6236dae4SAndroid Build Coastguard Worker    }
2697*6236dae4SAndroid Build Coastguard Worker
2698*6236dae4SAndroid Build Coastguard Worker    # Pass back the unparsed argument list
2699*6236dae4SAndroid Build Coastguard Worker    func_quote eval ${1+"$@"}
2700*6236dae4SAndroid Build Coastguard Worker    libtool_validate_options_result=$func_quote_result
2701*6236dae4SAndroid Build Coastguard Worker}
2702*6236dae4SAndroid Build Coastguard Workerfunc_add_hook func_validate_options libtool_validate_options
2703*6236dae4SAndroid Build Coastguard Worker
2704*6236dae4SAndroid Build Coastguard Worker
2705*6236dae4SAndroid Build Coastguard Worker# Process options as early as possible so that --help and --version
2706*6236dae4SAndroid Build Coastguard Worker# can return quickly.
2707*6236dae4SAndroid Build Coastguard Workerfunc_options ${1+"$@"}
2708*6236dae4SAndroid Build Coastguard Workereval set dummy "$func_options_result"; shift
2709*6236dae4SAndroid Build Coastguard Worker
2710*6236dae4SAndroid Build Coastguard Worker
2711*6236dae4SAndroid Build Coastguard Worker
2712*6236dae4SAndroid Build Coastguard Worker## ----------- ##
2713*6236dae4SAndroid Build Coastguard Worker##    Main.    ##
2714*6236dae4SAndroid Build Coastguard Worker## ----------- ##
2715*6236dae4SAndroid Build Coastguard Worker
2716*6236dae4SAndroid Build Coastguard Workermagic='%%%MAGIC variable%%%'
2717*6236dae4SAndroid Build Coastguard Workermagic_exe='%%%MAGIC EXE variable%%%'
2718*6236dae4SAndroid Build Coastguard Worker
2719*6236dae4SAndroid Build Coastguard Worker# Global variables.
2720*6236dae4SAndroid Build Coastguard Workerextracted_archives=
2721*6236dae4SAndroid Build Coastguard Workerextracted_serial=0
2722*6236dae4SAndroid Build Coastguard Worker
2723*6236dae4SAndroid Build Coastguard Worker# If this variable is set in any of the actions, the command in it
2724*6236dae4SAndroid Build Coastguard Worker# will be execed at the end.  This prevents here-documents from being
2725*6236dae4SAndroid Build Coastguard Worker# left over by shells.
2726*6236dae4SAndroid Build Coastguard Workerexec_cmd=
2727*6236dae4SAndroid Build Coastguard Worker
2728*6236dae4SAndroid Build Coastguard Worker
2729*6236dae4SAndroid Build Coastguard Worker# A function that is used when there is no print builtin or printf.
2730*6236dae4SAndroid Build Coastguard Workerfunc_fallback_echo ()
2731*6236dae4SAndroid Build Coastguard Worker{
2732*6236dae4SAndroid Build Coastguard Worker  eval 'cat <<_LTECHO_EOF
2733*6236dae4SAndroid Build Coastguard Worker$1
2734*6236dae4SAndroid Build Coastguard Worker_LTECHO_EOF'
2735*6236dae4SAndroid Build Coastguard Worker}
2736*6236dae4SAndroid Build Coastguard Worker
2737*6236dae4SAndroid Build Coastguard Worker# func_generated_by_libtool
2738*6236dae4SAndroid Build Coastguard Worker# True iff stdin has been generated by Libtool. This function is only
2739*6236dae4SAndroid Build Coastguard Worker# a basic sanity check; it will hardly flush out determined imposters.
2740*6236dae4SAndroid Build Coastguard Workerfunc_generated_by_libtool_p ()
2741*6236dae4SAndroid Build Coastguard Worker{
2742*6236dae4SAndroid Build Coastguard Worker  $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
2743*6236dae4SAndroid Build Coastguard Worker}
2744*6236dae4SAndroid Build Coastguard Worker
2745*6236dae4SAndroid Build Coastguard Worker# func_lalib_p file
2746*6236dae4SAndroid Build Coastguard Worker# True iff FILE is a libtool '.la' library or '.lo' object file.
2747*6236dae4SAndroid Build Coastguard Worker# This function is only a basic sanity check; it will hardly flush out
2748*6236dae4SAndroid Build Coastguard Worker# determined imposters.
2749*6236dae4SAndroid Build Coastguard Workerfunc_lalib_p ()
2750*6236dae4SAndroid Build Coastguard Worker{
2751*6236dae4SAndroid Build Coastguard Worker    test -f "$1" &&
2752*6236dae4SAndroid Build Coastguard Worker      $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p
2753*6236dae4SAndroid Build Coastguard Worker}
2754*6236dae4SAndroid Build Coastguard Worker
2755*6236dae4SAndroid Build Coastguard Worker# func_lalib_unsafe_p file
2756*6236dae4SAndroid Build Coastguard Worker# True iff FILE is a libtool '.la' library or '.lo' object file.
2757*6236dae4SAndroid Build Coastguard Worker# This function implements the same check as func_lalib_p without
2758*6236dae4SAndroid Build Coastguard Worker# resorting to external programs.  To this end, it redirects stdin and
2759*6236dae4SAndroid Build Coastguard Worker# closes it afterwards, without saving the original file descriptor.
2760*6236dae4SAndroid Build Coastguard Worker# As a safety measure, use it only where a negative result would be
2761*6236dae4SAndroid Build Coastguard Worker# fatal anyway.  Works if 'file' does not exist.
2762*6236dae4SAndroid Build Coastguard Workerfunc_lalib_unsafe_p ()
2763*6236dae4SAndroid Build Coastguard Worker{
2764*6236dae4SAndroid Build Coastguard Worker    lalib_p=no
2765*6236dae4SAndroid Build Coastguard Worker    if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then
2766*6236dae4SAndroid Build Coastguard Worker	for lalib_p_l in 1 2 3 4
2767*6236dae4SAndroid Build Coastguard Worker	do
2768*6236dae4SAndroid Build Coastguard Worker	    read lalib_p_line
2769*6236dae4SAndroid Build Coastguard Worker	    case $lalib_p_line in
2770*6236dae4SAndroid Build Coastguard Worker		\#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;;
2771*6236dae4SAndroid Build Coastguard Worker	    esac
2772*6236dae4SAndroid Build Coastguard Worker	done
2773*6236dae4SAndroid Build Coastguard Worker	exec 0<&5 5<&-
2774*6236dae4SAndroid Build Coastguard Worker    fi
2775*6236dae4SAndroid Build Coastguard Worker    test yes = "$lalib_p"
2776*6236dae4SAndroid Build Coastguard Worker}
2777*6236dae4SAndroid Build Coastguard Worker
2778*6236dae4SAndroid Build Coastguard Worker# func_ltwrapper_script_p file
2779*6236dae4SAndroid Build Coastguard Worker# True iff FILE is a libtool wrapper script
2780*6236dae4SAndroid Build Coastguard Worker# This function is only a basic sanity check; it will hardly flush out
2781*6236dae4SAndroid Build Coastguard Worker# determined imposters.
2782*6236dae4SAndroid Build Coastguard Workerfunc_ltwrapper_script_p ()
2783*6236dae4SAndroid Build Coastguard Worker{
2784*6236dae4SAndroid Build Coastguard Worker    test -f "$1" &&
2785*6236dae4SAndroid Build Coastguard Worker      $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p
2786*6236dae4SAndroid Build Coastguard Worker}
2787*6236dae4SAndroid Build Coastguard Worker
2788*6236dae4SAndroid Build Coastguard Worker# func_ltwrapper_executable_p file
2789*6236dae4SAndroid Build Coastguard Worker# True iff FILE is a libtool wrapper executable
2790*6236dae4SAndroid Build Coastguard Worker# This function is only a basic sanity check; it will hardly flush out
2791*6236dae4SAndroid Build Coastguard Worker# determined imposters.
2792*6236dae4SAndroid Build Coastguard Workerfunc_ltwrapper_executable_p ()
2793*6236dae4SAndroid Build Coastguard Worker{
2794*6236dae4SAndroid Build Coastguard Worker    func_ltwrapper_exec_suffix=
2795*6236dae4SAndroid Build Coastguard Worker    case $1 in
2796*6236dae4SAndroid Build Coastguard Worker    *.exe) ;;
2797*6236dae4SAndroid Build Coastguard Worker    *) func_ltwrapper_exec_suffix=.exe ;;
2798*6236dae4SAndroid Build Coastguard Worker    esac
2799*6236dae4SAndroid Build Coastguard Worker    $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1
2800*6236dae4SAndroid Build Coastguard Worker}
2801*6236dae4SAndroid Build Coastguard Worker
2802*6236dae4SAndroid Build Coastguard Worker# func_ltwrapper_scriptname file
2803*6236dae4SAndroid Build Coastguard Worker# Assumes file is an ltwrapper_executable
2804*6236dae4SAndroid Build Coastguard Worker# uses $file to determine the appropriate filename for a
2805*6236dae4SAndroid Build Coastguard Worker# temporary ltwrapper_script.
2806*6236dae4SAndroid Build Coastguard Workerfunc_ltwrapper_scriptname ()
2807*6236dae4SAndroid Build Coastguard Worker{
2808*6236dae4SAndroid Build Coastguard Worker    func_dirname_and_basename "$1" "" "."
2809*6236dae4SAndroid Build Coastguard Worker    func_stripname '' '.exe' "$func_basename_result"
2810*6236dae4SAndroid Build Coastguard Worker    func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper
2811*6236dae4SAndroid Build Coastguard Worker}
2812*6236dae4SAndroid Build Coastguard Worker
2813*6236dae4SAndroid Build Coastguard Worker# func_ltwrapper_p file
2814*6236dae4SAndroid Build Coastguard Worker# True iff FILE is a libtool wrapper script or wrapper executable
2815*6236dae4SAndroid Build Coastguard Worker# This function is only a basic sanity check; it will hardly flush out
2816*6236dae4SAndroid Build Coastguard Worker# determined imposters.
2817*6236dae4SAndroid Build Coastguard Workerfunc_ltwrapper_p ()
2818*6236dae4SAndroid Build Coastguard Worker{
2819*6236dae4SAndroid Build Coastguard Worker    func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1"
2820*6236dae4SAndroid Build Coastguard Worker}
2821*6236dae4SAndroid Build Coastguard Worker
2822*6236dae4SAndroid Build Coastguard Worker
2823*6236dae4SAndroid Build Coastguard Worker# func_execute_cmds commands fail_cmd
2824*6236dae4SAndroid Build Coastguard Worker# Execute tilde-delimited COMMANDS.
2825*6236dae4SAndroid Build Coastguard Worker# If FAIL_CMD is given, eval that upon failure.
2826*6236dae4SAndroid Build Coastguard Worker# FAIL_CMD may read-access the current command in variable CMD!
2827*6236dae4SAndroid Build Coastguard Workerfunc_execute_cmds ()
2828*6236dae4SAndroid Build Coastguard Worker{
2829*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2830*6236dae4SAndroid Build Coastguard Worker
2831*6236dae4SAndroid Build Coastguard Worker    save_ifs=$IFS; IFS='~'
2832*6236dae4SAndroid Build Coastguard Worker    for cmd in $1; do
2833*6236dae4SAndroid Build Coastguard Worker      IFS=$sp$nl
2834*6236dae4SAndroid Build Coastguard Worker      eval cmd=\"$cmd\"
2835*6236dae4SAndroid Build Coastguard Worker      IFS=$save_ifs
2836*6236dae4SAndroid Build Coastguard Worker      func_show_eval "$cmd" "${2-:}"
2837*6236dae4SAndroid Build Coastguard Worker    done
2838*6236dae4SAndroid Build Coastguard Worker    IFS=$save_ifs
2839*6236dae4SAndroid Build Coastguard Worker}
2840*6236dae4SAndroid Build Coastguard Worker
2841*6236dae4SAndroid Build Coastguard Worker
2842*6236dae4SAndroid Build Coastguard Worker# func_source file
2843*6236dae4SAndroid Build Coastguard Worker# Source FILE, adding directory component if necessary.
2844*6236dae4SAndroid Build Coastguard Worker# Note that it is not necessary on cygwin/mingw to append a dot to
2845*6236dae4SAndroid Build Coastguard Worker# FILE even if both FILE and FILE.exe exist: automatic-append-.exe
2846*6236dae4SAndroid Build Coastguard Worker# behavior happens only for exec(3), not for open(2)!  Also, sourcing
2847*6236dae4SAndroid Build Coastguard Worker# 'FILE.' does not work on cygwin managed mounts.
2848*6236dae4SAndroid Build Coastguard Workerfunc_source ()
2849*6236dae4SAndroid Build Coastguard Worker{
2850*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2851*6236dae4SAndroid Build Coastguard Worker
2852*6236dae4SAndroid Build Coastguard Worker    case $1 in
2853*6236dae4SAndroid Build Coastguard Worker    */* | *\\*)	. "$1" ;;
2854*6236dae4SAndroid Build Coastguard Worker    *)		. "./$1" ;;
2855*6236dae4SAndroid Build Coastguard Worker    esac
2856*6236dae4SAndroid Build Coastguard Worker}
2857*6236dae4SAndroid Build Coastguard Worker
2858*6236dae4SAndroid Build Coastguard Worker
2859*6236dae4SAndroid Build Coastguard Worker# func_resolve_sysroot PATH
2860*6236dae4SAndroid Build Coastguard Worker# Replace a leading = in PATH with a sysroot.  Store the result into
2861*6236dae4SAndroid Build Coastguard Worker# func_resolve_sysroot_result
2862*6236dae4SAndroid Build Coastguard Workerfunc_resolve_sysroot ()
2863*6236dae4SAndroid Build Coastguard Worker{
2864*6236dae4SAndroid Build Coastguard Worker  func_resolve_sysroot_result=$1
2865*6236dae4SAndroid Build Coastguard Worker  case $func_resolve_sysroot_result in
2866*6236dae4SAndroid Build Coastguard Worker  =*)
2867*6236dae4SAndroid Build Coastguard Worker    func_stripname '=' '' "$func_resolve_sysroot_result"
2868*6236dae4SAndroid Build Coastguard Worker    func_resolve_sysroot_result=$lt_sysroot$func_stripname_result
2869*6236dae4SAndroid Build Coastguard Worker    ;;
2870*6236dae4SAndroid Build Coastguard Worker  esac
2871*6236dae4SAndroid Build Coastguard Worker}
2872*6236dae4SAndroid Build Coastguard Worker
2873*6236dae4SAndroid Build Coastguard Worker# func_replace_sysroot PATH
2874*6236dae4SAndroid Build Coastguard Worker# If PATH begins with the sysroot, replace it with = and
2875*6236dae4SAndroid Build Coastguard Worker# store the result into func_replace_sysroot_result.
2876*6236dae4SAndroid Build Coastguard Workerfunc_replace_sysroot ()
2877*6236dae4SAndroid Build Coastguard Worker{
2878*6236dae4SAndroid Build Coastguard Worker  case $lt_sysroot:$1 in
2879*6236dae4SAndroid Build Coastguard Worker  ?*:"$lt_sysroot"*)
2880*6236dae4SAndroid Build Coastguard Worker    func_stripname "$lt_sysroot" '' "$1"
2881*6236dae4SAndroid Build Coastguard Worker    func_replace_sysroot_result='='$func_stripname_result
2882*6236dae4SAndroid Build Coastguard Worker    ;;
2883*6236dae4SAndroid Build Coastguard Worker  *)
2884*6236dae4SAndroid Build Coastguard Worker    # Including no sysroot.
2885*6236dae4SAndroid Build Coastguard Worker    func_replace_sysroot_result=$1
2886*6236dae4SAndroid Build Coastguard Worker    ;;
2887*6236dae4SAndroid Build Coastguard Worker  esac
2888*6236dae4SAndroid Build Coastguard Worker}
2889*6236dae4SAndroid Build Coastguard Worker
2890*6236dae4SAndroid Build Coastguard Worker# func_infer_tag arg
2891*6236dae4SAndroid Build Coastguard Worker# Infer tagged configuration to use if any are available and
2892*6236dae4SAndroid Build Coastguard Worker# if one wasn't chosen via the "--tag" command line option.
2893*6236dae4SAndroid Build Coastguard Worker# Only attempt this if the compiler in the base compile
2894*6236dae4SAndroid Build Coastguard Worker# command doesn't match the default compiler.
2895*6236dae4SAndroid Build Coastguard Worker# arg is usually of the form 'gcc ...'
2896*6236dae4SAndroid Build Coastguard Workerfunc_infer_tag ()
2897*6236dae4SAndroid Build Coastguard Worker{
2898*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
2899*6236dae4SAndroid Build Coastguard Worker
2900*6236dae4SAndroid Build Coastguard Worker    if test -n "$available_tags" && test -z "$tagname"; then
2901*6236dae4SAndroid Build Coastguard Worker      CC_quoted=
2902*6236dae4SAndroid Build Coastguard Worker      for arg in $CC; do
2903*6236dae4SAndroid Build Coastguard Worker	func_append_quoted CC_quoted "$arg"
2904*6236dae4SAndroid Build Coastguard Worker      done
2905*6236dae4SAndroid Build Coastguard Worker      CC_expanded=`func_echo_all $CC`
2906*6236dae4SAndroid Build Coastguard Worker      CC_quoted_expanded=`func_echo_all $CC_quoted`
2907*6236dae4SAndroid Build Coastguard Worker      case $@ in
2908*6236dae4SAndroid Build Coastguard Worker      # Blanks in the command may have been stripped by the calling shell,
2909*6236dae4SAndroid Build Coastguard Worker      # but not from the CC environment variable when configure was run.
2910*6236dae4SAndroid Build Coastguard Worker      " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
2911*6236dae4SAndroid Build Coastguard Worker      " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;;
2912*6236dae4SAndroid Build Coastguard Worker      # Blanks at the start of $base_compile will cause this to fail
2913*6236dae4SAndroid Build Coastguard Worker      # if we don't check for them as well.
2914*6236dae4SAndroid Build Coastguard Worker      *)
2915*6236dae4SAndroid Build Coastguard Worker	for z in $available_tags; do
2916*6236dae4SAndroid Build Coastguard Worker	  if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then
2917*6236dae4SAndroid Build Coastguard Worker	    # Evaluate the configuration.
2918*6236dae4SAndroid Build Coastguard Worker	    eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
2919*6236dae4SAndroid Build Coastguard Worker	    CC_quoted=
2920*6236dae4SAndroid Build Coastguard Worker	    for arg in $CC; do
2921*6236dae4SAndroid Build Coastguard Worker	      # Double-quote args containing other shell metacharacters.
2922*6236dae4SAndroid Build Coastguard Worker	      func_append_quoted CC_quoted "$arg"
2923*6236dae4SAndroid Build Coastguard Worker	    done
2924*6236dae4SAndroid Build Coastguard Worker	    CC_expanded=`func_echo_all $CC`
2925*6236dae4SAndroid Build Coastguard Worker	    CC_quoted_expanded=`func_echo_all $CC_quoted`
2926*6236dae4SAndroid Build Coastguard Worker	    case "$@ " in
2927*6236dae4SAndroid Build Coastguard Worker	    " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \
2928*6236dae4SAndroid Build Coastguard Worker	    " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*)
2929*6236dae4SAndroid Build Coastguard Worker	      # The compiler in the base compile command matches
2930*6236dae4SAndroid Build Coastguard Worker	      # the one in the tagged configuration.
2931*6236dae4SAndroid Build Coastguard Worker	      # Assume this is the tagged configuration we want.
2932*6236dae4SAndroid Build Coastguard Worker	      tagname=$z
2933*6236dae4SAndroid Build Coastguard Worker	      break
2934*6236dae4SAndroid Build Coastguard Worker	      ;;
2935*6236dae4SAndroid Build Coastguard Worker	    esac
2936*6236dae4SAndroid Build Coastguard Worker	  fi
2937*6236dae4SAndroid Build Coastguard Worker	done
2938*6236dae4SAndroid Build Coastguard Worker	# If $tagname still isn't set, then no tagged configuration
2939*6236dae4SAndroid Build Coastguard Worker	# was found and let the user know that the "--tag" command
2940*6236dae4SAndroid Build Coastguard Worker	# line option must be used.
2941*6236dae4SAndroid Build Coastguard Worker	if test -z "$tagname"; then
2942*6236dae4SAndroid Build Coastguard Worker	  func_echo "unable to infer tagged configuration"
2943*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "specify a tag with '--tag'"
2944*6236dae4SAndroid Build Coastguard Worker#	else
2945*6236dae4SAndroid Build Coastguard Worker#	  func_verbose "using $tagname tagged configuration"
2946*6236dae4SAndroid Build Coastguard Worker	fi
2947*6236dae4SAndroid Build Coastguard Worker	;;
2948*6236dae4SAndroid Build Coastguard Worker      esac
2949*6236dae4SAndroid Build Coastguard Worker    fi
2950*6236dae4SAndroid Build Coastguard Worker}
2951*6236dae4SAndroid Build Coastguard Worker
2952*6236dae4SAndroid Build Coastguard Worker
2953*6236dae4SAndroid Build Coastguard Worker
2954*6236dae4SAndroid Build Coastguard Worker# func_write_libtool_object output_name pic_name nonpic_name
2955*6236dae4SAndroid Build Coastguard Worker# Create a libtool object file (analogous to a ".la" file),
2956*6236dae4SAndroid Build Coastguard Worker# but don't create it if we're doing a dry run.
2957*6236dae4SAndroid Build Coastguard Workerfunc_write_libtool_object ()
2958*6236dae4SAndroid Build Coastguard Worker{
2959*6236dae4SAndroid Build Coastguard Worker    write_libobj=$1
2960*6236dae4SAndroid Build Coastguard Worker    if test yes = "$build_libtool_libs"; then
2961*6236dae4SAndroid Build Coastguard Worker      write_lobj=\'$2\'
2962*6236dae4SAndroid Build Coastguard Worker    else
2963*6236dae4SAndroid Build Coastguard Worker      write_lobj=none
2964*6236dae4SAndroid Build Coastguard Worker    fi
2965*6236dae4SAndroid Build Coastguard Worker
2966*6236dae4SAndroid Build Coastguard Worker    if test yes = "$build_old_libs"; then
2967*6236dae4SAndroid Build Coastguard Worker      write_oldobj=\'$3\'
2968*6236dae4SAndroid Build Coastguard Worker    else
2969*6236dae4SAndroid Build Coastguard Worker      write_oldobj=none
2970*6236dae4SAndroid Build Coastguard Worker    fi
2971*6236dae4SAndroid Build Coastguard Worker
2972*6236dae4SAndroid Build Coastguard Worker    $opt_dry_run || {
2973*6236dae4SAndroid Build Coastguard Worker      cat >${write_libobj}T <<EOF
2974*6236dae4SAndroid Build Coastguard Worker# $write_libobj - a libtool object file
2975*6236dae4SAndroid Build Coastguard Worker# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
2976*6236dae4SAndroid Build Coastguard Worker#
2977*6236dae4SAndroid Build Coastguard Worker# Please DO NOT delete this file!
2978*6236dae4SAndroid Build Coastguard Worker# It is necessary for linking the library.
2979*6236dae4SAndroid Build Coastguard Worker
2980*6236dae4SAndroid Build Coastguard Worker# Name of the PIC object.
2981*6236dae4SAndroid Build Coastguard Workerpic_object=$write_lobj
2982*6236dae4SAndroid Build Coastguard Worker
2983*6236dae4SAndroid Build Coastguard Worker# Name of the non-PIC object
2984*6236dae4SAndroid Build Coastguard Workernon_pic_object=$write_oldobj
2985*6236dae4SAndroid Build Coastguard Worker
2986*6236dae4SAndroid Build Coastguard WorkerEOF
2987*6236dae4SAndroid Build Coastguard Worker      $MV "${write_libobj}T" "$write_libobj"
2988*6236dae4SAndroid Build Coastguard Worker    }
2989*6236dae4SAndroid Build Coastguard Worker}
2990*6236dae4SAndroid Build Coastguard Worker
2991*6236dae4SAndroid Build Coastguard Worker
2992*6236dae4SAndroid Build Coastguard Worker##################################################
2993*6236dae4SAndroid Build Coastguard Worker# FILE NAME AND PATH CONVERSION HELPER FUNCTIONS #
2994*6236dae4SAndroid Build Coastguard Worker##################################################
2995*6236dae4SAndroid Build Coastguard Worker
2996*6236dae4SAndroid Build Coastguard Worker# func_convert_core_file_wine_to_w32 ARG
2997*6236dae4SAndroid Build Coastguard Worker# Helper function used by file name conversion functions when $build is *nix,
2998*6236dae4SAndroid Build Coastguard Worker# and $host is mingw, cygwin, or some other w32 environment. Relies on a
2999*6236dae4SAndroid Build Coastguard Worker# correctly configured wine environment available, with the winepath program
3000*6236dae4SAndroid Build Coastguard Worker# in $build's $PATH.
3001*6236dae4SAndroid Build Coastguard Worker#
3002*6236dae4SAndroid Build Coastguard Worker# ARG is the $build file name to be converted to w32 format.
3003*6236dae4SAndroid Build Coastguard Worker# Result is available in $func_convert_core_file_wine_to_w32_result, and will
3004*6236dae4SAndroid Build Coastguard Worker# be empty on error (or when ARG is empty)
3005*6236dae4SAndroid Build Coastguard Workerfunc_convert_core_file_wine_to_w32 ()
3006*6236dae4SAndroid Build Coastguard Worker{
3007*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3008*6236dae4SAndroid Build Coastguard Worker
3009*6236dae4SAndroid Build Coastguard Worker  func_convert_core_file_wine_to_w32_result=$1
3010*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3011*6236dae4SAndroid Build Coastguard Worker    # Unfortunately, winepath does not exit with a non-zero error code, so we
3012*6236dae4SAndroid Build Coastguard Worker    # are forced to check the contents of stdout. On the other hand, if the
3013*6236dae4SAndroid Build Coastguard Worker    # command is not found, the shell will set an exit code of 127 and print
3014*6236dae4SAndroid Build Coastguard Worker    # *an error message* to stdout. So we must check for both error code of
3015*6236dae4SAndroid Build Coastguard Worker    # zero AND non-empty stdout, which explains the odd construction:
3016*6236dae4SAndroid Build Coastguard Worker    func_convert_core_file_wine_to_w32_tmp=`winepath -w "$1" 2>/dev/null`
3017*6236dae4SAndroid Build Coastguard Worker    if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then
3018*6236dae4SAndroid Build Coastguard Worker      func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" |
3019*6236dae4SAndroid Build Coastguard Worker        $SED -e "$sed_naive_backslashify"`
3020*6236dae4SAndroid Build Coastguard Worker    else
3021*6236dae4SAndroid Build Coastguard Worker      func_convert_core_file_wine_to_w32_result=
3022*6236dae4SAndroid Build Coastguard Worker    fi
3023*6236dae4SAndroid Build Coastguard Worker  fi
3024*6236dae4SAndroid Build Coastguard Worker}
3025*6236dae4SAndroid Build Coastguard Worker# end: func_convert_core_file_wine_to_w32
3026*6236dae4SAndroid Build Coastguard Worker
3027*6236dae4SAndroid Build Coastguard Worker
3028*6236dae4SAndroid Build Coastguard Worker# func_convert_core_path_wine_to_w32 ARG
3029*6236dae4SAndroid Build Coastguard Worker# Helper function used by path conversion functions when $build is *nix, and
3030*6236dae4SAndroid Build Coastguard Worker# $host is mingw, cygwin, or some other w32 environment. Relies on a correctly
3031*6236dae4SAndroid Build Coastguard Worker# configured wine environment available, with the winepath program in $build's
3032*6236dae4SAndroid Build Coastguard Worker# $PATH. Assumes ARG has no leading or trailing path separator characters.
3033*6236dae4SAndroid Build Coastguard Worker#
3034*6236dae4SAndroid Build Coastguard Worker# ARG is path to be converted from $build format to win32.
3035*6236dae4SAndroid Build Coastguard Worker# Result is available in $func_convert_core_path_wine_to_w32_result.
3036*6236dae4SAndroid Build Coastguard Worker# Unconvertible file (directory) names in ARG are skipped; if no directory names
3037*6236dae4SAndroid Build Coastguard Worker# are convertible, then the result may be empty.
3038*6236dae4SAndroid Build Coastguard Workerfunc_convert_core_path_wine_to_w32 ()
3039*6236dae4SAndroid Build Coastguard Worker{
3040*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3041*6236dae4SAndroid Build Coastguard Worker
3042*6236dae4SAndroid Build Coastguard Worker  # unfortunately, winepath doesn't convert paths, only file names
3043*6236dae4SAndroid Build Coastguard Worker  func_convert_core_path_wine_to_w32_result=
3044*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3045*6236dae4SAndroid Build Coastguard Worker    oldIFS=$IFS
3046*6236dae4SAndroid Build Coastguard Worker    IFS=:
3047*6236dae4SAndroid Build Coastguard Worker    for func_convert_core_path_wine_to_w32_f in $1; do
3048*6236dae4SAndroid Build Coastguard Worker      IFS=$oldIFS
3049*6236dae4SAndroid Build Coastguard Worker      func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f"
3050*6236dae4SAndroid Build Coastguard Worker      if test -n "$func_convert_core_file_wine_to_w32_result"; then
3051*6236dae4SAndroid Build Coastguard Worker        if test -z "$func_convert_core_path_wine_to_w32_result"; then
3052*6236dae4SAndroid Build Coastguard Worker          func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result
3053*6236dae4SAndroid Build Coastguard Worker        else
3054*6236dae4SAndroid Build Coastguard Worker          func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result"
3055*6236dae4SAndroid Build Coastguard Worker        fi
3056*6236dae4SAndroid Build Coastguard Worker      fi
3057*6236dae4SAndroid Build Coastguard Worker    done
3058*6236dae4SAndroid Build Coastguard Worker    IFS=$oldIFS
3059*6236dae4SAndroid Build Coastguard Worker  fi
3060*6236dae4SAndroid Build Coastguard Worker}
3061*6236dae4SAndroid Build Coastguard Worker# end: func_convert_core_path_wine_to_w32
3062*6236dae4SAndroid Build Coastguard Worker
3063*6236dae4SAndroid Build Coastguard Worker
3064*6236dae4SAndroid Build Coastguard Worker# func_cygpath ARGS...
3065*6236dae4SAndroid Build Coastguard Worker# Wrapper around calling the cygpath program via LT_CYGPATH. This is used when
3066*6236dae4SAndroid Build Coastguard Worker# when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2)
3067*6236dae4SAndroid Build Coastguard Worker# $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or
3068*6236dae4SAndroid Build Coastguard Worker# (2), returns the Cygwin file name or path in func_cygpath_result (input
3069*6236dae4SAndroid Build Coastguard Worker# file name or path is assumed to be in w32 format, as previously converted
3070*6236dae4SAndroid Build Coastguard Worker# from $build's *nix or MSYS format). In case (3), returns the w32 file name
3071*6236dae4SAndroid Build Coastguard Worker# or path in func_cygpath_result (input file name or path is assumed to be in
3072*6236dae4SAndroid Build Coastguard Worker# Cygwin format). Returns an empty string on error.
3073*6236dae4SAndroid Build Coastguard Worker#
3074*6236dae4SAndroid Build Coastguard Worker# ARGS are passed to cygpath, with the last one being the file name or path to
3075*6236dae4SAndroid Build Coastguard Worker# be converted.
3076*6236dae4SAndroid Build Coastguard Worker#
3077*6236dae4SAndroid Build Coastguard Worker# Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH
3078*6236dae4SAndroid Build Coastguard Worker# environment variable; do not put it in $PATH.
3079*6236dae4SAndroid Build Coastguard Workerfunc_cygpath ()
3080*6236dae4SAndroid Build Coastguard Worker{
3081*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3082*6236dae4SAndroid Build Coastguard Worker
3083*6236dae4SAndroid Build Coastguard Worker  if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then
3084*6236dae4SAndroid Build Coastguard Worker    func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null`
3085*6236dae4SAndroid Build Coastguard Worker    if test "$?" -ne 0; then
3086*6236dae4SAndroid Build Coastguard Worker      # on failure, ensure result is empty
3087*6236dae4SAndroid Build Coastguard Worker      func_cygpath_result=
3088*6236dae4SAndroid Build Coastguard Worker    fi
3089*6236dae4SAndroid Build Coastguard Worker  else
3090*6236dae4SAndroid Build Coastguard Worker    func_cygpath_result=
3091*6236dae4SAndroid Build Coastguard Worker    func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'"
3092*6236dae4SAndroid Build Coastguard Worker  fi
3093*6236dae4SAndroid Build Coastguard Worker}
3094*6236dae4SAndroid Build Coastguard Worker#end: func_cygpath
3095*6236dae4SAndroid Build Coastguard Worker
3096*6236dae4SAndroid Build Coastguard Worker
3097*6236dae4SAndroid Build Coastguard Worker# func_convert_core_msys_to_w32 ARG
3098*6236dae4SAndroid Build Coastguard Worker# Convert file name or path ARG from MSYS format to w32 format.  Return
3099*6236dae4SAndroid Build Coastguard Worker# result in func_convert_core_msys_to_w32_result.
3100*6236dae4SAndroid Build Coastguard Workerfunc_convert_core_msys_to_w32 ()
3101*6236dae4SAndroid Build Coastguard Worker{
3102*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3103*6236dae4SAndroid Build Coastguard Worker
3104*6236dae4SAndroid Build Coastguard Worker  # awkward: cmd appends spaces to result
3105*6236dae4SAndroid Build Coastguard Worker  func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null |
3106*6236dae4SAndroid Build Coastguard Worker    $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"`
3107*6236dae4SAndroid Build Coastguard Worker}
3108*6236dae4SAndroid Build Coastguard Worker#end: func_convert_core_msys_to_w32
3109*6236dae4SAndroid Build Coastguard Worker
3110*6236dae4SAndroid Build Coastguard Worker
3111*6236dae4SAndroid Build Coastguard Worker# func_convert_file_check ARG1 ARG2
3112*6236dae4SAndroid Build Coastguard Worker# Verify that ARG1 (a file name in $build format) was converted to $host
3113*6236dae4SAndroid Build Coastguard Worker# format in ARG2. Otherwise, emit an error message, but continue (resetting
3114*6236dae4SAndroid Build Coastguard Worker# func_to_host_file_result to ARG1).
3115*6236dae4SAndroid Build Coastguard Workerfunc_convert_file_check ()
3116*6236dae4SAndroid Build Coastguard Worker{
3117*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3118*6236dae4SAndroid Build Coastguard Worker
3119*6236dae4SAndroid Build Coastguard Worker  if test -z "$2" && test -n "$1"; then
3120*6236dae4SAndroid Build Coastguard Worker    func_error "Could not determine host file name corresponding to"
3121*6236dae4SAndroid Build Coastguard Worker    func_error "  '$1'"
3122*6236dae4SAndroid Build Coastguard Worker    func_error "Continuing, but uninstalled executables may not work."
3123*6236dae4SAndroid Build Coastguard Worker    # Fallback:
3124*6236dae4SAndroid Build Coastguard Worker    func_to_host_file_result=$1
3125*6236dae4SAndroid Build Coastguard Worker  fi
3126*6236dae4SAndroid Build Coastguard Worker}
3127*6236dae4SAndroid Build Coastguard Worker# end func_convert_file_check
3128*6236dae4SAndroid Build Coastguard Worker
3129*6236dae4SAndroid Build Coastguard Worker
3130*6236dae4SAndroid Build Coastguard Worker# func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH
3131*6236dae4SAndroid Build Coastguard Worker# Verify that FROM_PATH (a path in $build format) was converted to $host
3132*6236dae4SAndroid Build Coastguard Worker# format in TO_PATH. Otherwise, emit an error message, but continue, resetting
3133*6236dae4SAndroid Build Coastguard Worker# func_to_host_file_result to a simplistic fallback value (see below).
3134*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_check ()
3135*6236dae4SAndroid Build Coastguard Worker{
3136*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3137*6236dae4SAndroid Build Coastguard Worker
3138*6236dae4SAndroid Build Coastguard Worker  if test -z "$4" && test -n "$3"; then
3139*6236dae4SAndroid Build Coastguard Worker    func_error "Could not determine the host path corresponding to"
3140*6236dae4SAndroid Build Coastguard Worker    func_error "  '$3'"
3141*6236dae4SAndroid Build Coastguard Worker    func_error "Continuing, but uninstalled executables may not work."
3142*6236dae4SAndroid Build Coastguard Worker    # Fallback.  This is a deliberately simplistic "conversion" and
3143*6236dae4SAndroid Build Coastguard Worker    # should not be "improved".  See libtool.info.
3144*6236dae4SAndroid Build Coastguard Worker    if test "x$1" != "x$2"; then
3145*6236dae4SAndroid Build Coastguard Worker      lt_replace_pathsep_chars="s|$1|$2|g"
3146*6236dae4SAndroid Build Coastguard Worker      func_to_host_path_result=`echo "$3" |
3147*6236dae4SAndroid Build Coastguard Worker        $SED -e "$lt_replace_pathsep_chars"`
3148*6236dae4SAndroid Build Coastguard Worker    else
3149*6236dae4SAndroid Build Coastguard Worker      func_to_host_path_result=$3
3150*6236dae4SAndroid Build Coastguard Worker    fi
3151*6236dae4SAndroid Build Coastguard Worker  fi
3152*6236dae4SAndroid Build Coastguard Worker}
3153*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_check
3154*6236dae4SAndroid Build Coastguard Worker
3155*6236dae4SAndroid Build Coastguard Worker
3156*6236dae4SAndroid Build Coastguard Worker# func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG
3157*6236dae4SAndroid Build Coastguard Worker# Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT
3158*6236dae4SAndroid Build Coastguard Worker# and appending REPL if ORIG matches BACKPAT.
3159*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_front_back_pathsep ()
3160*6236dae4SAndroid Build Coastguard Worker{
3161*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3162*6236dae4SAndroid Build Coastguard Worker
3163*6236dae4SAndroid Build Coastguard Worker  case $4 in
3164*6236dae4SAndroid Build Coastguard Worker  $1 ) func_to_host_path_result=$3$func_to_host_path_result
3165*6236dae4SAndroid Build Coastguard Worker    ;;
3166*6236dae4SAndroid Build Coastguard Worker  esac
3167*6236dae4SAndroid Build Coastguard Worker  case $4 in
3168*6236dae4SAndroid Build Coastguard Worker  $2 ) func_append func_to_host_path_result "$3"
3169*6236dae4SAndroid Build Coastguard Worker    ;;
3170*6236dae4SAndroid Build Coastguard Worker  esac
3171*6236dae4SAndroid Build Coastguard Worker}
3172*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_front_back_pathsep
3173*6236dae4SAndroid Build Coastguard Worker
3174*6236dae4SAndroid Build Coastguard Worker
3175*6236dae4SAndroid Build Coastguard Worker##################################################
3176*6236dae4SAndroid Build Coastguard Worker# $build to $host FILE NAME CONVERSION FUNCTIONS #
3177*6236dae4SAndroid Build Coastguard Worker##################################################
3178*6236dae4SAndroid Build Coastguard Worker# invoked via '$to_host_file_cmd ARG'
3179*6236dae4SAndroid Build Coastguard Worker#
3180*6236dae4SAndroid Build Coastguard Worker# In each case, ARG is the path to be converted from $build to $host format.
3181*6236dae4SAndroid Build Coastguard Worker# Result will be available in $func_to_host_file_result.
3182*6236dae4SAndroid Build Coastguard Worker
3183*6236dae4SAndroid Build Coastguard Worker
3184*6236dae4SAndroid Build Coastguard Worker# func_to_host_file ARG
3185*6236dae4SAndroid Build Coastguard Worker# Converts the file name ARG from $build format to $host format. Return result
3186*6236dae4SAndroid Build Coastguard Worker# in func_to_host_file_result.
3187*6236dae4SAndroid Build Coastguard Workerfunc_to_host_file ()
3188*6236dae4SAndroid Build Coastguard Worker{
3189*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3190*6236dae4SAndroid Build Coastguard Worker
3191*6236dae4SAndroid Build Coastguard Worker  $to_host_file_cmd "$1"
3192*6236dae4SAndroid Build Coastguard Worker}
3193*6236dae4SAndroid Build Coastguard Worker# end func_to_host_file
3194*6236dae4SAndroid Build Coastguard Worker
3195*6236dae4SAndroid Build Coastguard Worker
3196*6236dae4SAndroid Build Coastguard Worker# func_to_tool_file ARG LAZY
3197*6236dae4SAndroid Build Coastguard Worker# converts the file name ARG from $build format to toolchain format. Return
3198*6236dae4SAndroid Build Coastguard Worker# result in func_to_tool_file_result.  If the conversion in use is listed
3199*6236dae4SAndroid Build Coastguard Worker# in (the comma separated) LAZY, no conversion takes place.
3200*6236dae4SAndroid Build Coastguard Workerfunc_to_tool_file ()
3201*6236dae4SAndroid Build Coastguard Worker{
3202*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3203*6236dae4SAndroid Build Coastguard Worker
3204*6236dae4SAndroid Build Coastguard Worker  case ,$2, in
3205*6236dae4SAndroid Build Coastguard Worker    *,"$to_tool_file_cmd",*)
3206*6236dae4SAndroid Build Coastguard Worker      func_to_tool_file_result=$1
3207*6236dae4SAndroid Build Coastguard Worker      ;;
3208*6236dae4SAndroid Build Coastguard Worker    *)
3209*6236dae4SAndroid Build Coastguard Worker      $to_tool_file_cmd "$1"
3210*6236dae4SAndroid Build Coastguard Worker      func_to_tool_file_result=$func_to_host_file_result
3211*6236dae4SAndroid Build Coastguard Worker      ;;
3212*6236dae4SAndroid Build Coastguard Worker  esac
3213*6236dae4SAndroid Build Coastguard Worker}
3214*6236dae4SAndroid Build Coastguard Worker# end func_to_tool_file
3215*6236dae4SAndroid Build Coastguard Worker
3216*6236dae4SAndroid Build Coastguard Worker
3217*6236dae4SAndroid Build Coastguard Worker# func_convert_file_noop ARG
3218*6236dae4SAndroid Build Coastguard Worker# Copy ARG to func_to_host_file_result.
3219*6236dae4SAndroid Build Coastguard Workerfunc_convert_file_noop ()
3220*6236dae4SAndroid Build Coastguard Worker{
3221*6236dae4SAndroid Build Coastguard Worker  func_to_host_file_result=$1
3222*6236dae4SAndroid Build Coastguard Worker}
3223*6236dae4SAndroid Build Coastguard Worker# end func_convert_file_noop
3224*6236dae4SAndroid Build Coastguard Worker
3225*6236dae4SAndroid Build Coastguard Worker
3226*6236dae4SAndroid Build Coastguard Worker# func_convert_file_msys_to_w32 ARG
3227*6236dae4SAndroid Build Coastguard Worker# Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic
3228*6236dae4SAndroid Build Coastguard Worker# conversion to w32 is not available inside the cwrapper.  Returns result in
3229*6236dae4SAndroid Build Coastguard Worker# func_to_host_file_result.
3230*6236dae4SAndroid Build Coastguard Workerfunc_convert_file_msys_to_w32 ()
3231*6236dae4SAndroid Build Coastguard Worker{
3232*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3233*6236dae4SAndroid Build Coastguard Worker
3234*6236dae4SAndroid Build Coastguard Worker  func_to_host_file_result=$1
3235*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3236*6236dae4SAndroid Build Coastguard Worker    func_convert_core_msys_to_w32 "$1"
3237*6236dae4SAndroid Build Coastguard Worker    func_to_host_file_result=$func_convert_core_msys_to_w32_result
3238*6236dae4SAndroid Build Coastguard Worker  fi
3239*6236dae4SAndroid Build Coastguard Worker  func_convert_file_check "$1" "$func_to_host_file_result"
3240*6236dae4SAndroid Build Coastguard Worker}
3241*6236dae4SAndroid Build Coastguard Worker# end func_convert_file_msys_to_w32
3242*6236dae4SAndroid Build Coastguard Worker
3243*6236dae4SAndroid Build Coastguard Worker
3244*6236dae4SAndroid Build Coastguard Worker# func_convert_file_cygwin_to_w32 ARG
3245*6236dae4SAndroid Build Coastguard Worker# Convert file name ARG from Cygwin to w32 format.  Returns result in
3246*6236dae4SAndroid Build Coastguard Worker# func_to_host_file_result.
3247*6236dae4SAndroid Build Coastguard Workerfunc_convert_file_cygwin_to_w32 ()
3248*6236dae4SAndroid Build Coastguard Worker{
3249*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3250*6236dae4SAndroid Build Coastguard Worker
3251*6236dae4SAndroid Build Coastguard Worker  func_to_host_file_result=$1
3252*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3253*6236dae4SAndroid Build Coastguard Worker    # because $build is cygwin, we call "the" cygpath in $PATH; no need to use
3254*6236dae4SAndroid Build Coastguard Worker    # LT_CYGPATH in this case.
3255*6236dae4SAndroid Build Coastguard Worker    func_to_host_file_result=`cygpath -m "$1"`
3256*6236dae4SAndroid Build Coastguard Worker  fi
3257*6236dae4SAndroid Build Coastguard Worker  func_convert_file_check "$1" "$func_to_host_file_result"
3258*6236dae4SAndroid Build Coastguard Worker}
3259*6236dae4SAndroid Build Coastguard Worker# end func_convert_file_cygwin_to_w32
3260*6236dae4SAndroid Build Coastguard Worker
3261*6236dae4SAndroid Build Coastguard Worker
3262*6236dae4SAndroid Build Coastguard Worker# func_convert_file_nix_to_w32 ARG
3263*6236dae4SAndroid Build Coastguard Worker# Convert file name ARG from *nix to w32 format.  Requires a wine environment
3264*6236dae4SAndroid Build Coastguard Worker# and a working winepath. Returns result in func_to_host_file_result.
3265*6236dae4SAndroid Build Coastguard Workerfunc_convert_file_nix_to_w32 ()
3266*6236dae4SAndroid Build Coastguard Worker{
3267*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3268*6236dae4SAndroid Build Coastguard Worker
3269*6236dae4SAndroid Build Coastguard Worker  func_to_host_file_result=$1
3270*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3271*6236dae4SAndroid Build Coastguard Worker    func_convert_core_file_wine_to_w32 "$1"
3272*6236dae4SAndroid Build Coastguard Worker    func_to_host_file_result=$func_convert_core_file_wine_to_w32_result
3273*6236dae4SAndroid Build Coastguard Worker  fi
3274*6236dae4SAndroid Build Coastguard Worker  func_convert_file_check "$1" "$func_to_host_file_result"
3275*6236dae4SAndroid Build Coastguard Worker}
3276*6236dae4SAndroid Build Coastguard Worker# end func_convert_file_nix_to_w32
3277*6236dae4SAndroid Build Coastguard Worker
3278*6236dae4SAndroid Build Coastguard Worker
3279*6236dae4SAndroid Build Coastguard Worker# func_convert_file_msys_to_cygwin ARG
3280*6236dae4SAndroid Build Coastguard Worker# Convert file name ARG from MSYS to Cygwin format.  Requires LT_CYGPATH set.
3281*6236dae4SAndroid Build Coastguard Worker# Returns result in func_to_host_file_result.
3282*6236dae4SAndroid Build Coastguard Workerfunc_convert_file_msys_to_cygwin ()
3283*6236dae4SAndroid Build Coastguard Worker{
3284*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3285*6236dae4SAndroid Build Coastguard Worker
3286*6236dae4SAndroid Build Coastguard Worker  func_to_host_file_result=$1
3287*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3288*6236dae4SAndroid Build Coastguard Worker    func_convert_core_msys_to_w32 "$1"
3289*6236dae4SAndroid Build Coastguard Worker    func_cygpath -u "$func_convert_core_msys_to_w32_result"
3290*6236dae4SAndroid Build Coastguard Worker    func_to_host_file_result=$func_cygpath_result
3291*6236dae4SAndroid Build Coastguard Worker  fi
3292*6236dae4SAndroid Build Coastguard Worker  func_convert_file_check "$1" "$func_to_host_file_result"
3293*6236dae4SAndroid Build Coastguard Worker}
3294*6236dae4SAndroid Build Coastguard Worker# end func_convert_file_msys_to_cygwin
3295*6236dae4SAndroid Build Coastguard Worker
3296*6236dae4SAndroid Build Coastguard Worker
3297*6236dae4SAndroid Build Coastguard Worker# func_convert_file_nix_to_cygwin ARG
3298*6236dae4SAndroid Build Coastguard Worker# Convert file name ARG from *nix to Cygwin format.  Requires Cygwin installed
3299*6236dae4SAndroid Build Coastguard Worker# in a wine environment, working winepath, and LT_CYGPATH set.  Returns result
3300*6236dae4SAndroid Build Coastguard Worker# in func_to_host_file_result.
3301*6236dae4SAndroid Build Coastguard Workerfunc_convert_file_nix_to_cygwin ()
3302*6236dae4SAndroid Build Coastguard Worker{
3303*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3304*6236dae4SAndroid Build Coastguard Worker
3305*6236dae4SAndroid Build Coastguard Worker  func_to_host_file_result=$1
3306*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3307*6236dae4SAndroid Build Coastguard Worker    # convert from *nix to w32, then use cygpath to convert from w32 to cygwin.
3308*6236dae4SAndroid Build Coastguard Worker    func_convert_core_file_wine_to_w32 "$1"
3309*6236dae4SAndroid Build Coastguard Worker    func_cygpath -u "$func_convert_core_file_wine_to_w32_result"
3310*6236dae4SAndroid Build Coastguard Worker    func_to_host_file_result=$func_cygpath_result
3311*6236dae4SAndroid Build Coastguard Worker  fi
3312*6236dae4SAndroid Build Coastguard Worker  func_convert_file_check "$1" "$func_to_host_file_result"
3313*6236dae4SAndroid Build Coastguard Worker}
3314*6236dae4SAndroid Build Coastguard Worker# end func_convert_file_nix_to_cygwin
3315*6236dae4SAndroid Build Coastguard Worker
3316*6236dae4SAndroid Build Coastguard Worker
3317*6236dae4SAndroid Build Coastguard Worker#############################################
3318*6236dae4SAndroid Build Coastguard Worker# $build to $host PATH CONVERSION FUNCTIONS #
3319*6236dae4SAndroid Build Coastguard Worker#############################################
3320*6236dae4SAndroid Build Coastguard Worker# invoked via '$to_host_path_cmd ARG'
3321*6236dae4SAndroid Build Coastguard Worker#
3322*6236dae4SAndroid Build Coastguard Worker# In each case, ARG is the path to be converted from $build to $host format.
3323*6236dae4SAndroid Build Coastguard Worker# The result will be available in $func_to_host_path_result.
3324*6236dae4SAndroid Build Coastguard Worker#
3325*6236dae4SAndroid Build Coastguard Worker# Path separators are also converted from $build format to $host format.  If
3326*6236dae4SAndroid Build Coastguard Worker# ARG begins or ends with a path separator character, it is preserved (but
3327*6236dae4SAndroid Build Coastguard Worker# converted to $host format) on output.
3328*6236dae4SAndroid Build Coastguard Worker#
3329*6236dae4SAndroid Build Coastguard Worker# All path conversion functions are named using the following convention:
3330*6236dae4SAndroid Build Coastguard Worker#   file name conversion function    : func_convert_file_X_to_Y ()
3331*6236dae4SAndroid Build Coastguard Worker#   path conversion function         : func_convert_path_X_to_Y ()
3332*6236dae4SAndroid Build Coastguard Worker# where, for any given $build/$host combination the 'X_to_Y' value is the
3333*6236dae4SAndroid Build Coastguard Worker# same.  If conversion functions are added for new $build/$host combinations,
3334*6236dae4SAndroid Build Coastguard Worker# the two new functions must follow this pattern, or func_init_to_host_path_cmd
3335*6236dae4SAndroid Build Coastguard Worker# will break.
3336*6236dae4SAndroid Build Coastguard Worker
3337*6236dae4SAndroid Build Coastguard Worker
3338*6236dae4SAndroid Build Coastguard Worker# func_init_to_host_path_cmd
3339*6236dae4SAndroid Build Coastguard Worker# Ensures that function "pointer" variable $to_host_path_cmd is set to the
3340*6236dae4SAndroid Build Coastguard Worker# appropriate value, based on the value of $to_host_file_cmd.
3341*6236dae4SAndroid Build Coastguard Workerto_host_path_cmd=
3342*6236dae4SAndroid Build Coastguard Workerfunc_init_to_host_path_cmd ()
3343*6236dae4SAndroid Build Coastguard Worker{
3344*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3345*6236dae4SAndroid Build Coastguard Worker
3346*6236dae4SAndroid Build Coastguard Worker  if test -z "$to_host_path_cmd"; then
3347*6236dae4SAndroid Build Coastguard Worker    func_stripname 'func_convert_file_' '' "$to_host_file_cmd"
3348*6236dae4SAndroid Build Coastguard Worker    to_host_path_cmd=func_convert_path_$func_stripname_result
3349*6236dae4SAndroid Build Coastguard Worker  fi
3350*6236dae4SAndroid Build Coastguard Worker}
3351*6236dae4SAndroid Build Coastguard Worker
3352*6236dae4SAndroid Build Coastguard Worker
3353*6236dae4SAndroid Build Coastguard Worker# func_to_host_path ARG
3354*6236dae4SAndroid Build Coastguard Worker# Converts the path ARG from $build format to $host format. Return result
3355*6236dae4SAndroid Build Coastguard Worker# in func_to_host_path_result.
3356*6236dae4SAndroid Build Coastguard Workerfunc_to_host_path ()
3357*6236dae4SAndroid Build Coastguard Worker{
3358*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3359*6236dae4SAndroid Build Coastguard Worker
3360*6236dae4SAndroid Build Coastguard Worker  func_init_to_host_path_cmd
3361*6236dae4SAndroid Build Coastguard Worker  $to_host_path_cmd "$1"
3362*6236dae4SAndroid Build Coastguard Worker}
3363*6236dae4SAndroid Build Coastguard Worker# end func_to_host_path
3364*6236dae4SAndroid Build Coastguard Worker
3365*6236dae4SAndroid Build Coastguard Worker
3366*6236dae4SAndroid Build Coastguard Worker# func_convert_path_noop ARG
3367*6236dae4SAndroid Build Coastguard Worker# Copy ARG to func_to_host_path_result.
3368*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_noop ()
3369*6236dae4SAndroid Build Coastguard Worker{
3370*6236dae4SAndroid Build Coastguard Worker  func_to_host_path_result=$1
3371*6236dae4SAndroid Build Coastguard Worker}
3372*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_noop
3373*6236dae4SAndroid Build Coastguard Worker
3374*6236dae4SAndroid Build Coastguard Worker
3375*6236dae4SAndroid Build Coastguard Worker# func_convert_path_msys_to_w32 ARG
3376*6236dae4SAndroid Build Coastguard Worker# Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic
3377*6236dae4SAndroid Build Coastguard Worker# conversion to w32 is not available inside the cwrapper.  Returns result in
3378*6236dae4SAndroid Build Coastguard Worker# func_to_host_path_result.
3379*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_msys_to_w32 ()
3380*6236dae4SAndroid Build Coastguard Worker{
3381*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3382*6236dae4SAndroid Build Coastguard Worker
3383*6236dae4SAndroid Build Coastguard Worker  func_to_host_path_result=$1
3384*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3385*6236dae4SAndroid Build Coastguard Worker    # Remove leading and trailing path separator characters from ARG.  MSYS
3386*6236dae4SAndroid Build Coastguard Worker    # behavior is inconsistent here; cygpath turns them into '.;' and ';.';
3387*6236dae4SAndroid Build Coastguard Worker    # and winepath ignores them completely.
3388*6236dae4SAndroid Build Coastguard Worker    func_stripname : : "$1"
3389*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_tmp1=$func_stripname_result
3390*6236dae4SAndroid Build Coastguard Worker    func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
3391*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_result=$func_convert_core_msys_to_w32_result
3392*6236dae4SAndroid Build Coastguard Worker    func_convert_path_check : ";" \
3393*6236dae4SAndroid Build Coastguard Worker      "$func_to_host_path_tmp1" "$func_to_host_path_result"
3394*6236dae4SAndroid Build Coastguard Worker    func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
3395*6236dae4SAndroid Build Coastguard Worker  fi
3396*6236dae4SAndroid Build Coastguard Worker}
3397*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_msys_to_w32
3398*6236dae4SAndroid Build Coastguard Worker
3399*6236dae4SAndroid Build Coastguard Worker
3400*6236dae4SAndroid Build Coastguard Worker# func_convert_path_cygwin_to_w32 ARG
3401*6236dae4SAndroid Build Coastguard Worker# Convert path ARG from Cygwin to w32 format.  Returns result in
3402*6236dae4SAndroid Build Coastguard Worker# func_to_host_file_result.
3403*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_cygwin_to_w32 ()
3404*6236dae4SAndroid Build Coastguard Worker{
3405*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3406*6236dae4SAndroid Build Coastguard Worker
3407*6236dae4SAndroid Build Coastguard Worker  func_to_host_path_result=$1
3408*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3409*6236dae4SAndroid Build Coastguard Worker    # See func_convert_path_msys_to_w32:
3410*6236dae4SAndroid Build Coastguard Worker    func_stripname : : "$1"
3411*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_tmp1=$func_stripname_result
3412*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"`
3413*6236dae4SAndroid Build Coastguard Worker    func_convert_path_check : ";" \
3414*6236dae4SAndroid Build Coastguard Worker      "$func_to_host_path_tmp1" "$func_to_host_path_result"
3415*6236dae4SAndroid Build Coastguard Worker    func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
3416*6236dae4SAndroid Build Coastguard Worker  fi
3417*6236dae4SAndroid Build Coastguard Worker}
3418*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_cygwin_to_w32
3419*6236dae4SAndroid Build Coastguard Worker
3420*6236dae4SAndroid Build Coastguard Worker
3421*6236dae4SAndroid Build Coastguard Worker# func_convert_path_nix_to_w32 ARG
3422*6236dae4SAndroid Build Coastguard Worker# Convert path ARG from *nix to w32 format.  Requires a wine environment and
3423*6236dae4SAndroid Build Coastguard Worker# a working winepath.  Returns result in func_to_host_file_result.
3424*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_nix_to_w32 ()
3425*6236dae4SAndroid Build Coastguard Worker{
3426*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3427*6236dae4SAndroid Build Coastguard Worker
3428*6236dae4SAndroid Build Coastguard Worker  func_to_host_path_result=$1
3429*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3430*6236dae4SAndroid Build Coastguard Worker    # See func_convert_path_msys_to_w32:
3431*6236dae4SAndroid Build Coastguard Worker    func_stripname : : "$1"
3432*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_tmp1=$func_stripname_result
3433*6236dae4SAndroid Build Coastguard Worker    func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
3434*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_result=$func_convert_core_path_wine_to_w32_result
3435*6236dae4SAndroid Build Coastguard Worker    func_convert_path_check : ";" \
3436*6236dae4SAndroid Build Coastguard Worker      "$func_to_host_path_tmp1" "$func_to_host_path_result"
3437*6236dae4SAndroid Build Coastguard Worker    func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
3438*6236dae4SAndroid Build Coastguard Worker  fi
3439*6236dae4SAndroid Build Coastguard Worker}
3440*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_nix_to_w32
3441*6236dae4SAndroid Build Coastguard Worker
3442*6236dae4SAndroid Build Coastguard Worker
3443*6236dae4SAndroid Build Coastguard Worker# func_convert_path_msys_to_cygwin ARG
3444*6236dae4SAndroid Build Coastguard Worker# Convert path ARG from MSYS to Cygwin format.  Requires LT_CYGPATH set.
3445*6236dae4SAndroid Build Coastguard Worker# Returns result in func_to_host_file_result.
3446*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_msys_to_cygwin ()
3447*6236dae4SAndroid Build Coastguard Worker{
3448*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3449*6236dae4SAndroid Build Coastguard Worker
3450*6236dae4SAndroid Build Coastguard Worker  func_to_host_path_result=$1
3451*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3452*6236dae4SAndroid Build Coastguard Worker    # See func_convert_path_msys_to_w32:
3453*6236dae4SAndroid Build Coastguard Worker    func_stripname : : "$1"
3454*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_tmp1=$func_stripname_result
3455*6236dae4SAndroid Build Coastguard Worker    func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
3456*6236dae4SAndroid Build Coastguard Worker    func_cygpath -u -p "$func_convert_core_msys_to_w32_result"
3457*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_result=$func_cygpath_result
3458*6236dae4SAndroid Build Coastguard Worker    func_convert_path_check : : \
3459*6236dae4SAndroid Build Coastguard Worker      "$func_to_host_path_tmp1" "$func_to_host_path_result"
3460*6236dae4SAndroid Build Coastguard Worker    func_convert_path_front_back_pathsep ":*" "*:" : "$1"
3461*6236dae4SAndroid Build Coastguard Worker  fi
3462*6236dae4SAndroid Build Coastguard Worker}
3463*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_msys_to_cygwin
3464*6236dae4SAndroid Build Coastguard Worker
3465*6236dae4SAndroid Build Coastguard Worker
3466*6236dae4SAndroid Build Coastguard Worker# func_convert_path_nix_to_cygwin ARG
3467*6236dae4SAndroid Build Coastguard Worker# Convert path ARG from *nix to Cygwin format.  Requires Cygwin installed in a
3468*6236dae4SAndroid Build Coastguard Worker# a wine environment, working winepath, and LT_CYGPATH set.  Returns result in
3469*6236dae4SAndroid Build Coastguard Worker# func_to_host_file_result.
3470*6236dae4SAndroid Build Coastguard Workerfunc_convert_path_nix_to_cygwin ()
3471*6236dae4SAndroid Build Coastguard Worker{
3472*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3473*6236dae4SAndroid Build Coastguard Worker
3474*6236dae4SAndroid Build Coastguard Worker  func_to_host_path_result=$1
3475*6236dae4SAndroid Build Coastguard Worker  if test -n "$1"; then
3476*6236dae4SAndroid Build Coastguard Worker    # Remove leading and trailing path separator characters from
3477*6236dae4SAndroid Build Coastguard Worker    # ARG. msys behavior is inconsistent here, cygpath turns them
3478*6236dae4SAndroid Build Coastguard Worker    # into '.;' and ';.', and winepath ignores them completely.
3479*6236dae4SAndroid Build Coastguard Worker    func_stripname : : "$1"
3480*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_tmp1=$func_stripname_result
3481*6236dae4SAndroid Build Coastguard Worker    func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
3482*6236dae4SAndroid Build Coastguard Worker    func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result"
3483*6236dae4SAndroid Build Coastguard Worker    func_to_host_path_result=$func_cygpath_result
3484*6236dae4SAndroid Build Coastguard Worker    func_convert_path_check : : \
3485*6236dae4SAndroid Build Coastguard Worker      "$func_to_host_path_tmp1" "$func_to_host_path_result"
3486*6236dae4SAndroid Build Coastguard Worker    func_convert_path_front_back_pathsep ":*" "*:" : "$1"
3487*6236dae4SAndroid Build Coastguard Worker  fi
3488*6236dae4SAndroid Build Coastguard Worker}
3489*6236dae4SAndroid Build Coastguard Worker# end func_convert_path_nix_to_cygwin
3490*6236dae4SAndroid Build Coastguard Worker
3491*6236dae4SAndroid Build Coastguard Worker
3492*6236dae4SAndroid Build Coastguard Worker# func_dll_def_p FILE
3493*6236dae4SAndroid Build Coastguard Worker# True iff FILE is a Windows DLL '.def' file.
3494*6236dae4SAndroid Build Coastguard Worker# Keep in sync with _LT_DLL_DEF_P in libtool.m4
3495*6236dae4SAndroid Build Coastguard Workerfunc_dll_def_p ()
3496*6236dae4SAndroid Build Coastguard Worker{
3497*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
3498*6236dae4SAndroid Build Coastguard Worker
3499*6236dae4SAndroid Build Coastguard Worker  func_dll_def_p_tmp=`$SED -n \
3500*6236dae4SAndroid Build Coastguard Worker    -e 's/^[	 ]*//' \
3501*6236dae4SAndroid Build Coastguard Worker    -e '/^\(;.*\)*$/d' \
3502*6236dae4SAndroid Build Coastguard Worker    -e 's/^\(EXPORTS\|LIBRARY\)\([	 ].*\)*$/DEF/p' \
3503*6236dae4SAndroid Build Coastguard Worker    -e q \
3504*6236dae4SAndroid Build Coastguard Worker    "$1"`
3505*6236dae4SAndroid Build Coastguard Worker  test DEF = "$func_dll_def_p_tmp"
3506*6236dae4SAndroid Build Coastguard Worker}
3507*6236dae4SAndroid Build Coastguard Worker
3508*6236dae4SAndroid Build Coastguard Worker
3509*6236dae4SAndroid Build Coastguard Worker# func_mode_compile arg...
3510*6236dae4SAndroid Build Coastguard Workerfunc_mode_compile ()
3511*6236dae4SAndroid Build Coastguard Worker{
3512*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
3513*6236dae4SAndroid Build Coastguard Worker
3514*6236dae4SAndroid Build Coastguard Worker    # Get the compilation command and the source file.
3515*6236dae4SAndroid Build Coastguard Worker    base_compile=
3516*6236dae4SAndroid Build Coastguard Worker    srcfile=$nonopt  #  always keep a non-empty value in "srcfile"
3517*6236dae4SAndroid Build Coastguard Worker    suppress_opt=yes
3518*6236dae4SAndroid Build Coastguard Worker    suppress_output=
3519*6236dae4SAndroid Build Coastguard Worker    arg_mode=normal
3520*6236dae4SAndroid Build Coastguard Worker    libobj=
3521*6236dae4SAndroid Build Coastguard Worker    later=
3522*6236dae4SAndroid Build Coastguard Worker    pie_flag=
3523*6236dae4SAndroid Build Coastguard Worker
3524*6236dae4SAndroid Build Coastguard Worker    for arg
3525*6236dae4SAndroid Build Coastguard Worker    do
3526*6236dae4SAndroid Build Coastguard Worker      case $arg_mode in
3527*6236dae4SAndroid Build Coastguard Worker      arg  )
3528*6236dae4SAndroid Build Coastguard Worker	# do not "continue".  Instead, add this to base_compile
3529*6236dae4SAndroid Build Coastguard Worker	lastarg=$arg
3530*6236dae4SAndroid Build Coastguard Worker	arg_mode=normal
3531*6236dae4SAndroid Build Coastguard Worker	;;
3532*6236dae4SAndroid Build Coastguard Worker
3533*6236dae4SAndroid Build Coastguard Worker      target )
3534*6236dae4SAndroid Build Coastguard Worker	libobj=$arg
3535*6236dae4SAndroid Build Coastguard Worker	arg_mode=normal
3536*6236dae4SAndroid Build Coastguard Worker	continue
3537*6236dae4SAndroid Build Coastguard Worker	;;
3538*6236dae4SAndroid Build Coastguard Worker
3539*6236dae4SAndroid Build Coastguard Worker      normal )
3540*6236dae4SAndroid Build Coastguard Worker	# Accept any command-line options.
3541*6236dae4SAndroid Build Coastguard Worker	case $arg in
3542*6236dae4SAndroid Build Coastguard Worker	-o)
3543*6236dae4SAndroid Build Coastguard Worker	  test -n "$libobj" && \
3544*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "you cannot specify '-o' more than once"
3545*6236dae4SAndroid Build Coastguard Worker	  arg_mode=target
3546*6236dae4SAndroid Build Coastguard Worker	  continue
3547*6236dae4SAndroid Build Coastguard Worker	  ;;
3548*6236dae4SAndroid Build Coastguard Worker
3549*6236dae4SAndroid Build Coastguard Worker	-pie | -fpie | -fPIE)
3550*6236dae4SAndroid Build Coastguard Worker          func_append pie_flag " $arg"
3551*6236dae4SAndroid Build Coastguard Worker	  continue
3552*6236dae4SAndroid Build Coastguard Worker	  ;;
3553*6236dae4SAndroid Build Coastguard Worker
3554*6236dae4SAndroid Build Coastguard Worker	-shared | -static | -prefer-pic | -prefer-non-pic)
3555*6236dae4SAndroid Build Coastguard Worker	  func_append later " $arg"
3556*6236dae4SAndroid Build Coastguard Worker	  continue
3557*6236dae4SAndroid Build Coastguard Worker	  ;;
3558*6236dae4SAndroid Build Coastguard Worker
3559*6236dae4SAndroid Build Coastguard Worker	-no-suppress)
3560*6236dae4SAndroid Build Coastguard Worker	  suppress_opt=no
3561*6236dae4SAndroid Build Coastguard Worker	  continue
3562*6236dae4SAndroid Build Coastguard Worker	  ;;
3563*6236dae4SAndroid Build Coastguard Worker
3564*6236dae4SAndroid Build Coastguard Worker	-Xcompiler)
3565*6236dae4SAndroid Build Coastguard Worker	  arg_mode=arg  #  the next one goes into the "base_compile" arg list
3566*6236dae4SAndroid Build Coastguard Worker	  continue      #  The current "srcfile" will either be retained or
3567*6236dae4SAndroid Build Coastguard Worker	  ;;            #  replaced later.  I would guess that would be a bug.
3568*6236dae4SAndroid Build Coastguard Worker
3569*6236dae4SAndroid Build Coastguard Worker	-Wc,*)
3570*6236dae4SAndroid Build Coastguard Worker	  func_stripname '-Wc,' '' "$arg"
3571*6236dae4SAndroid Build Coastguard Worker	  args=$func_stripname_result
3572*6236dae4SAndroid Build Coastguard Worker	  lastarg=
3573*6236dae4SAndroid Build Coastguard Worker	  save_ifs=$IFS; IFS=,
3574*6236dae4SAndroid Build Coastguard Worker	  for arg in $args; do
3575*6236dae4SAndroid Build Coastguard Worker	    IFS=$save_ifs
3576*6236dae4SAndroid Build Coastguard Worker	    func_append_quoted lastarg "$arg"
3577*6236dae4SAndroid Build Coastguard Worker	  done
3578*6236dae4SAndroid Build Coastguard Worker	  IFS=$save_ifs
3579*6236dae4SAndroid Build Coastguard Worker	  func_stripname ' ' '' "$lastarg"
3580*6236dae4SAndroid Build Coastguard Worker	  lastarg=$func_stripname_result
3581*6236dae4SAndroid Build Coastguard Worker
3582*6236dae4SAndroid Build Coastguard Worker	  # Add the arguments to base_compile.
3583*6236dae4SAndroid Build Coastguard Worker	  func_append base_compile " $lastarg"
3584*6236dae4SAndroid Build Coastguard Worker	  continue
3585*6236dae4SAndroid Build Coastguard Worker	  ;;
3586*6236dae4SAndroid Build Coastguard Worker
3587*6236dae4SAndroid Build Coastguard Worker	*)
3588*6236dae4SAndroid Build Coastguard Worker	  # Accept the current argument as the source file.
3589*6236dae4SAndroid Build Coastguard Worker	  # The previous "srcfile" becomes the current argument.
3590*6236dae4SAndroid Build Coastguard Worker	  #
3591*6236dae4SAndroid Build Coastguard Worker	  lastarg=$srcfile
3592*6236dae4SAndroid Build Coastguard Worker	  srcfile=$arg
3593*6236dae4SAndroid Build Coastguard Worker	  ;;
3594*6236dae4SAndroid Build Coastguard Worker	esac  #  case $arg
3595*6236dae4SAndroid Build Coastguard Worker	;;
3596*6236dae4SAndroid Build Coastguard Worker      esac    #  case $arg_mode
3597*6236dae4SAndroid Build Coastguard Worker
3598*6236dae4SAndroid Build Coastguard Worker      # Aesthetically quote the previous argument.
3599*6236dae4SAndroid Build Coastguard Worker      func_append_quoted base_compile "$lastarg"
3600*6236dae4SAndroid Build Coastguard Worker    done # for arg
3601*6236dae4SAndroid Build Coastguard Worker
3602*6236dae4SAndroid Build Coastguard Worker    case $arg_mode in
3603*6236dae4SAndroid Build Coastguard Worker    arg)
3604*6236dae4SAndroid Build Coastguard Worker      func_fatal_error "you must specify an argument for -Xcompile"
3605*6236dae4SAndroid Build Coastguard Worker      ;;
3606*6236dae4SAndroid Build Coastguard Worker    target)
3607*6236dae4SAndroid Build Coastguard Worker      func_fatal_error "you must specify a target with '-o'"
3608*6236dae4SAndroid Build Coastguard Worker      ;;
3609*6236dae4SAndroid Build Coastguard Worker    *)
3610*6236dae4SAndroid Build Coastguard Worker      # Get the name of the library object.
3611*6236dae4SAndroid Build Coastguard Worker      test -z "$libobj" && {
3612*6236dae4SAndroid Build Coastguard Worker	func_basename "$srcfile"
3613*6236dae4SAndroid Build Coastguard Worker	libobj=$func_basename_result
3614*6236dae4SAndroid Build Coastguard Worker      }
3615*6236dae4SAndroid Build Coastguard Worker      ;;
3616*6236dae4SAndroid Build Coastguard Worker    esac
3617*6236dae4SAndroid Build Coastguard Worker
3618*6236dae4SAndroid Build Coastguard Worker    # Recognize several different file suffixes.
3619*6236dae4SAndroid Build Coastguard Worker    # If the user specifies -o file.o, it is replaced with file.lo
3620*6236dae4SAndroid Build Coastguard Worker    case $libobj in
3621*6236dae4SAndroid Build Coastguard Worker    *.[cCFSifmso] | \
3622*6236dae4SAndroid Build Coastguard Worker    *.ada | *.adb | *.ads | *.asm | \
3623*6236dae4SAndroid Build Coastguard Worker    *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \
3624*6236dae4SAndroid Build Coastguard Worker    *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup)
3625*6236dae4SAndroid Build Coastguard Worker      func_xform "$libobj"
3626*6236dae4SAndroid Build Coastguard Worker      libobj=$func_xform_result
3627*6236dae4SAndroid Build Coastguard Worker      ;;
3628*6236dae4SAndroid Build Coastguard Worker    esac
3629*6236dae4SAndroid Build Coastguard Worker
3630*6236dae4SAndroid Build Coastguard Worker    case $libobj in
3631*6236dae4SAndroid Build Coastguard Worker    *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;;
3632*6236dae4SAndroid Build Coastguard Worker    *)
3633*6236dae4SAndroid Build Coastguard Worker      func_fatal_error "cannot determine name of library object from '$libobj'"
3634*6236dae4SAndroid Build Coastguard Worker      ;;
3635*6236dae4SAndroid Build Coastguard Worker    esac
3636*6236dae4SAndroid Build Coastguard Worker
3637*6236dae4SAndroid Build Coastguard Worker    func_infer_tag $base_compile
3638*6236dae4SAndroid Build Coastguard Worker
3639*6236dae4SAndroid Build Coastguard Worker    for arg in $later; do
3640*6236dae4SAndroid Build Coastguard Worker      case $arg in
3641*6236dae4SAndroid Build Coastguard Worker      -shared)
3642*6236dae4SAndroid Build Coastguard Worker	test yes = "$build_libtool_libs" \
3643*6236dae4SAndroid Build Coastguard Worker	  || func_fatal_configuration "cannot build a shared library"
3644*6236dae4SAndroid Build Coastguard Worker	build_old_libs=no
3645*6236dae4SAndroid Build Coastguard Worker	continue
3646*6236dae4SAndroid Build Coastguard Worker	;;
3647*6236dae4SAndroid Build Coastguard Worker
3648*6236dae4SAndroid Build Coastguard Worker      -static)
3649*6236dae4SAndroid Build Coastguard Worker	build_libtool_libs=no
3650*6236dae4SAndroid Build Coastguard Worker	build_old_libs=yes
3651*6236dae4SAndroid Build Coastguard Worker	continue
3652*6236dae4SAndroid Build Coastguard Worker	;;
3653*6236dae4SAndroid Build Coastguard Worker
3654*6236dae4SAndroid Build Coastguard Worker      -prefer-pic)
3655*6236dae4SAndroid Build Coastguard Worker	pic_mode=yes
3656*6236dae4SAndroid Build Coastguard Worker	continue
3657*6236dae4SAndroid Build Coastguard Worker	;;
3658*6236dae4SAndroid Build Coastguard Worker
3659*6236dae4SAndroid Build Coastguard Worker      -prefer-non-pic)
3660*6236dae4SAndroid Build Coastguard Worker	pic_mode=no
3661*6236dae4SAndroid Build Coastguard Worker	continue
3662*6236dae4SAndroid Build Coastguard Worker	;;
3663*6236dae4SAndroid Build Coastguard Worker      esac
3664*6236dae4SAndroid Build Coastguard Worker    done
3665*6236dae4SAndroid Build Coastguard Worker
3666*6236dae4SAndroid Build Coastguard Worker    func_quote_arg pretty "$libobj"
3667*6236dae4SAndroid Build Coastguard Worker    test "X$libobj" != "X$func_quote_arg_result" \
3668*6236dae4SAndroid Build Coastguard Worker      && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"'	 &()|`$[]' \
3669*6236dae4SAndroid Build Coastguard Worker      && func_warning "libobj name '$libobj' may not contain shell special characters."
3670*6236dae4SAndroid Build Coastguard Worker    func_dirname_and_basename "$obj" "/" ""
3671*6236dae4SAndroid Build Coastguard Worker    objname=$func_basename_result
3672*6236dae4SAndroid Build Coastguard Worker    xdir=$func_dirname_result
3673*6236dae4SAndroid Build Coastguard Worker    lobj=$xdir$objdir/$objname
3674*6236dae4SAndroid Build Coastguard Worker
3675*6236dae4SAndroid Build Coastguard Worker    test -z "$base_compile" && \
3676*6236dae4SAndroid Build Coastguard Worker      func_fatal_help "you must specify a compilation command"
3677*6236dae4SAndroid Build Coastguard Worker
3678*6236dae4SAndroid Build Coastguard Worker    # Delete any leftover library objects.
3679*6236dae4SAndroid Build Coastguard Worker    if test yes = "$build_old_libs"; then
3680*6236dae4SAndroid Build Coastguard Worker      removelist="$obj $lobj $libobj ${libobj}T"
3681*6236dae4SAndroid Build Coastguard Worker    else
3682*6236dae4SAndroid Build Coastguard Worker      removelist="$lobj $libobj ${libobj}T"
3683*6236dae4SAndroid Build Coastguard Worker    fi
3684*6236dae4SAndroid Build Coastguard Worker
3685*6236dae4SAndroid Build Coastguard Worker    # On Cygwin there's no "real" PIC flag so we must build both object types
3686*6236dae4SAndroid Build Coastguard Worker    case $host_os in
3687*6236dae4SAndroid Build Coastguard Worker    cygwin* | mingw* | pw32* | os2* | cegcc*)
3688*6236dae4SAndroid Build Coastguard Worker      pic_mode=default
3689*6236dae4SAndroid Build Coastguard Worker      ;;
3690*6236dae4SAndroid Build Coastguard Worker    esac
3691*6236dae4SAndroid Build Coastguard Worker    if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then
3692*6236dae4SAndroid Build Coastguard Worker      # non-PIC code in shared libraries is not supported
3693*6236dae4SAndroid Build Coastguard Worker      pic_mode=default
3694*6236dae4SAndroid Build Coastguard Worker    fi
3695*6236dae4SAndroid Build Coastguard Worker
3696*6236dae4SAndroid Build Coastguard Worker    # Calculate the filename of the output object if compiler does
3697*6236dae4SAndroid Build Coastguard Worker    # not support -o with -c
3698*6236dae4SAndroid Build Coastguard Worker    if test no = "$compiler_c_o"; then
3699*6236dae4SAndroid Build Coastguard Worker      output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext
3700*6236dae4SAndroid Build Coastguard Worker      lockfile=$output_obj.lock
3701*6236dae4SAndroid Build Coastguard Worker    else
3702*6236dae4SAndroid Build Coastguard Worker      output_obj=
3703*6236dae4SAndroid Build Coastguard Worker      need_locks=no
3704*6236dae4SAndroid Build Coastguard Worker      lockfile=
3705*6236dae4SAndroid Build Coastguard Worker    fi
3706*6236dae4SAndroid Build Coastguard Worker
3707*6236dae4SAndroid Build Coastguard Worker    # Lock this critical section if it is needed
3708*6236dae4SAndroid Build Coastguard Worker    # We use this script file to make the link, it avoids creating a new file
3709*6236dae4SAndroid Build Coastguard Worker    if test yes = "$need_locks"; then
3710*6236dae4SAndroid Build Coastguard Worker      until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
3711*6236dae4SAndroid Build Coastguard Worker	func_echo "Waiting for $lockfile to be removed"
3712*6236dae4SAndroid Build Coastguard Worker	sleep 2
3713*6236dae4SAndroid Build Coastguard Worker      done
3714*6236dae4SAndroid Build Coastguard Worker    elif test warn = "$need_locks"; then
3715*6236dae4SAndroid Build Coastguard Worker      if test -f "$lockfile"; then
3716*6236dae4SAndroid Build Coastguard Worker	$ECHO "\
3717*6236dae4SAndroid Build Coastguard Worker*** ERROR, $lockfile exists and contains:
3718*6236dae4SAndroid Build Coastguard Worker`cat $lockfile 2>/dev/null`
3719*6236dae4SAndroid Build Coastguard Worker
3720*6236dae4SAndroid Build Coastguard WorkerThis indicates that another process is trying to use the same
3721*6236dae4SAndroid Build Coastguard Workertemporary object file, and libtool could not work around it because
3722*6236dae4SAndroid Build Coastguard Workeryour compiler does not support '-c' and '-o' together.  If you
3723*6236dae4SAndroid Build Coastguard Workerrepeat this compilation, it may succeed, by chance, but you had better
3724*6236dae4SAndroid Build Coastguard Workeravoid parallel builds (make -j) in this platform, or get a better
3725*6236dae4SAndroid Build Coastguard Workercompiler."
3726*6236dae4SAndroid Build Coastguard Worker
3727*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || $RM $removelist
3728*6236dae4SAndroid Build Coastguard Worker	exit $EXIT_FAILURE
3729*6236dae4SAndroid Build Coastguard Worker      fi
3730*6236dae4SAndroid Build Coastguard Worker      func_append removelist " $output_obj"
3731*6236dae4SAndroid Build Coastguard Worker      $ECHO "$srcfile" > "$lockfile"
3732*6236dae4SAndroid Build Coastguard Worker    fi
3733*6236dae4SAndroid Build Coastguard Worker
3734*6236dae4SAndroid Build Coastguard Worker    $opt_dry_run || $RM $removelist
3735*6236dae4SAndroid Build Coastguard Worker    func_append removelist " $lockfile"
3736*6236dae4SAndroid Build Coastguard Worker    trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15
3737*6236dae4SAndroid Build Coastguard Worker
3738*6236dae4SAndroid Build Coastguard Worker    func_to_tool_file "$srcfile" func_convert_file_msys_to_w32
3739*6236dae4SAndroid Build Coastguard Worker    srcfile=$func_to_tool_file_result
3740*6236dae4SAndroid Build Coastguard Worker    func_quote_arg pretty "$srcfile"
3741*6236dae4SAndroid Build Coastguard Worker    qsrcfile=$func_quote_arg_result
3742*6236dae4SAndroid Build Coastguard Worker
3743*6236dae4SAndroid Build Coastguard Worker    # Only build a PIC object if we are building libtool libraries.
3744*6236dae4SAndroid Build Coastguard Worker    if test yes = "$build_libtool_libs"; then
3745*6236dae4SAndroid Build Coastguard Worker      # Without this assignment, base_compile gets emptied.
3746*6236dae4SAndroid Build Coastguard Worker      fbsd_hideous_sh_bug=$base_compile
3747*6236dae4SAndroid Build Coastguard Worker
3748*6236dae4SAndroid Build Coastguard Worker      if test no != "$pic_mode"; then
3749*6236dae4SAndroid Build Coastguard Worker	command="$base_compile $qsrcfile $pic_flag"
3750*6236dae4SAndroid Build Coastguard Worker      else
3751*6236dae4SAndroid Build Coastguard Worker	# Don't build PIC code
3752*6236dae4SAndroid Build Coastguard Worker	command="$base_compile $qsrcfile"
3753*6236dae4SAndroid Build Coastguard Worker      fi
3754*6236dae4SAndroid Build Coastguard Worker
3755*6236dae4SAndroid Build Coastguard Worker      func_mkdir_p "$xdir$objdir"
3756*6236dae4SAndroid Build Coastguard Worker
3757*6236dae4SAndroid Build Coastguard Worker      if test -z "$output_obj"; then
3758*6236dae4SAndroid Build Coastguard Worker	# Place PIC objects in $objdir
3759*6236dae4SAndroid Build Coastguard Worker	func_append command " -o $lobj"
3760*6236dae4SAndroid Build Coastguard Worker      fi
3761*6236dae4SAndroid Build Coastguard Worker
3762*6236dae4SAndroid Build Coastguard Worker      func_show_eval_locale "$command"	\
3763*6236dae4SAndroid Build Coastguard Worker          'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE'
3764*6236dae4SAndroid Build Coastguard Worker
3765*6236dae4SAndroid Build Coastguard Worker      if test warn = "$need_locks" &&
3766*6236dae4SAndroid Build Coastguard Worker	 test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
3767*6236dae4SAndroid Build Coastguard Worker	$ECHO "\
3768*6236dae4SAndroid Build Coastguard Worker*** ERROR, $lockfile contains:
3769*6236dae4SAndroid Build Coastguard Worker`cat $lockfile 2>/dev/null`
3770*6236dae4SAndroid Build Coastguard Worker
3771*6236dae4SAndroid Build Coastguard Workerbut it should contain:
3772*6236dae4SAndroid Build Coastguard Worker$srcfile
3773*6236dae4SAndroid Build Coastguard Worker
3774*6236dae4SAndroid Build Coastguard WorkerThis indicates that another process is trying to use the same
3775*6236dae4SAndroid Build Coastguard Workertemporary object file, and libtool could not work around it because
3776*6236dae4SAndroid Build Coastguard Workeryour compiler does not support '-c' and '-o' together.  If you
3777*6236dae4SAndroid Build Coastguard Workerrepeat this compilation, it may succeed, by chance, but you had better
3778*6236dae4SAndroid Build Coastguard Workeravoid parallel builds (make -j) in this platform, or get a better
3779*6236dae4SAndroid Build Coastguard Workercompiler."
3780*6236dae4SAndroid Build Coastguard Worker
3781*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || $RM $removelist
3782*6236dae4SAndroid Build Coastguard Worker	exit $EXIT_FAILURE
3783*6236dae4SAndroid Build Coastguard Worker      fi
3784*6236dae4SAndroid Build Coastguard Worker
3785*6236dae4SAndroid Build Coastguard Worker      # Just move the object if needed, then go on to compile the next one
3786*6236dae4SAndroid Build Coastguard Worker      if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then
3787*6236dae4SAndroid Build Coastguard Worker	func_show_eval '$MV "$output_obj" "$lobj"' \
3788*6236dae4SAndroid Build Coastguard Worker	  'error=$?; $opt_dry_run || $RM $removelist; exit $error'
3789*6236dae4SAndroid Build Coastguard Worker      fi
3790*6236dae4SAndroid Build Coastguard Worker
3791*6236dae4SAndroid Build Coastguard Worker      # Allow error messages only from the first compilation.
3792*6236dae4SAndroid Build Coastguard Worker      if test yes = "$suppress_opt"; then
3793*6236dae4SAndroid Build Coastguard Worker	suppress_output=' >/dev/null 2>&1'
3794*6236dae4SAndroid Build Coastguard Worker      fi
3795*6236dae4SAndroid Build Coastguard Worker    fi
3796*6236dae4SAndroid Build Coastguard Worker
3797*6236dae4SAndroid Build Coastguard Worker    # Only build a position-dependent object if we build old libraries.
3798*6236dae4SAndroid Build Coastguard Worker    if test yes = "$build_old_libs"; then
3799*6236dae4SAndroid Build Coastguard Worker      if test yes != "$pic_mode"; then
3800*6236dae4SAndroid Build Coastguard Worker	# Don't build PIC code
3801*6236dae4SAndroid Build Coastguard Worker	command="$base_compile $qsrcfile$pie_flag"
3802*6236dae4SAndroid Build Coastguard Worker      else
3803*6236dae4SAndroid Build Coastguard Worker	command="$base_compile $qsrcfile $pic_flag"
3804*6236dae4SAndroid Build Coastguard Worker      fi
3805*6236dae4SAndroid Build Coastguard Worker      if test yes = "$compiler_c_o"; then
3806*6236dae4SAndroid Build Coastguard Worker	func_append command " -o $obj"
3807*6236dae4SAndroid Build Coastguard Worker      fi
3808*6236dae4SAndroid Build Coastguard Worker
3809*6236dae4SAndroid Build Coastguard Worker      # Suppress compiler output if we already did a PIC compilation.
3810*6236dae4SAndroid Build Coastguard Worker      func_append command "$suppress_output"
3811*6236dae4SAndroid Build Coastguard Worker      func_show_eval_locale "$command" \
3812*6236dae4SAndroid Build Coastguard Worker        '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE'
3813*6236dae4SAndroid Build Coastguard Worker
3814*6236dae4SAndroid Build Coastguard Worker      if test warn = "$need_locks" &&
3815*6236dae4SAndroid Build Coastguard Worker	 test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
3816*6236dae4SAndroid Build Coastguard Worker	$ECHO "\
3817*6236dae4SAndroid Build Coastguard Worker*** ERROR, $lockfile contains:
3818*6236dae4SAndroid Build Coastguard Worker`cat $lockfile 2>/dev/null`
3819*6236dae4SAndroid Build Coastguard Worker
3820*6236dae4SAndroid Build Coastguard Workerbut it should contain:
3821*6236dae4SAndroid Build Coastguard Worker$srcfile
3822*6236dae4SAndroid Build Coastguard Worker
3823*6236dae4SAndroid Build Coastguard WorkerThis indicates that another process is trying to use the same
3824*6236dae4SAndroid Build Coastguard Workertemporary object file, and libtool could not work around it because
3825*6236dae4SAndroid Build Coastguard Workeryour compiler does not support '-c' and '-o' together.  If you
3826*6236dae4SAndroid Build Coastguard Workerrepeat this compilation, it may succeed, by chance, but you had better
3827*6236dae4SAndroid Build Coastguard Workeravoid parallel builds (make -j) in this platform, or get a better
3828*6236dae4SAndroid Build Coastguard Workercompiler."
3829*6236dae4SAndroid Build Coastguard Worker
3830*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || $RM $removelist
3831*6236dae4SAndroid Build Coastguard Worker	exit $EXIT_FAILURE
3832*6236dae4SAndroid Build Coastguard Worker      fi
3833*6236dae4SAndroid Build Coastguard Worker
3834*6236dae4SAndroid Build Coastguard Worker      # Just move the object if needed
3835*6236dae4SAndroid Build Coastguard Worker      if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then
3836*6236dae4SAndroid Build Coastguard Worker	func_show_eval '$MV "$output_obj" "$obj"' \
3837*6236dae4SAndroid Build Coastguard Worker	  'error=$?; $opt_dry_run || $RM $removelist; exit $error'
3838*6236dae4SAndroid Build Coastguard Worker      fi
3839*6236dae4SAndroid Build Coastguard Worker    fi
3840*6236dae4SAndroid Build Coastguard Worker
3841*6236dae4SAndroid Build Coastguard Worker    $opt_dry_run || {
3842*6236dae4SAndroid Build Coastguard Worker      func_write_libtool_object "$libobj" "$objdir/$objname" "$objname"
3843*6236dae4SAndroid Build Coastguard Worker
3844*6236dae4SAndroid Build Coastguard Worker      # Unlock the critical section if it was locked
3845*6236dae4SAndroid Build Coastguard Worker      if test no != "$need_locks"; then
3846*6236dae4SAndroid Build Coastguard Worker	removelist=$lockfile
3847*6236dae4SAndroid Build Coastguard Worker        $RM "$lockfile"
3848*6236dae4SAndroid Build Coastguard Worker      fi
3849*6236dae4SAndroid Build Coastguard Worker    }
3850*6236dae4SAndroid Build Coastguard Worker
3851*6236dae4SAndroid Build Coastguard Worker    exit $EXIT_SUCCESS
3852*6236dae4SAndroid Build Coastguard Worker}
3853*6236dae4SAndroid Build Coastguard Worker
3854*6236dae4SAndroid Build Coastguard Worker$opt_help || {
3855*6236dae4SAndroid Build Coastguard Worker  test compile = "$opt_mode" && func_mode_compile ${1+"$@"}
3856*6236dae4SAndroid Build Coastguard Worker}
3857*6236dae4SAndroid Build Coastguard Worker
3858*6236dae4SAndroid Build Coastguard Workerfunc_mode_help ()
3859*6236dae4SAndroid Build Coastguard Worker{
3860*6236dae4SAndroid Build Coastguard Worker    # We need to display help for each of the modes.
3861*6236dae4SAndroid Build Coastguard Worker    case $opt_mode in
3862*6236dae4SAndroid Build Coastguard Worker      "")
3863*6236dae4SAndroid Build Coastguard Worker        # Generic help is extracted from the usage comments
3864*6236dae4SAndroid Build Coastguard Worker        # at the start of this file.
3865*6236dae4SAndroid Build Coastguard Worker        func_help
3866*6236dae4SAndroid Build Coastguard Worker        ;;
3867*6236dae4SAndroid Build Coastguard Worker
3868*6236dae4SAndroid Build Coastguard Worker      clean)
3869*6236dae4SAndroid Build Coastguard Worker        $ECHO \
3870*6236dae4SAndroid Build Coastguard Worker"Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE...
3871*6236dae4SAndroid Build Coastguard Worker
3872*6236dae4SAndroid Build Coastguard WorkerRemove files from the build directory.
3873*6236dae4SAndroid Build Coastguard Worker
3874*6236dae4SAndroid Build Coastguard WorkerRM is the name of the program to use to delete files associated with each FILE
3875*6236dae4SAndroid Build Coastguard Worker(typically '/bin/rm').  RM-OPTIONS are options (such as '-f') to be passed
3876*6236dae4SAndroid Build Coastguard Workerto RM.
3877*6236dae4SAndroid Build Coastguard Worker
3878*6236dae4SAndroid Build Coastguard WorkerIf FILE is a libtool library, object or program, all the files associated
3879*6236dae4SAndroid Build Coastguard Workerwith it are deleted. Otherwise, only FILE itself is deleted using RM."
3880*6236dae4SAndroid Build Coastguard Worker        ;;
3881*6236dae4SAndroid Build Coastguard Worker
3882*6236dae4SAndroid Build Coastguard Worker      compile)
3883*6236dae4SAndroid Build Coastguard Worker      $ECHO \
3884*6236dae4SAndroid Build Coastguard Worker"Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE
3885*6236dae4SAndroid Build Coastguard Worker
3886*6236dae4SAndroid Build Coastguard WorkerCompile a source file into a libtool library object.
3887*6236dae4SAndroid Build Coastguard Worker
3888*6236dae4SAndroid Build Coastguard WorkerThis mode accepts the following additional options:
3889*6236dae4SAndroid Build Coastguard Worker
3890*6236dae4SAndroid Build Coastguard Worker  -o OUTPUT-FILE    set the output file name to OUTPUT-FILE
3891*6236dae4SAndroid Build Coastguard Worker  -no-suppress      do not suppress compiler output for multiple passes
3892*6236dae4SAndroid Build Coastguard Worker  -prefer-pic       try to build PIC objects only
3893*6236dae4SAndroid Build Coastguard Worker  -prefer-non-pic   try to build non-PIC objects only
3894*6236dae4SAndroid Build Coastguard Worker  -shared           do not build a '.o' file suitable for static linking
3895*6236dae4SAndroid Build Coastguard Worker  -static           only build a '.o' file suitable for static linking
3896*6236dae4SAndroid Build Coastguard Worker  -Wc,FLAG
3897*6236dae4SAndroid Build Coastguard Worker  -Xcompiler FLAG   pass FLAG directly to the compiler
3898*6236dae4SAndroid Build Coastguard Worker
3899*6236dae4SAndroid Build Coastguard WorkerCOMPILE-COMMAND is a command to be used in creating a 'standard' object file
3900*6236dae4SAndroid Build Coastguard Workerfrom the given SOURCEFILE.
3901*6236dae4SAndroid Build Coastguard Worker
3902*6236dae4SAndroid Build Coastguard WorkerThe output file name is determined by removing the directory component from
3903*6236dae4SAndroid Build Coastguard WorkerSOURCEFILE, then substituting the C source code suffix '.c' with the
3904*6236dae4SAndroid Build Coastguard Workerlibrary object suffix, '.lo'."
3905*6236dae4SAndroid Build Coastguard Worker        ;;
3906*6236dae4SAndroid Build Coastguard Worker
3907*6236dae4SAndroid Build Coastguard Worker      execute)
3908*6236dae4SAndroid Build Coastguard Worker        $ECHO \
3909*6236dae4SAndroid Build Coastguard Worker"Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]...
3910*6236dae4SAndroid Build Coastguard Worker
3911*6236dae4SAndroid Build Coastguard WorkerAutomatically set library path, then run a program.
3912*6236dae4SAndroid Build Coastguard Worker
3913*6236dae4SAndroid Build Coastguard WorkerThis mode accepts the following additional options:
3914*6236dae4SAndroid Build Coastguard Worker
3915*6236dae4SAndroid Build Coastguard Worker  -dlopen FILE      add the directory containing FILE to the library path
3916*6236dae4SAndroid Build Coastguard Worker
3917*6236dae4SAndroid Build Coastguard WorkerThis mode sets the library path environment variable according to '-dlopen'
3918*6236dae4SAndroid Build Coastguard Workerflags.
3919*6236dae4SAndroid Build Coastguard Worker
3920*6236dae4SAndroid Build Coastguard WorkerIf any of the ARGS are libtool executable wrappers, then they are translated
3921*6236dae4SAndroid Build Coastguard Workerinto their corresponding uninstalled binary, and any of their required library
3922*6236dae4SAndroid Build Coastguard Workerdirectories are added to the library path.
3923*6236dae4SAndroid Build Coastguard Worker
3924*6236dae4SAndroid Build Coastguard WorkerThen, COMMAND is executed, with ARGS as arguments."
3925*6236dae4SAndroid Build Coastguard Worker        ;;
3926*6236dae4SAndroid Build Coastguard Worker
3927*6236dae4SAndroid Build Coastguard Worker      finish)
3928*6236dae4SAndroid Build Coastguard Worker        $ECHO \
3929*6236dae4SAndroid Build Coastguard Worker"Usage: $progname [OPTION]... --mode=finish [LIBDIR]...
3930*6236dae4SAndroid Build Coastguard Worker
3931*6236dae4SAndroid Build Coastguard WorkerComplete the installation of libtool libraries.
3932*6236dae4SAndroid Build Coastguard Worker
3933*6236dae4SAndroid Build Coastguard WorkerEach LIBDIR is a directory that contains libtool libraries.
3934*6236dae4SAndroid Build Coastguard Worker
3935*6236dae4SAndroid Build Coastguard WorkerThe commands that this mode executes may require superuser privileges.  Use
3936*6236dae4SAndroid Build Coastguard Workerthe '--dry-run' option if you just want to see what would be executed."
3937*6236dae4SAndroid Build Coastguard Worker        ;;
3938*6236dae4SAndroid Build Coastguard Worker
3939*6236dae4SAndroid Build Coastguard Worker      install)
3940*6236dae4SAndroid Build Coastguard Worker        $ECHO \
3941*6236dae4SAndroid Build Coastguard Worker"Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND...
3942*6236dae4SAndroid Build Coastguard Worker
3943*6236dae4SAndroid Build Coastguard WorkerInstall executables or libraries.
3944*6236dae4SAndroid Build Coastguard Worker
3945*6236dae4SAndroid Build Coastguard WorkerINSTALL-COMMAND is the installation command.  The first component should be
3946*6236dae4SAndroid Build Coastguard Workereither the 'install' or 'cp' program.
3947*6236dae4SAndroid Build Coastguard Worker
3948*6236dae4SAndroid Build Coastguard WorkerThe following components of INSTALL-COMMAND are treated specially:
3949*6236dae4SAndroid Build Coastguard Worker
3950*6236dae4SAndroid Build Coastguard Worker  -inst-prefix-dir PREFIX-DIR  Use PREFIX-DIR as a staging area for installation
3951*6236dae4SAndroid Build Coastguard Worker
3952*6236dae4SAndroid Build Coastguard WorkerThe rest of the components are interpreted as arguments to that command (only
3953*6236dae4SAndroid Build Coastguard WorkerBSD-compatible install options are recognized)."
3954*6236dae4SAndroid Build Coastguard Worker        ;;
3955*6236dae4SAndroid Build Coastguard Worker
3956*6236dae4SAndroid Build Coastguard Worker      link)
3957*6236dae4SAndroid Build Coastguard Worker        $ECHO \
3958*6236dae4SAndroid Build Coastguard Worker"Usage: $progname [OPTION]... --mode=link LINK-COMMAND...
3959*6236dae4SAndroid Build Coastguard Worker
3960*6236dae4SAndroid Build Coastguard WorkerLink object files or libraries together to form another library, or to
3961*6236dae4SAndroid Build Coastguard Workercreate an executable program.
3962*6236dae4SAndroid Build Coastguard Worker
3963*6236dae4SAndroid Build Coastguard WorkerLINK-COMMAND is a command using the C compiler that you would use to create
3964*6236dae4SAndroid Build Coastguard Workera program from several object files.
3965*6236dae4SAndroid Build Coastguard Worker
3966*6236dae4SAndroid Build Coastguard WorkerThe following components of LINK-COMMAND are treated specially:
3967*6236dae4SAndroid Build Coastguard Worker
3968*6236dae4SAndroid Build Coastguard Worker  -all-static       do not do any dynamic linking at all
3969*6236dae4SAndroid Build Coastguard Worker  -avoid-version    do not add a version suffix if possible
3970*6236dae4SAndroid Build Coastguard Worker  -bindir BINDIR    specify path to binaries directory (for systems where
3971*6236dae4SAndroid Build Coastguard Worker                    libraries must be found in the PATH setting at runtime)
3972*6236dae4SAndroid Build Coastguard Worker  -dlopen FILE      '-dlpreopen' FILE if it cannot be dlopened at runtime
3973*6236dae4SAndroid Build Coastguard Worker  -dlpreopen FILE   link in FILE and add its symbols to lt_preloaded_symbols
3974*6236dae4SAndroid Build Coastguard Worker  -export-dynamic   allow symbols from OUTPUT-FILE to be resolved with dlsym(3)
3975*6236dae4SAndroid Build Coastguard Worker  -export-symbols SYMFILE
3976*6236dae4SAndroid Build Coastguard Worker                    try to export only the symbols listed in SYMFILE
3977*6236dae4SAndroid Build Coastguard Worker  -export-symbols-regex REGEX
3978*6236dae4SAndroid Build Coastguard Worker                    try to export only the symbols matching REGEX
3979*6236dae4SAndroid Build Coastguard Worker  -LLIBDIR          search LIBDIR for required installed libraries
3980*6236dae4SAndroid Build Coastguard Worker  -lNAME            OUTPUT-FILE requires the installed library libNAME
3981*6236dae4SAndroid Build Coastguard Worker  -module           build a library that can dlopened
3982*6236dae4SAndroid Build Coastguard Worker  -no-fast-install  disable the fast-install mode
3983*6236dae4SAndroid Build Coastguard Worker  -no-install       link a not-installable executable
3984*6236dae4SAndroid Build Coastguard Worker  -no-undefined     declare that a library does not refer to external symbols
3985*6236dae4SAndroid Build Coastguard Worker  -o OUTPUT-FILE    create OUTPUT-FILE from the specified objects
3986*6236dae4SAndroid Build Coastguard Worker  -objectlist FILE  use a list of object files found in FILE to specify objects
3987*6236dae4SAndroid Build Coastguard Worker  -os2dllname NAME  force a short DLL name on OS/2 (no effect on other OSes)
3988*6236dae4SAndroid Build Coastguard Worker  -precious-files-regex REGEX
3989*6236dae4SAndroid Build Coastguard Worker                    don't remove output files matching REGEX
3990*6236dae4SAndroid Build Coastguard Worker  -release RELEASE  specify package release information
3991*6236dae4SAndroid Build Coastguard Worker  -rpath LIBDIR     the created library will eventually be installed in LIBDIR
3992*6236dae4SAndroid Build Coastguard Worker  -R[ ]LIBDIR       add LIBDIR to the runtime path of programs and libraries
3993*6236dae4SAndroid Build Coastguard Worker  -shared           only do dynamic linking of libtool libraries
3994*6236dae4SAndroid Build Coastguard Worker  -shrext SUFFIX    override the standard shared library file extension
3995*6236dae4SAndroid Build Coastguard Worker  -static           do not do any dynamic linking of uninstalled libtool libraries
3996*6236dae4SAndroid Build Coastguard Worker  -static-libtool-libs
3997*6236dae4SAndroid Build Coastguard Worker                    do not do any dynamic linking of libtool libraries
3998*6236dae4SAndroid Build Coastguard Worker  -version-info CURRENT[:REVISION[:AGE]]
3999*6236dae4SAndroid Build Coastguard Worker                    specify library version info [each variable defaults to 0]
4000*6236dae4SAndroid Build Coastguard Worker  -weak LIBNAME     declare that the target provides the LIBNAME interface
4001*6236dae4SAndroid Build Coastguard Worker  -Wc,FLAG
4002*6236dae4SAndroid Build Coastguard Worker  -Xcompiler FLAG   pass linker-specific FLAG directly to the compiler
4003*6236dae4SAndroid Build Coastguard Worker  -Wa,FLAG
4004*6236dae4SAndroid Build Coastguard Worker  -Xassembler FLAG  pass linker-specific FLAG directly to the assembler
4005*6236dae4SAndroid Build Coastguard Worker  -Wl,FLAG
4006*6236dae4SAndroid Build Coastguard Worker  -Xlinker FLAG     pass linker-specific FLAG directly to the linker
4007*6236dae4SAndroid Build Coastguard Worker  -XCClinker FLAG   pass link-specific FLAG to the compiler driver (CC)
4008*6236dae4SAndroid Build Coastguard Worker
4009*6236dae4SAndroid Build Coastguard WorkerAll other options (arguments beginning with '-') are ignored.
4010*6236dae4SAndroid Build Coastguard Worker
4011*6236dae4SAndroid Build Coastguard WorkerEvery other argument is treated as a filename.  Files ending in '.la' are
4012*6236dae4SAndroid Build Coastguard Workertreated as uninstalled libtool libraries, other files are standard or library
4013*6236dae4SAndroid Build Coastguard Workerobject files.
4014*6236dae4SAndroid Build Coastguard Worker
4015*6236dae4SAndroid Build Coastguard WorkerIf the OUTPUT-FILE ends in '.la', then a libtool library is created,
4016*6236dae4SAndroid Build Coastguard Workeronly library objects ('.lo' files) may be specified, and '-rpath' is
4017*6236dae4SAndroid Build Coastguard Workerrequired, except when creating a convenience library.
4018*6236dae4SAndroid Build Coastguard Worker
4019*6236dae4SAndroid Build Coastguard WorkerIf OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created
4020*6236dae4SAndroid Build Coastguard Workerusing 'ar' and 'ranlib', or on Windows using 'lib'.
4021*6236dae4SAndroid Build Coastguard Worker
4022*6236dae4SAndroid Build Coastguard WorkerIf OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file
4023*6236dae4SAndroid Build Coastguard Workeris created, otherwise an executable program is created."
4024*6236dae4SAndroid Build Coastguard Worker        ;;
4025*6236dae4SAndroid Build Coastguard Worker
4026*6236dae4SAndroid Build Coastguard Worker      uninstall)
4027*6236dae4SAndroid Build Coastguard Worker        $ECHO \
4028*6236dae4SAndroid Build Coastguard Worker"Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE...
4029*6236dae4SAndroid Build Coastguard Worker
4030*6236dae4SAndroid Build Coastguard WorkerRemove libraries from an installation directory.
4031*6236dae4SAndroid Build Coastguard Worker
4032*6236dae4SAndroid Build Coastguard WorkerRM is the name of the program to use to delete files associated with each FILE
4033*6236dae4SAndroid Build Coastguard Worker(typically '/bin/rm').  RM-OPTIONS are options (such as '-f') to be passed
4034*6236dae4SAndroid Build Coastguard Workerto RM.
4035*6236dae4SAndroid Build Coastguard Worker
4036*6236dae4SAndroid Build Coastguard WorkerIf FILE is a libtool library, all the files associated with it are deleted.
4037*6236dae4SAndroid Build Coastguard WorkerOtherwise, only FILE itself is deleted using RM."
4038*6236dae4SAndroid Build Coastguard Worker        ;;
4039*6236dae4SAndroid Build Coastguard Worker
4040*6236dae4SAndroid Build Coastguard Worker      *)
4041*6236dae4SAndroid Build Coastguard Worker        func_fatal_help "invalid operation mode '$opt_mode'"
4042*6236dae4SAndroid Build Coastguard Worker        ;;
4043*6236dae4SAndroid Build Coastguard Worker    esac
4044*6236dae4SAndroid Build Coastguard Worker
4045*6236dae4SAndroid Build Coastguard Worker    echo
4046*6236dae4SAndroid Build Coastguard Worker    $ECHO "Try '$progname --help' for more information about other modes."
4047*6236dae4SAndroid Build Coastguard Worker}
4048*6236dae4SAndroid Build Coastguard Worker
4049*6236dae4SAndroid Build Coastguard Worker# Now that we've collected a possible --mode arg, show help if necessary
4050*6236dae4SAndroid Build Coastguard Workerif $opt_help; then
4051*6236dae4SAndroid Build Coastguard Worker  if test : = "$opt_help"; then
4052*6236dae4SAndroid Build Coastguard Worker    func_mode_help
4053*6236dae4SAndroid Build Coastguard Worker  else
4054*6236dae4SAndroid Build Coastguard Worker    {
4055*6236dae4SAndroid Build Coastguard Worker      func_help noexit
4056*6236dae4SAndroid Build Coastguard Worker      for opt_mode in compile link execute install finish uninstall clean; do
4057*6236dae4SAndroid Build Coastguard Worker	func_mode_help
4058*6236dae4SAndroid Build Coastguard Worker      done
4059*6236dae4SAndroid Build Coastguard Worker    } | $SED -n '1p; 2,$s/^Usage:/  or: /p'
4060*6236dae4SAndroid Build Coastguard Worker    {
4061*6236dae4SAndroid Build Coastguard Worker      func_help noexit
4062*6236dae4SAndroid Build Coastguard Worker      for opt_mode in compile link execute install finish uninstall clean; do
4063*6236dae4SAndroid Build Coastguard Worker	echo
4064*6236dae4SAndroid Build Coastguard Worker	func_mode_help
4065*6236dae4SAndroid Build Coastguard Worker      done
4066*6236dae4SAndroid Build Coastguard Worker    } |
4067*6236dae4SAndroid Build Coastguard Worker    $SED '1d
4068*6236dae4SAndroid Build Coastguard Worker      /^When reporting/,/^Report/{
4069*6236dae4SAndroid Build Coastguard Worker	H
4070*6236dae4SAndroid Build Coastguard Worker	d
4071*6236dae4SAndroid Build Coastguard Worker      }
4072*6236dae4SAndroid Build Coastguard Worker      $x
4073*6236dae4SAndroid Build Coastguard Worker      /information about other modes/d
4074*6236dae4SAndroid Build Coastguard Worker      /more detailed .*MODE/d
4075*6236dae4SAndroid Build Coastguard Worker      s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/'
4076*6236dae4SAndroid Build Coastguard Worker  fi
4077*6236dae4SAndroid Build Coastguard Worker  exit $?
4078*6236dae4SAndroid Build Coastguard Workerfi
4079*6236dae4SAndroid Build Coastguard Worker
4080*6236dae4SAndroid Build Coastguard Worker
4081*6236dae4SAndroid Build Coastguard Worker# func_mode_execute arg...
4082*6236dae4SAndroid Build Coastguard Workerfunc_mode_execute ()
4083*6236dae4SAndroid Build Coastguard Worker{
4084*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
4085*6236dae4SAndroid Build Coastguard Worker
4086*6236dae4SAndroid Build Coastguard Worker    # The first argument is the command name.
4087*6236dae4SAndroid Build Coastguard Worker    cmd=$nonopt
4088*6236dae4SAndroid Build Coastguard Worker    test -z "$cmd" && \
4089*6236dae4SAndroid Build Coastguard Worker      func_fatal_help "you must specify a COMMAND"
4090*6236dae4SAndroid Build Coastguard Worker
4091*6236dae4SAndroid Build Coastguard Worker    # Handle -dlopen flags immediately.
4092*6236dae4SAndroid Build Coastguard Worker    for file in $opt_dlopen; do
4093*6236dae4SAndroid Build Coastguard Worker      test -f "$file" \
4094*6236dae4SAndroid Build Coastguard Worker	|| func_fatal_help "'$file' is not a file"
4095*6236dae4SAndroid Build Coastguard Worker
4096*6236dae4SAndroid Build Coastguard Worker      dir=
4097*6236dae4SAndroid Build Coastguard Worker      case $file in
4098*6236dae4SAndroid Build Coastguard Worker      *.la)
4099*6236dae4SAndroid Build Coastguard Worker	func_resolve_sysroot "$file"
4100*6236dae4SAndroid Build Coastguard Worker	file=$func_resolve_sysroot_result
4101*6236dae4SAndroid Build Coastguard Worker
4102*6236dae4SAndroid Build Coastguard Worker	# Check to see that this really is a libtool archive.
4103*6236dae4SAndroid Build Coastguard Worker	func_lalib_unsafe_p "$file" \
4104*6236dae4SAndroid Build Coastguard Worker	  || func_fatal_help "'$lib' is not a valid libtool archive"
4105*6236dae4SAndroid Build Coastguard Worker
4106*6236dae4SAndroid Build Coastguard Worker	# Read the libtool library.
4107*6236dae4SAndroid Build Coastguard Worker	dlname=
4108*6236dae4SAndroid Build Coastguard Worker	library_names=
4109*6236dae4SAndroid Build Coastguard Worker	func_source "$file"
4110*6236dae4SAndroid Build Coastguard Worker
4111*6236dae4SAndroid Build Coastguard Worker	# Skip this library if it cannot be dlopened.
4112*6236dae4SAndroid Build Coastguard Worker	if test -z "$dlname"; then
4113*6236dae4SAndroid Build Coastguard Worker	  # Warn if it was a shared library.
4114*6236dae4SAndroid Build Coastguard Worker	  test -n "$library_names" && \
4115*6236dae4SAndroid Build Coastguard Worker	    func_warning "'$file' was not linked with '-export-dynamic'"
4116*6236dae4SAndroid Build Coastguard Worker	  continue
4117*6236dae4SAndroid Build Coastguard Worker	fi
4118*6236dae4SAndroid Build Coastguard Worker
4119*6236dae4SAndroid Build Coastguard Worker	func_dirname "$file" "" "."
4120*6236dae4SAndroid Build Coastguard Worker	dir=$func_dirname_result
4121*6236dae4SAndroid Build Coastguard Worker
4122*6236dae4SAndroid Build Coastguard Worker	if test -f "$dir/$objdir/$dlname"; then
4123*6236dae4SAndroid Build Coastguard Worker	  func_append dir "/$objdir"
4124*6236dae4SAndroid Build Coastguard Worker	else
4125*6236dae4SAndroid Build Coastguard Worker	  if test ! -f "$dir/$dlname"; then
4126*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'"
4127*6236dae4SAndroid Build Coastguard Worker	  fi
4128*6236dae4SAndroid Build Coastguard Worker	fi
4129*6236dae4SAndroid Build Coastguard Worker	;;
4130*6236dae4SAndroid Build Coastguard Worker
4131*6236dae4SAndroid Build Coastguard Worker      *.lo)
4132*6236dae4SAndroid Build Coastguard Worker	# Just add the directory containing the .lo file.
4133*6236dae4SAndroid Build Coastguard Worker	func_dirname "$file" "" "."
4134*6236dae4SAndroid Build Coastguard Worker	dir=$func_dirname_result
4135*6236dae4SAndroid Build Coastguard Worker	;;
4136*6236dae4SAndroid Build Coastguard Worker
4137*6236dae4SAndroid Build Coastguard Worker      *)
4138*6236dae4SAndroid Build Coastguard Worker	func_warning "'-dlopen' is ignored for non-libtool libraries and objects"
4139*6236dae4SAndroid Build Coastguard Worker	continue
4140*6236dae4SAndroid Build Coastguard Worker	;;
4141*6236dae4SAndroid Build Coastguard Worker      esac
4142*6236dae4SAndroid Build Coastguard Worker
4143*6236dae4SAndroid Build Coastguard Worker      # Get the absolute pathname.
4144*6236dae4SAndroid Build Coastguard Worker      absdir=`cd "$dir" && pwd`
4145*6236dae4SAndroid Build Coastguard Worker      test -n "$absdir" && dir=$absdir
4146*6236dae4SAndroid Build Coastguard Worker
4147*6236dae4SAndroid Build Coastguard Worker      # Now add the directory to shlibpath_var.
4148*6236dae4SAndroid Build Coastguard Worker      if eval "test -z \"\$$shlibpath_var\""; then
4149*6236dae4SAndroid Build Coastguard Worker	eval "$shlibpath_var=\"\$dir\""
4150*6236dae4SAndroid Build Coastguard Worker      else
4151*6236dae4SAndroid Build Coastguard Worker	eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\""
4152*6236dae4SAndroid Build Coastguard Worker      fi
4153*6236dae4SAndroid Build Coastguard Worker    done
4154*6236dae4SAndroid Build Coastguard Worker
4155*6236dae4SAndroid Build Coastguard Worker    # This variable tells wrapper scripts just to set shlibpath_var
4156*6236dae4SAndroid Build Coastguard Worker    # rather than running their programs.
4157*6236dae4SAndroid Build Coastguard Worker    libtool_execute_magic=$magic
4158*6236dae4SAndroid Build Coastguard Worker
4159*6236dae4SAndroid Build Coastguard Worker    # Check if any of the arguments is a wrapper script.
4160*6236dae4SAndroid Build Coastguard Worker    args=
4161*6236dae4SAndroid Build Coastguard Worker    for file
4162*6236dae4SAndroid Build Coastguard Worker    do
4163*6236dae4SAndroid Build Coastguard Worker      case $file in
4164*6236dae4SAndroid Build Coastguard Worker      -* | *.la | *.lo ) ;;
4165*6236dae4SAndroid Build Coastguard Worker      *)
4166*6236dae4SAndroid Build Coastguard Worker	# Do a test to see if this is really a libtool program.
4167*6236dae4SAndroid Build Coastguard Worker	if func_ltwrapper_script_p "$file"; then
4168*6236dae4SAndroid Build Coastguard Worker	  func_source "$file"
4169*6236dae4SAndroid Build Coastguard Worker	  # Transform arg to wrapped name.
4170*6236dae4SAndroid Build Coastguard Worker	  file=$progdir/$program
4171*6236dae4SAndroid Build Coastguard Worker	elif func_ltwrapper_executable_p "$file"; then
4172*6236dae4SAndroid Build Coastguard Worker	  func_ltwrapper_scriptname "$file"
4173*6236dae4SAndroid Build Coastguard Worker	  func_source "$func_ltwrapper_scriptname_result"
4174*6236dae4SAndroid Build Coastguard Worker	  # Transform arg to wrapped name.
4175*6236dae4SAndroid Build Coastguard Worker	  file=$progdir/$program
4176*6236dae4SAndroid Build Coastguard Worker	fi
4177*6236dae4SAndroid Build Coastguard Worker	;;
4178*6236dae4SAndroid Build Coastguard Worker      esac
4179*6236dae4SAndroid Build Coastguard Worker      # Quote arguments (to preserve shell metacharacters).
4180*6236dae4SAndroid Build Coastguard Worker      func_append_quoted args "$file"
4181*6236dae4SAndroid Build Coastguard Worker    done
4182*6236dae4SAndroid Build Coastguard Worker
4183*6236dae4SAndroid Build Coastguard Worker    if $opt_dry_run; then
4184*6236dae4SAndroid Build Coastguard Worker      # Display what would be done.
4185*6236dae4SAndroid Build Coastguard Worker      if test -n "$shlibpath_var"; then
4186*6236dae4SAndroid Build Coastguard Worker	eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\""
4187*6236dae4SAndroid Build Coastguard Worker	echo "export $shlibpath_var"
4188*6236dae4SAndroid Build Coastguard Worker      fi
4189*6236dae4SAndroid Build Coastguard Worker      $ECHO "$cmd$args"
4190*6236dae4SAndroid Build Coastguard Worker      exit $EXIT_SUCCESS
4191*6236dae4SAndroid Build Coastguard Worker    else
4192*6236dae4SAndroid Build Coastguard Worker      if test -n "$shlibpath_var"; then
4193*6236dae4SAndroid Build Coastguard Worker	# Export the shlibpath_var.
4194*6236dae4SAndroid Build Coastguard Worker	eval "export $shlibpath_var"
4195*6236dae4SAndroid Build Coastguard Worker      fi
4196*6236dae4SAndroid Build Coastguard Worker
4197*6236dae4SAndroid Build Coastguard Worker      # Restore saved environment variables
4198*6236dae4SAndroid Build Coastguard Worker      for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
4199*6236dae4SAndroid Build Coastguard Worker      do
4200*6236dae4SAndroid Build Coastguard Worker	eval "if test \"\${save_$lt_var+set}\" = set; then
4201*6236dae4SAndroid Build Coastguard Worker                $lt_var=\$save_$lt_var; export $lt_var
4202*6236dae4SAndroid Build Coastguard Worker	      else
4203*6236dae4SAndroid Build Coastguard Worker		$lt_unset $lt_var
4204*6236dae4SAndroid Build Coastguard Worker	      fi"
4205*6236dae4SAndroid Build Coastguard Worker      done
4206*6236dae4SAndroid Build Coastguard Worker
4207*6236dae4SAndroid Build Coastguard Worker      # Now prepare to actually exec the command.
4208*6236dae4SAndroid Build Coastguard Worker      exec_cmd=\$cmd$args
4209*6236dae4SAndroid Build Coastguard Worker    fi
4210*6236dae4SAndroid Build Coastguard Worker}
4211*6236dae4SAndroid Build Coastguard Worker
4212*6236dae4SAndroid Build Coastguard Workertest execute = "$opt_mode" && func_mode_execute ${1+"$@"}
4213*6236dae4SAndroid Build Coastguard Worker
4214*6236dae4SAndroid Build Coastguard Worker
4215*6236dae4SAndroid Build Coastguard Worker# func_mode_finish arg...
4216*6236dae4SAndroid Build Coastguard Workerfunc_mode_finish ()
4217*6236dae4SAndroid Build Coastguard Worker{
4218*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
4219*6236dae4SAndroid Build Coastguard Worker
4220*6236dae4SAndroid Build Coastguard Worker    libs=
4221*6236dae4SAndroid Build Coastguard Worker    libdirs=
4222*6236dae4SAndroid Build Coastguard Worker    admincmds=
4223*6236dae4SAndroid Build Coastguard Worker
4224*6236dae4SAndroid Build Coastguard Worker    for opt in "$nonopt" ${1+"$@"}
4225*6236dae4SAndroid Build Coastguard Worker    do
4226*6236dae4SAndroid Build Coastguard Worker      if test -d "$opt"; then
4227*6236dae4SAndroid Build Coastguard Worker	func_append libdirs " $opt"
4228*6236dae4SAndroid Build Coastguard Worker
4229*6236dae4SAndroid Build Coastguard Worker      elif test -f "$opt"; then
4230*6236dae4SAndroid Build Coastguard Worker	if func_lalib_unsafe_p "$opt"; then
4231*6236dae4SAndroid Build Coastguard Worker	  func_append libs " $opt"
4232*6236dae4SAndroid Build Coastguard Worker	else
4233*6236dae4SAndroid Build Coastguard Worker	  func_warning "'$opt' is not a valid libtool archive"
4234*6236dae4SAndroid Build Coastguard Worker	fi
4235*6236dae4SAndroid Build Coastguard Worker
4236*6236dae4SAndroid Build Coastguard Worker      else
4237*6236dae4SAndroid Build Coastguard Worker	func_fatal_error "invalid argument '$opt'"
4238*6236dae4SAndroid Build Coastguard Worker      fi
4239*6236dae4SAndroid Build Coastguard Worker    done
4240*6236dae4SAndroid Build Coastguard Worker
4241*6236dae4SAndroid Build Coastguard Worker    if test -n "$libs"; then
4242*6236dae4SAndroid Build Coastguard Worker      if test -n "$lt_sysroot"; then
4243*6236dae4SAndroid Build Coastguard Worker        sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"`
4244*6236dae4SAndroid Build Coastguard Worker        sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;"
4245*6236dae4SAndroid Build Coastguard Worker      else
4246*6236dae4SAndroid Build Coastguard Worker        sysroot_cmd=
4247*6236dae4SAndroid Build Coastguard Worker      fi
4248*6236dae4SAndroid Build Coastguard Worker
4249*6236dae4SAndroid Build Coastguard Worker      # Remove sysroot references
4250*6236dae4SAndroid Build Coastguard Worker      if $opt_dry_run; then
4251*6236dae4SAndroid Build Coastguard Worker        for lib in $libs; do
4252*6236dae4SAndroid Build Coastguard Worker          echo "removing references to $lt_sysroot and '=' prefixes from $lib"
4253*6236dae4SAndroid Build Coastguard Worker        done
4254*6236dae4SAndroid Build Coastguard Worker      else
4255*6236dae4SAndroid Build Coastguard Worker        tmpdir=`func_mktempdir`
4256*6236dae4SAndroid Build Coastguard Worker        for lib in $libs; do
4257*6236dae4SAndroid Build Coastguard Worker	  $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \
4258*6236dae4SAndroid Build Coastguard Worker	    > $tmpdir/tmp-la
4259*6236dae4SAndroid Build Coastguard Worker	  mv -f $tmpdir/tmp-la $lib
4260*6236dae4SAndroid Build Coastguard Worker	done
4261*6236dae4SAndroid Build Coastguard Worker        ${RM}r "$tmpdir"
4262*6236dae4SAndroid Build Coastguard Worker      fi
4263*6236dae4SAndroid Build Coastguard Worker    fi
4264*6236dae4SAndroid Build Coastguard Worker
4265*6236dae4SAndroid Build Coastguard Worker    if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
4266*6236dae4SAndroid Build Coastguard Worker      for libdir in $libdirs; do
4267*6236dae4SAndroid Build Coastguard Worker	if test -n "$finish_cmds"; then
4268*6236dae4SAndroid Build Coastguard Worker	  # Do each command in the finish commands.
4269*6236dae4SAndroid Build Coastguard Worker	  func_execute_cmds "$finish_cmds" 'admincmds="$admincmds
4270*6236dae4SAndroid Build Coastguard Worker'"$cmd"'"'
4271*6236dae4SAndroid Build Coastguard Worker	fi
4272*6236dae4SAndroid Build Coastguard Worker	if test -n "$finish_eval"; then
4273*6236dae4SAndroid Build Coastguard Worker	  # Do the single finish_eval.
4274*6236dae4SAndroid Build Coastguard Worker	  eval cmds=\"$finish_eval\"
4275*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || eval "$cmds" || func_append admincmds "
4276*6236dae4SAndroid Build Coastguard Worker       $cmds"
4277*6236dae4SAndroid Build Coastguard Worker	fi
4278*6236dae4SAndroid Build Coastguard Worker      done
4279*6236dae4SAndroid Build Coastguard Worker    fi
4280*6236dae4SAndroid Build Coastguard Worker
4281*6236dae4SAndroid Build Coastguard Worker    # Exit here if they wanted silent mode.
4282*6236dae4SAndroid Build Coastguard Worker    $opt_quiet && exit $EXIT_SUCCESS
4283*6236dae4SAndroid Build Coastguard Worker
4284*6236dae4SAndroid Build Coastguard Worker    if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
4285*6236dae4SAndroid Build Coastguard Worker      echo "----------------------------------------------------------------------"
4286*6236dae4SAndroid Build Coastguard Worker      echo "Libraries have been installed in:"
4287*6236dae4SAndroid Build Coastguard Worker      for libdir in $libdirs; do
4288*6236dae4SAndroid Build Coastguard Worker	$ECHO "   $libdir"
4289*6236dae4SAndroid Build Coastguard Worker      done
4290*6236dae4SAndroid Build Coastguard Worker      echo
4291*6236dae4SAndroid Build Coastguard Worker      echo "If you ever happen to want to link against installed libraries"
4292*6236dae4SAndroid Build Coastguard Worker      echo "in a given directory, LIBDIR, you must either use libtool, and"
4293*6236dae4SAndroid Build Coastguard Worker      echo "specify the full pathname of the library, or use the '-LLIBDIR'"
4294*6236dae4SAndroid Build Coastguard Worker      echo "flag during linking and do at least one of the following:"
4295*6236dae4SAndroid Build Coastguard Worker      if test -n "$shlibpath_var"; then
4296*6236dae4SAndroid Build Coastguard Worker	echo "   - add LIBDIR to the '$shlibpath_var' environment variable"
4297*6236dae4SAndroid Build Coastguard Worker	echo "     during execution"
4298*6236dae4SAndroid Build Coastguard Worker      fi
4299*6236dae4SAndroid Build Coastguard Worker      if test -n "$runpath_var"; then
4300*6236dae4SAndroid Build Coastguard Worker	echo "   - add LIBDIR to the '$runpath_var' environment variable"
4301*6236dae4SAndroid Build Coastguard Worker	echo "     during linking"
4302*6236dae4SAndroid Build Coastguard Worker      fi
4303*6236dae4SAndroid Build Coastguard Worker      if test -n "$hardcode_libdir_flag_spec"; then
4304*6236dae4SAndroid Build Coastguard Worker	libdir=LIBDIR
4305*6236dae4SAndroid Build Coastguard Worker	eval flag=\"$hardcode_libdir_flag_spec\"
4306*6236dae4SAndroid Build Coastguard Worker
4307*6236dae4SAndroid Build Coastguard Worker	$ECHO "   - use the '$flag' linker flag"
4308*6236dae4SAndroid Build Coastguard Worker      fi
4309*6236dae4SAndroid Build Coastguard Worker      if test -n "$admincmds"; then
4310*6236dae4SAndroid Build Coastguard Worker	$ECHO "   - have your system administrator run these commands:$admincmds"
4311*6236dae4SAndroid Build Coastguard Worker      fi
4312*6236dae4SAndroid Build Coastguard Worker      if test -f /etc/ld.so.conf; then
4313*6236dae4SAndroid Build Coastguard Worker	echo "   - have your system administrator add LIBDIR to '/etc/ld.so.conf'"
4314*6236dae4SAndroid Build Coastguard Worker      fi
4315*6236dae4SAndroid Build Coastguard Worker      echo
4316*6236dae4SAndroid Build Coastguard Worker
4317*6236dae4SAndroid Build Coastguard Worker      echo "See any operating system documentation about shared libraries for"
4318*6236dae4SAndroid Build Coastguard Worker      case $host in
4319*6236dae4SAndroid Build Coastguard Worker	solaris2.[6789]|solaris2.1[0-9])
4320*6236dae4SAndroid Build Coastguard Worker	  echo "more information, such as the ld(1), crle(1) and ld.so(8) manual"
4321*6236dae4SAndroid Build Coastguard Worker	  echo "pages."
4322*6236dae4SAndroid Build Coastguard Worker	  ;;
4323*6236dae4SAndroid Build Coastguard Worker	*)
4324*6236dae4SAndroid Build Coastguard Worker	  echo "more information, such as the ld(1) and ld.so(8) manual pages."
4325*6236dae4SAndroid Build Coastguard Worker	  ;;
4326*6236dae4SAndroid Build Coastguard Worker      esac
4327*6236dae4SAndroid Build Coastguard Worker      echo "----------------------------------------------------------------------"
4328*6236dae4SAndroid Build Coastguard Worker    fi
4329*6236dae4SAndroid Build Coastguard Worker    exit $EXIT_SUCCESS
4330*6236dae4SAndroid Build Coastguard Worker}
4331*6236dae4SAndroid Build Coastguard Worker
4332*6236dae4SAndroid Build Coastguard Workertest finish = "$opt_mode" && func_mode_finish ${1+"$@"}
4333*6236dae4SAndroid Build Coastguard Worker
4334*6236dae4SAndroid Build Coastguard Worker
4335*6236dae4SAndroid Build Coastguard Worker# func_mode_install arg...
4336*6236dae4SAndroid Build Coastguard Workerfunc_mode_install ()
4337*6236dae4SAndroid Build Coastguard Worker{
4338*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
4339*6236dae4SAndroid Build Coastguard Worker
4340*6236dae4SAndroid Build Coastguard Worker    # There may be an optional sh(1) argument at the beginning of
4341*6236dae4SAndroid Build Coastguard Worker    # install_prog (especially on Windows NT).
4342*6236dae4SAndroid Build Coastguard Worker    if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" ||
4343*6236dae4SAndroid Build Coastguard Worker       # Allow the use of GNU shtool's install command.
4344*6236dae4SAndroid Build Coastguard Worker       case $nonopt in *shtool*) :;; *) false;; esac
4345*6236dae4SAndroid Build Coastguard Worker    then
4346*6236dae4SAndroid Build Coastguard Worker      # Aesthetically quote it.
4347*6236dae4SAndroid Build Coastguard Worker      func_quote_arg pretty "$nonopt"
4348*6236dae4SAndroid Build Coastguard Worker      install_prog="$func_quote_arg_result "
4349*6236dae4SAndroid Build Coastguard Worker      arg=$1
4350*6236dae4SAndroid Build Coastguard Worker      shift
4351*6236dae4SAndroid Build Coastguard Worker    else
4352*6236dae4SAndroid Build Coastguard Worker      install_prog=
4353*6236dae4SAndroid Build Coastguard Worker      arg=$nonopt
4354*6236dae4SAndroid Build Coastguard Worker    fi
4355*6236dae4SAndroid Build Coastguard Worker
4356*6236dae4SAndroid Build Coastguard Worker    # The real first argument should be the name of the installation program.
4357*6236dae4SAndroid Build Coastguard Worker    # Aesthetically quote it.
4358*6236dae4SAndroid Build Coastguard Worker    func_quote_arg pretty "$arg"
4359*6236dae4SAndroid Build Coastguard Worker    func_append install_prog "$func_quote_arg_result"
4360*6236dae4SAndroid Build Coastguard Worker    install_shared_prog=$install_prog
4361*6236dae4SAndroid Build Coastguard Worker    case " $install_prog " in
4362*6236dae4SAndroid Build Coastguard Worker      *[\\\ /]cp\ *) install_cp=: ;;
4363*6236dae4SAndroid Build Coastguard Worker      *) install_cp=false ;;
4364*6236dae4SAndroid Build Coastguard Worker    esac
4365*6236dae4SAndroid Build Coastguard Worker
4366*6236dae4SAndroid Build Coastguard Worker    # We need to accept at least all the BSD install flags.
4367*6236dae4SAndroid Build Coastguard Worker    dest=
4368*6236dae4SAndroid Build Coastguard Worker    files=
4369*6236dae4SAndroid Build Coastguard Worker    opts=
4370*6236dae4SAndroid Build Coastguard Worker    prev=
4371*6236dae4SAndroid Build Coastguard Worker    install_type=
4372*6236dae4SAndroid Build Coastguard Worker    isdir=false
4373*6236dae4SAndroid Build Coastguard Worker    stripme=
4374*6236dae4SAndroid Build Coastguard Worker    no_mode=:
4375*6236dae4SAndroid Build Coastguard Worker    for arg
4376*6236dae4SAndroid Build Coastguard Worker    do
4377*6236dae4SAndroid Build Coastguard Worker      arg2=
4378*6236dae4SAndroid Build Coastguard Worker      if test -n "$dest"; then
4379*6236dae4SAndroid Build Coastguard Worker	func_append files " $dest"
4380*6236dae4SAndroid Build Coastguard Worker	dest=$arg
4381*6236dae4SAndroid Build Coastguard Worker	continue
4382*6236dae4SAndroid Build Coastguard Worker      fi
4383*6236dae4SAndroid Build Coastguard Worker
4384*6236dae4SAndroid Build Coastguard Worker      case $arg in
4385*6236dae4SAndroid Build Coastguard Worker      -d) isdir=: ;;
4386*6236dae4SAndroid Build Coastguard Worker      -f)
4387*6236dae4SAndroid Build Coastguard Worker	if $install_cp; then :; else
4388*6236dae4SAndroid Build Coastguard Worker	  prev=$arg
4389*6236dae4SAndroid Build Coastguard Worker	fi
4390*6236dae4SAndroid Build Coastguard Worker	;;
4391*6236dae4SAndroid Build Coastguard Worker      -g | -m | -o)
4392*6236dae4SAndroid Build Coastguard Worker	prev=$arg
4393*6236dae4SAndroid Build Coastguard Worker	;;
4394*6236dae4SAndroid Build Coastguard Worker      -s)
4395*6236dae4SAndroid Build Coastguard Worker	stripme=" -s"
4396*6236dae4SAndroid Build Coastguard Worker	continue
4397*6236dae4SAndroid Build Coastguard Worker	;;
4398*6236dae4SAndroid Build Coastguard Worker      -*)
4399*6236dae4SAndroid Build Coastguard Worker	;;
4400*6236dae4SAndroid Build Coastguard Worker      *)
4401*6236dae4SAndroid Build Coastguard Worker	# If the previous option needed an argument, then skip it.
4402*6236dae4SAndroid Build Coastguard Worker	if test -n "$prev"; then
4403*6236dae4SAndroid Build Coastguard Worker	  if test X-m = "X$prev" && test -n "$install_override_mode"; then
4404*6236dae4SAndroid Build Coastguard Worker	    arg2=$install_override_mode
4405*6236dae4SAndroid Build Coastguard Worker	    no_mode=false
4406*6236dae4SAndroid Build Coastguard Worker	  fi
4407*6236dae4SAndroid Build Coastguard Worker	  prev=
4408*6236dae4SAndroid Build Coastguard Worker	else
4409*6236dae4SAndroid Build Coastguard Worker	  dest=$arg
4410*6236dae4SAndroid Build Coastguard Worker	  continue
4411*6236dae4SAndroid Build Coastguard Worker	fi
4412*6236dae4SAndroid Build Coastguard Worker	;;
4413*6236dae4SAndroid Build Coastguard Worker      esac
4414*6236dae4SAndroid Build Coastguard Worker
4415*6236dae4SAndroid Build Coastguard Worker      # Aesthetically quote the argument.
4416*6236dae4SAndroid Build Coastguard Worker      func_quote_arg pretty "$arg"
4417*6236dae4SAndroid Build Coastguard Worker      func_append install_prog " $func_quote_arg_result"
4418*6236dae4SAndroid Build Coastguard Worker      if test -n "$arg2"; then
4419*6236dae4SAndroid Build Coastguard Worker	func_quote_arg pretty "$arg2"
4420*6236dae4SAndroid Build Coastguard Worker      fi
4421*6236dae4SAndroid Build Coastguard Worker      func_append install_shared_prog " $func_quote_arg_result"
4422*6236dae4SAndroid Build Coastguard Worker    done
4423*6236dae4SAndroid Build Coastguard Worker
4424*6236dae4SAndroid Build Coastguard Worker    test -z "$install_prog" && \
4425*6236dae4SAndroid Build Coastguard Worker      func_fatal_help "you must specify an install program"
4426*6236dae4SAndroid Build Coastguard Worker
4427*6236dae4SAndroid Build Coastguard Worker    test -n "$prev" && \
4428*6236dae4SAndroid Build Coastguard Worker      func_fatal_help "the '$prev' option requires an argument"
4429*6236dae4SAndroid Build Coastguard Worker
4430*6236dae4SAndroid Build Coastguard Worker    if test -n "$install_override_mode" && $no_mode; then
4431*6236dae4SAndroid Build Coastguard Worker      if $install_cp; then :; else
4432*6236dae4SAndroid Build Coastguard Worker	func_quote_arg pretty "$install_override_mode"
4433*6236dae4SAndroid Build Coastguard Worker	func_append install_shared_prog " -m $func_quote_arg_result"
4434*6236dae4SAndroid Build Coastguard Worker      fi
4435*6236dae4SAndroid Build Coastguard Worker    fi
4436*6236dae4SAndroid Build Coastguard Worker
4437*6236dae4SAndroid Build Coastguard Worker    if test -z "$files"; then
4438*6236dae4SAndroid Build Coastguard Worker      if test -z "$dest"; then
4439*6236dae4SAndroid Build Coastguard Worker	func_fatal_help "no file or destination specified"
4440*6236dae4SAndroid Build Coastguard Worker      else
4441*6236dae4SAndroid Build Coastguard Worker	func_fatal_help "you must specify a destination"
4442*6236dae4SAndroid Build Coastguard Worker      fi
4443*6236dae4SAndroid Build Coastguard Worker    fi
4444*6236dae4SAndroid Build Coastguard Worker
4445*6236dae4SAndroid Build Coastguard Worker    # Strip any trailing slash from the destination.
4446*6236dae4SAndroid Build Coastguard Worker    func_stripname '' '/' "$dest"
4447*6236dae4SAndroid Build Coastguard Worker    dest=$func_stripname_result
4448*6236dae4SAndroid Build Coastguard Worker
4449*6236dae4SAndroid Build Coastguard Worker    # Check to see that the destination is a directory.
4450*6236dae4SAndroid Build Coastguard Worker    test -d "$dest" && isdir=:
4451*6236dae4SAndroid Build Coastguard Worker    if $isdir; then
4452*6236dae4SAndroid Build Coastguard Worker      destdir=$dest
4453*6236dae4SAndroid Build Coastguard Worker      destname=
4454*6236dae4SAndroid Build Coastguard Worker    else
4455*6236dae4SAndroid Build Coastguard Worker      func_dirname_and_basename "$dest" "" "."
4456*6236dae4SAndroid Build Coastguard Worker      destdir=$func_dirname_result
4457*6236dae4SAndroid Build Coastguard Worker      destname=$func_basename_result
4458*6236dae4SAndroid Build Coastguard Worker
4459*6236dae4SAndroid Build Coastguard Worker      # Not a directory, so check to see that there is only one file specified.
4460*6236dae4SAndroid Build Coastguard Worker      set dummy $files; shift
4461*6236dae4SAndroid Build Coastguard Worker      test "$#" -gt 1 && \
4462*6236dae4SAndroid Build Coastguard Worker	func_fatal_help "'$dest' is not a directory"
4463*6236dae4SAndroid Build Coastguard Worker    fi
4464*6236dae4SAndroid Build Coastguard Worker    case $destdir in
4465*6236dae4SAndroid Build Coastguard Worker    [\\/]* | [A-Za-z]:[\\/]*) ;;
4466*6236dae4SAndroid Build Coastguard Worker    *)
4467*6236dae4SAndroid Build Coastguard Worker      for file in $files; do
4468*6236dae4SAndroid Build Coastguard Worker	case $file in
4469*6236dae4SAndroid Build Coastguard Worker	*.lo) ;;
4470*6236dae4SAndroid Build Coastguard Worker	*)
4471*6236dae4SAndroid Build Coastguard Worker	  func_fatal_help "'$destdir' must be an absolute directory name"
4472*6236dae4SAndroid Build Coastguard Worker	  ;;
4473*6236dae4SAndroid Build Coastguard Worker	esac
4474*6236dae4SAndroid Build Coastguard Worker      done
4475*6236dae4SAndroid Build Coastguard Worker      ;;
4476*6236dae4SAndroid Build Coastguard Worker    esac
4477*6236dae4SAndroid Build Coastguard Worker
4478*6236dae4SAndroid Build Coastguard Worker    # This variable tells wrapper scripts just to set variables rather
4479*6236dae4SAndroid Build Coastguard Worker    # than running their programs.
4480*6236dae4SAndroid Build Coastguard Worker    libtool_install_magic=$magic
4481*6236dae4SAndroid Build Coastguard Worker
4482*6236dae4SAndroid Build Coastguard Worker    staticlibs=
4483*6236dae4SAndroid Build Coastguard Worker    future_libdirs=
4484*6236dae4SAndroid Build Coastguard Worker    current_libdirs=
4485*6236dae4SAndroid Build Coastguard Worker    for file in $files; do
4486*6236dae4SAndroid Build Coastguard Worker
4487*6236dae4SAndroid Build Coastguard Worker      # Do each installation.
4488*6236dae4SAndroid Build Coastguard Worker      case $file in
4489*6236dae4SAndroid Build Coastguard Worker      *.$libext)
4490*6236dae4SAndroid Build Coastguard Worker	# Do the static libraries later.
4491*6236dae4SAndroid Build Coastguard Worker	func_append staticlibs " $file"
4492*6236dae4SAndroid Build Coastguard Worker	;;
4493*6236dae4SAndroid Build Coastguard Worker
4494*6236dae4SAndroid Build Coastguard Worker      *.la)
4495*6236dae4SAndroid Build Coastguard Worker	func_resolve_sysroot "$file"
4496*6236dae4SAndroid Build Coastguard Worker	file=$func_resolve_sysroot_result
4497*6236dae4SAndroid Build Coastguard Worker
4498*6236dae4SAndroid Build Coastguard Worker	# Check to see that this really is a libtool archive.
4499*6236dae4SAndroid Build Coastguard Worker	func_lalib_unsafe_p "$file" \
4500*6236dae4SAndroid Build Coastguard Worker	  || func_fatal_help "'$file' is not a valid libtool archive"
4501*6236dae4SAndroid Build Coastguard Worker
4502*6236dae4SAndroid Build Coastguard Worker	library_names=
4503*6236dae4SAndroid Build Coastguard Worker	old_library=
4504*6236dae4SAndroid Build Coastguard Worker	relink_command=
4505*6236dae4SAndroid Build Coastguard Worker	func_source "$file"
4506*6236dae4SAndroid Build Coastguard Worker
4507*6236dae4SAndroid Build Coastguard Worker	# Add the libdir to current_libdirs if it is the destination.
4508*6236dae4SAndroid Build Coastguard Worker	if test "X$destdir" = "X$libdir"; then
4509*6236dae4SAndroid Build Coastguard Worker	  case "$current_libdirs " in
4510*6236dae4SAndroid Build Coastguard Worker	  *" $libdir "*) ;;
4511*6236dae4SAndroid Build Coastguard Worker	  *) func_append current_libdirs " $libdir" ;;
4512*6236dae4SAndroid Build Coastguard Worker	  esac
4513*6236dae4SAndroid Build Coastguard Worker	else
4514*6236dae4SAndroid Build Coastguard Worker	  # Note the libdir as a future libdir.
4515*6236dae4SAndroid Build Coastguard Worker	  case "$future_libdirs " in
4516*6236dae4SAndroid Build Coastguard Worker	  *" $libdir "*) ;;
4517*6236dae4SAndroid Build Coastguard Worker	  *) func_append future_libdirs " $libdir" ;;
4518*6236dae4SAndroid Build Coastguard Worker	  esac
4519*6236dae4SAndroid Build Coastguard Worker	fi
4520*6236dae4SAndroid Build Coastguard Worker
4521*6236dae4SAndroid Build Coastguard Worker	func_dirname "$file" "/" ""
4522*6236dae4SAndroid Build Coastguard Worker	dir=$func_dirname_result
4523*6236dae4SAndroid Build Coastguard Worker	func_append dir "$objdir"
4524*6236dae4SAndroid Build Coastguard Worker
4525*6236dae4SAndroid Build Coastguard Worker	if test -n "$relink_command"; then
4526*6236dae4SAndroid Build Coastguard Worker	  # Determine the prefix the user has applied to our future dir.
4527*6236dae4SAndroid Build Coastguard Worker	  inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"`
4528*6236dae4SAndroid Build Coastguard Worker
4529*6236dae4SAndroid Build Coastguard Worker	  # Don't allow the user to place us outside of our expected
4530*6236dae4SAndroid Build Coastguard Worker	  # location b/c this prevents finding dependent libraries that
4531*6236dae4SAndroid Build Coastguard Worker	  # are installed to the same prefix.
4532*6236dae4SAndroid Build Coastguard Worker	  # At present, this check doesn't affect windows .dll's that
4533*6236dae4SAndroid Build Coastguard Worker	  # are installed into $libdir/../bin (currently, that works fine)
4534*6236dae4SAndroid Build Coastguard Worker	  # but it's something to keep an eye on.
4535*6236dae4SAndroid Build Coastguard Worker	  test "$inst_prefix_dir" = "$destdir" && \
4536*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir"
4537*6236dae4SAndroid Build Coastguard Worker
4538*6236dae4SAndroid Build Coastguard Worker	  if test -n "$inst_prefix_dir"; then
4539*6236dae4SAndroid Build Coastguard Worker	    # Stick the inst_prefix_dir data into the link command.
4540*6236dae4SAndroid Build Coastguard Worker	    relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"`
4541*6236dae4SAndroid Build Coastguard Worker	  else
4542*6236dae4SAndroid Build Coastguard Worker	    relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"`
4543*6236dae4SAndroid Build Coastguard Worker	  fi
4544*6236dae4SAndroid Build Coastguard Worker
4545*6236dae4SAndroid Build Coastguard Worker	  func_warning "relinking '$file'"
4546*6236dae4SAndroid Build Coastguard Worker	  func_show_eval "$relink_command" \
4547*6236dae4SAndroid Build Coastguard Worker	    'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"'
4548*6236dae4SAndroid Build Coastguard Worker	fi
4549*6236dae4SAndroid Build Coastguard Worker
4550*6236dae4SAndroid Build Coastguard Worker	# See the names of the shared library.
4551*6236dae4SAndroid Build Coastguard Worker	set dummy $library_names; shift
4552*6236dae4SAndroid Build Coastguard Worker	if test -n "$1"; then
4553*6236dae4SAndroid Build Coastguard Worker	  realname=$1
4554*6236dae4SAndroid Build Coastguard Worker	  shift
4555*6236dae4SAndroid Build Coastguard Worker
4556*6236dae4SAndroid Build Coastguard Worker	  srcname=$realname
4557*6236dae4SAndroid Build Coastguard Worker	  test -n "$relink_command" && srcname=${realname}T
4558*6236dae4SAndroid Build Coastguard Worker
4559*6236dae4SAndroid Build Coastguard Worker	  # Install the shared library and build the symlinks.
4560*6236dae4SAndroid Build Coastguard Worker	  func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \
4561*6236dae4SAndroid Build Coastguard Worker	      'exit $?'
4562*6236dae4SAndroid Build Coastguard Worker	  tstripme=$stripme
4563*6236dae4SAndroid Build Coastguard Worker	  case $host_os in
4564*6236dae4SAndroid Build Coastguard Worker	  cygwin* | mingw* | pw32* | cegcc*)
4565*6236dae4SAndroid Build Coastguard Worker	    case $realname in
4566*6236dae4SAndroid Build Coastguard Worker	    *.dll.a)
4567*6236dae4SAndroid Build Coastguard Worker	      tstripme=
4568*6236dae4SAndroid Build Coastguard Worker	      ;;
4569*6236dae4SAndroid Build Coastguard Worker	    esac
4570*6236dae4SAndroid Build Coastguard Worker	    ;;
4571*6236dae4SAndroid Build Coastguard Worker	  os2*)
4572*6236dae4SAndroid Build Coastguard Worker	    case $realname in
4573*6236dae4SAndroid Build Coastguard Worker	    *_dll.a)
4574*6236dae4SAndroid Build Coastguard Worker	      tstripme=
4575*6236dae4SAndroid Build Coastguard Worker	      ;;
4576*6236dae4SAndroid Build Coastguard Worker	    esac
4577*6236dae4SAndroid Build Coastguard Worker	    ;;
4578*6236dae4SAndroid Build Coastguard Worker	  esac
4579*6236dae4SAndroid Build Coastguard Worker	  if test -n "$tstripme" && test -n "$striplib"; then
4580*6236dae4SAndroid Build Coastguard Worker	    func_show_eval "$striplib $destdir/$realname" 'exit $?'
4581*6236dae4SAndroid Build Coastguard Worker	  fi
4582*6236dae4SAndroid Build Coastguard Worker
4583*6236dae4SAndroid Build Coastguard Worker	  if test "$#" -gt 0; then
4584*6236dae4SAndroid Build Coastguard Worker	    # Delete the old symlinks, and create new ones.
4585*6236dae4SAndroid Build Coastguard Worker	    # Try 'ln -sf' first, because the 'ln' binary might depend on
4586*6236dae4SAndroid Build Coastguard Worker	    # the symlink we replace!  Solaris /bin/ln does not understand -f,
4587*6236dae4SAndroid Build Coastguard Worker	    # so we also need to try rm && ln -s.
4588*6236dae4SAndroid Build Coastguard Worker	    for linkname
4589*6236dae4SAndroid Build Coastguard Worker	    do
4590*6236dae4SAndroid Build Coastguard Worker	      test "$linkname" != "$realname" \
4591*6236dae4SAndroid Build Coastguard Worker		&& func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })"
4592*6236dae4SAndroid Build Coastguard Worker	    done
4593*6236dae4SAndroid Build Coastguard Worker	  fi
4594*6236dae4SAndroid Build Coastguard Worker
4595*6236dae4SAndroid Build Coastguard Worker	  # Do each command in the postinstall commands.
4596*6236dae4SAndroid Build Coastguard Worker	  lib=$destdir/$realname
4597*6236dae4SAndroid Build Coastguard Worker	  func_execute_cmds "$postinstall_cmds" 'exit $?'
4598*6236dae4SAndroid Build Coastguard Worker	fi
4599*6236dae4SAndroid Build Coastguard Worker
4600*6236dae4SAndroid Build Coastguard Worker	# Install the pseudo-library for information purposes.
4601*6236dae4SAndroid Build Coastguard Worker	func_basename "$file"
4602*6236dae4SAndroid Build Coastguard Worker	name=$func_basename_result
4603*6236dae4SAndroid Build Coastguard Worker	instname=$dir/${name}i
4604*6236dae4SAndroid Build Coastguard Worker	func_show_eval "$install_prog $instname $destdir/$name" 'exit $?'
4605*6236dae4SAndroid Build Coastguard Worker
4606*6236dae4SAndroid Build Coastguard Worker	# Maybe install the static library, too.
4607*6236dae4SAndroid Build Coastguard Worker	test -n "$old_library" && func_append staticlibs " $dir/$old_library"
4608*6236dae4SAndroid Build Coastguard Worker	;;
4609*6236dae4SAndroid Build Coastguard Worker
4610*6236dae4SAndroid Build Coastguard Worker      *.lo)
4611*6236dae4SAndroid Build Coastguard Worker	# Install (i.e. copy) a libtool object.
4612*6236dae4SAndroid Build Coastguard Worker
4613*6236dae4SAndroid Build Coastguard Worker	# Figure out destination file name, if it wasn't already specified.
4614*6236dae4SAndroid Build Coastguard Worker	if test -n "$destname"; then
4615*6236dae4SAndroid Build Coastguard Worker	  destfile=$destdir/$destname
4616*6236dae4SAndroid Build Coastguard Worker	else
4617*6236dae4SAndroid Build Coastguard Worker	  func_basename "$file"
4618*6236dae4SAndroid Build Coastguard Worker	  destfile=$func_basename_result
4619*6236dae4SAndroid Build Coastguard Worker	  destfile=$destdir/$destfile
4620*6236dae4SAndroid Build Coastguard Worker	fi
4621*6236dae4SAndroid Build Coastguard Worker
4622*6236dae4SAndroid Build Coastguard Worker	# Deduce the name of the destination old-style object file.
4623*6236dae4SAndroid Build Coastguard Worker	case $destfile in
4624*6236dae4SAndroid Build Coastguard Worker	*.lo)
4625*6236dae4SAndroid Build Coastguard Worker	  func_lo2o "$destfile"
4626*6236dae4SAndroid Build Coastguard Worker	  staticdest=$func_lo2o_result
4627*6236dae4SAndroid Build Coastguard Worker	  ;;
4628*6236dae4SAndroid Build Coastguard Worker	*.$objext)
4629*6236dae4SAndroid Build Coastguard Worker	  staticdest=$destfile
4630*6236dae4SAndroid Build Coastguard Worker	  destfile=
4631*6236dae4SAndroid Build Coastguard Worker	  ;;
4632*6236dae4SAndroid Build Coastguard Worker	*)
4633*6236dae4SAndroid Build Coastguard Worker	  func_fatal_help "cannot copy a libtool object to '$destfile'"
4634*6236dae4SAndroid Build Coastguard Worker	  ;;
4635*6236dae4SAndroid Build Coastguard Worker	esac
4636*6236dae4SAndroid Build Coastguard Worker
4637*6236dae4SAndroid Build Coastguard Worker	# Install the libtool object if requested.
4638*6236dae4SAndroid Build Coastguard Worker	test -n "$destfile" && \
4639*6236dae4SAndroid Build Coastguard Worker	  func_show_eval "$install_prog $file $destfile" 'exit $?'
4640*6236dae4SAndroid Build Coastguard Worker
4641*6236dae4SAndroid Build Coastguard Worker	# Install the old object if enabled.
4642*6236dae4SAndroid Build Coastguard Worker	if test yes = "$build_old_libs"; then
4643*6236dae4SAndroid Build Coastguard Worker	  # Deduce the name of the old-style object file.
4644*6236dae4SAndroid Build Coastguard Worker	  func_lo2o "$file"
4645*6236dae4SAndroid Build Coastguard Worker	  staticobj=$func_lo2o_result
4646*6236dae4SAndroid Build Coastguard Worker	  func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?'
4647*6236dae4SAndroid Build Coastguard Worker	fi
4648*6236dae4SAndroid Build Coastguard Worker	exit $EXIT_SUCCESS
4649*6236dae4SAndroid Build Coastguard Worker	;;
4650*6236dae4SAndroid Build Coastguard Worker
4651*6236dae4SAndroid Build Coastguard Worker      *)
4652*6236dae4SAndroid Build Coastguard Worker	# Figure out destination file name, if it wasn't already specified.
4653*6236dae4SAndroid Build Coastguard Worker	if test -n "$destname"; then
4654*6236dae4SAndroid Build Coastguard Worker	  destfile=$destdir/$destname
4655*6236dae4SAndroid Build Coastguard Worker	else
4656*6236dae4SAndroid Build Coastguard Worker	  func_basename "$file"
4657*6236dae4SAndroid Build Coastguard Worker	  destfile=$func_basename_result
4658*6236dae4SAndroid Build Coastguard Worker	  destfile=$destdir/$destfile
4659*6236dae4SAndroid Build Coastguard Worker	fi
4660*6236dae4SAndroid Build Coastguard Worker
4661*6236dae4SAndroid Build Coastguard Worker	# If the file is missing, and there is a .exe on the end, strip it
4662*6236dae4SAndroid Build Coastguard Worker	# because it is most likely a libtool script we actually want to
4663*6236dae4SAndroid Build Coastguard Worker	# install
4664*6236dae4SAndroid Build Coastguard Worker	stripped_ext=
4665*6236dae4SAndroid Build Coastguard Worker	case $file in
4666*6236dae4SAndroid Build Coastguard Worker	  *.exe)
4667*6236dae4SAndroid Build Coastguard Worker	    if test ! -f "$file"; then
4668*6236dae4SAndroid Build Coastguard Worker	      func_stripname '' '.exe' "$file"
4669*6236dae4SAndroid Build Coastguard Worker	      file=$func_stripname_result
4670*6236dae4SAndroid Build Coastguard Worker	      stripped_ext=.exe
4671*6236dae4SAndroid Build Coastguard Worker	    fi
4672*6236dae4SAndroid Build Coastguard Worker	    ;;
4673*6236dae4SAndroid Build Coastguard Worker	esac
4674*6236dae4SAndroid Build Coastguard Worker
4675*6236dae4SAndroid Build Coastguard Worker	# Do a test to see if this is really a libtool program.
4676*6236dae4SAndroid Build Coastguard Worker	case $host in
4677*6236dae4SAndroid Build Coastguard Worker	*cygwin* | *mingw*)
4678*6236dae4SAndroid Build Coastguard Worker	    if func_ltwrapper_executable_p "$file"; then
4679*6236dae4SAndroid Build Coastguard Worker	      func_ltwrapper_scriptname "$file"
4680*6236dae4SAndroid Build Coastguard Worker	      wrapper=$func_ltwrapper_scriptname_result
4681*6236dae4SAndroid Build Coastguard Worker	    else
4682*6236dae4SAndroid Build Coastguard Worker	      func_stripname '' '.exe' "$file"
4683*6236dae4SAndroid Build Coastguard Worker	      wrapper=$func_stripname_result
4684*6236dae4SAndroid Build Coastguard Worker	    fi
4685*6236dae4SAndroid Build Coastguard Worker	    ;;
4686*6236dae4SAndroid Build Coastguard Worker	*)
4687*6236dae4SAndroid Build Coastguard Worker	    wrapper=$file
4688*6236dae4SAndroid Build Coastguard Worker	    ;;
4689*6236dae4SAndroid Build Coastguard Worker	esac
4690*6236dae4SAndroid Build Coastguard Worker	if func_ltwrapper_script_p "$wrapper"; then
4691*6236dae4SAndroid Build Coastguard Worker	  notinst_deplibs=
4692*6236dae4SAndroid Build Coastguard Worker	  relink_command=
4693*6236dae4SAndroid Build Coastguard Worker
4694*6236dae4SAndroid Build Coastguard Worker	  func_source "$wrapper"
4695*6236dae4SAndroid Build Coastguard Worker
4696*6236dae4SAndroid Build Coastguard Worker	  # Check the variables that should have been set.
4697*6236dae4SAndroid Build Coastguard Worker	  test -z "$generated_by_libtool_version" && \
4698*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "invalid libtool wrapper script '$wrapper'"
4699*6236dae4SAndroid Build Coastguard Worker
4700*6236dae4SAndroid Build Coastguard Worker	  finalize=:
4701*6236dae4SAndroid Build Coastguard Worker	  for lib in $notinst_deplibs; do
4702*6236dae4SAndroid Build Coastguard Worker	    # Check to see that each library is installed.
4703*6236dae4SAndroid Build Coastguard Worker	    libdir=
4704*6236dae4SAndroid Build Coastguard Worker	    if test -f "$lib"; then
4705*6236dae4SAndroid Build Coastguard Worker	      func_source "$lib"
4706*6236dae4SAndroid Build Coastguard Worker	    fi
4707*6236dae4SAndroid Build Coastguard Worker	    libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'`
4708*6236dae4SAndroid Build Coastguard Worker	    if test -n "$libdir" && test ! -f "$libfile"; then
4709*6236dae4SAndroid Build Coastguard Worker	      func_warning "'$lib' has not been installed in '$libdir'"
4710*6236dae4SAndroid Build Coastguard Worker	      finalize=false
4711*6236dae4SAndroid Build Coastguard Worker	    fi
4712*6236dae4SAndroid Build Coastguard Worker	  done
4713*6236dae4SAndroid Build Coastguard Worker
4714*6236dae4SAndroid Build Coastguard Worker	  relink_command=
4715*6236dae4SAndroid Build Coastguard Worker	  func_source "$wrapper"
4716*6236dae4SAndroid Build Coastguard Worker
4717*6236dae4SAndroid Build Coastguard Worker	  outputname=
4718*6236dae4SAndroid Build Coastguard Worker	  if test no = "$fast_install" && test -n "$relink_command"; then
4719*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || {
4720*6236dae4SAndroid Build Coastguard Worker	      if $finalize; then
4721*6236dae4SAndroid Build Coastguard Worker	        tmpdir=`func_mktempdir`
4722*6236dae4SAndroid Build Coastguard Worker		func_basename "$file$stripped_ext"
4723*6236dae4SAndroid Build Coastguard Worker		file=$func_basename_result
4724*6236dae4SAndroid Build Coastguard Worker	        outputname=$tmpdir/$file
4725*6236dae4SAndroid Build Coastguard Worker	        # Replace the output file specification.
4726*6236dae4SAndroid Build Coastguard Worker	        relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'`
4727*6236dae4SAndroid Build Coastguard Worker
4728*6236dae4SAndroid Build Coastguard Worker	        $opt_quiet || {
4729*6236dae4SAndroid Build Coastguard Worker	          func_quote_arg expand,pretty "$relink_command"
4730*6236dae4SAndroid Build Coastguard Worker		  eval "func_echo $func_quote_arg_result"
4731*6236dae4SAndroid Build Coastguard Worker	        }
4732*6236dae4SAndroid Build Coastguard Worker	        if eval "$relink_command"; then :
4733*6236dae4SAndroid Build Coastguard Worker	          else
4734*6236dae4SAndroid Build Coastguard Worker		  func_error "error: relink '$file' with the above command before installing it"
4735*6236dae4SAndroid Build Coastguard Worker		  $opt_dry_run || ${RM}r "$tmpdir"
4736*6236dae4SAndroid Build Coastguard Worker		  continue
4737*6236dae4SAndroid Build Coastguard Worker	        fi
4738*6236dae4SAndroid Build Coastguard Worker	        file=$outputname
4739*6236dae4SAndroid Build Coastguard Worker	      else
4740*6236dae4SAndroid Build Coastguard Worker	        func_warning "cannot relink '$file'"
4741*6236dae4SAndroid Build Coastguard Worker	      fi
4742*6236dae4SAndroid Build Coastguard Worker	    }
4743*6236dae4SAndroid Build Coastguard Worker	  else
4744*6236dae4SAndroid Build Coastguard Worker	    # Install the binary that we compiled earlier.
4745*6236dae4SAndroid Build Coastguard Worker	    file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"`
4746*6236dae4SAndroid Build Coastguard Worker	  fi
4747*6236dae4SAndroid Build Coastguard Worker	fi
4748*6236dae4SAndroid Build Coastguard Worker
4749*6236dae4SAndroid Build Coastguard Worker	# remove .exe since cygwin /usr/bin/install will append another
4750*6236dae4SAndroid Build Coastguard Worker	# one anyway
4751*6236dae4SAndroid Build Coastguard Worker	case $install_prog,$host in
4752*6236dae4SAndroid Build Coastguard Worker	*/usr/bin/install*,*cygwin*)
4753*6236dae4SAndroid Build Coastguard Worker	  case $file:$destfile in
4754*6236dae4SAndroid Build Coastguard Worker	  *.exe:*.exe)
4755*6236dae4SAndroid Build Coastguard Worker	    # this is ok
4756*6236dae4SAndroid Build Coastguard Worker	    ;;
4757*6236dae4SAndroid Build Coastguard Worker	  *.exe:*)
4758*6236dae4SAndroid Build Coastguard Worker	    destfile=$destfile.exe
4759*6236dae4SAndroid Build Coastguard Worker	    ;;
4760*6236dae4SAndroid Build Coastguard Worker	  *:*.exe)
4761*6236dae4SAndroid Build Coastguard Worker	    func_stripname '' '.exe' "$destfile"
4762*6236dae4SAndroid Build Coastguard Worker	    destfile=$func_stripname_result
4763*6236dae4SAndroid Build Coastguard Worker	    ;;
4764*6236dae4SAndroid Build Coastguard Worker	  esac
4765*6236dae4SAndroid Build Coastguard Worker	  ;;
4766*6236dae4SAndroid Build Coastguard Worker	esac
4767*6236dae4SAndroid Build Coastguard Worker	func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?'
4768*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || if test -n "$outputname"; then
4769*6236dae4SAndroid Build Coastguard Worker	  ${RM}r "$tmpdir"
4770*6236dae4SAndroid Build Coastguard Worker	fi
4771*6236dae4SAndroid Build Coastguard Worker	;;
4772*6236dae4SAndroid Build Coastguard Worker      esac
4773*6236dae4SAndroid Build Coastguard Worker    done
4774*6236dae4SAndroid Build Coastguard Worker
4775*6236dae4SAndroid Build Coastguard Worker    for file in $staticlibs; do
4776*6236dae4SAndroid Build Coastguard Worker      func_basename "$file"
4777*6236dae4SAndroid Build Coastguard Worker      name=$func_basename_result
4778*6236dae4SAndroid Build Coastguard Worker
4779*6236dae4SAndroid Build Coastguard Worker      # Set up the ranlib parameters.
4780*6236dae4SAndroid Build Coastguard Worker      oldlib=$destdir/$name
4781*6236dae4SAndroid Build Coastguard Worker      func_to_tool_file "$oldlib" func_convert_file_msys_to_w32
4782*6236dae4SAndroid Build Coastguard Worker      tool_oldlib=$func_to_tool_file_result
4783*6236dae4SAndroid Build Coastguard Worker
4784*6236dae4SAndroid Build Coastguard Worker      func_show_eval "$install_prog \$file \$oldlib" 'exit $?'
4785*6236dae4SAndroid Build Coastguard Worker
4786*6236dae4SAndroid Build Coastguard Worker      if test -n "$stripme" && test -n "$old_striplib"; then
4787*6236dae4SAndroid Build Coastguard Worker	func_show_eval "$old_striplib $tool_oldlib" 'exit $?'
4788*6236dae4SAndroid Build Coastguard Worker      fi
4789*6236dae4SAndroid Build Coastguard Worker
4790*6236dae4SAndroid Build Coastguard Worker      # Do each command in the postinstall commands.
4791*6236dae4SAndroid Build Coastguard Worker      func_execute_cmds "$old_postinstall_cmds" 'exit $?'
4792*6236dae4SAndroid Build Coastguard Worker    done
4793*6236dae4SAndroid Build Coastguard Worker
4794*6236dae4SAndroid Build Coastguard Worker    test -n "$future_libdirs" && \
4795*6236dae4SAndroid Build Coastguard Worker      func_warning "remember to run '$progname --finish$future_libdirs'"
4796*6236dae4SAndroid Build Coastguard Worker
4797*6236dae4SAndroid Build Coastguard Worker    if test -n "$current_libdirs"; then
4798*6236dae4SAndroid Build Coastguard Worker      # Maybe just do a dry run.
4799*6236dae4SAndroid Build Coastguard Worker      $opt_dry_run && current_libdirs=" -n$current_libdirs"
4800*6236dae4SAndroid Build Coastguard Worker      exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs'
4801*6236dae4SAndroid Build Coastguard Worker    else
4802*6236dae4SAndroid Build Coastguard Worker      exit $EXIT_SUCCESS
4803*6236dae4SAndroid Build Coastguard Worker    fi
4804*6236dae4SAndroid Build Coastguard Worker}
4805*6236dae4SAndroid Build Coastguard Worker
4806*6236dae4SAndroid Build Coastguard Workertest install = "$opt_mode" && func_mode_install ${1+"$@"}
4807*6236dae4SAndroid Build Coastguard Worker
4808*6236dae4SAndroid Build Coastguard Worker
4809*6236dae4SAndroid Build Coastguard Worker# func_generate_dlsyms outputname originator pic_p
4810*6236dae4SAndroid Build Coastguard Worker# Extract symbols from dlprefiles and create ${outputname}S.o with
4811*6236dae4SAndroid Build Coastguard Worker# a dlpreopen symbol table.
4812*6236dae4SAndroid Build Coastguard Workerfunc_generate_dlsyms ()
4813*6236dae4SAndroid Build Coastguard Worker{
4814*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
4815*6236dae4SAndroid Build Coastguard Worker
4816*6236dae4SAndroid Build Coastguard Worker    my_outputname=$1
4817*6236dae4SAndroid Build Coastguard Worker    my_originator=$2
4818*6236dae4SAndroid Build Coastguard Worker    my_pic_p=${3-false}
4819*6236dae4SAndroid Build Coastguard Worker    my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'`
4820*6236dae4SAndroid Build Coastguard Worker    my_dlsyms=
4821*6236dae4SAndroid Build Coastguard Worker
4822*6236dae4SAndroid Build Coastguard Worker    if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
4823*6236dae4SAndroid Build Coastguard Worker      if test -n "$NM" && test -n "$global_symbol_pipe"; then
4824*6236dae4SAndroid Build Coastguard Worker	my_dlsyms=${my_outputname}S.c
4825*6236dae4SAndroid Build Coastguard Worker      else
4826*6236dae4SAndroid Build Coastguard Worker	func_error "not configured to extract global symbols from dlpreopened files"
4827*6236dae4SAndroid Build Coastguard Worker      fi
4828*6236dae4SAndroid Build Coastguard Worker    fi
4829*6236dae4SAndroid Build Coastguard Worker
4830*6236dae4SAndroid Build Coastguard Worker    if test -n "$my_dlsyms"; then
4831*6236dae4SAndroid Build Coastguard Worker      case $my_dlsyms in
4832*6236dae4SAndroid Build Coastguard Worker      "") ;;
4833*6236dae4SAndroid Build Coastguard Worker      *.c)
4834*6236dae4SAndroid Build Coastguard Worker	# Discover the nlist of each of the dlfiles.
4835*6236dae4SAndroid Build Coastguard Worker	nlist=$output_objdir/$my_outputname.nm
4836*6236dae4SAndroid Build Coastguard Worker
4837*6236dae4SAndroid Build Coastguard Worker	func_show_eval "$RM $nlist ${nlist}S ${nlist}T"
4838*6236dae4SAndroid Build Coastguard Worker
4839*6236dae4SAndroid Build Coastguard Worker	# Parse the name list into a source file.
4840*6236dae4SAndroid Build Coastguard Worker	func_verbose "creating $output_objdir/$my_dlsyms"
4841*6236dae4SAndroid Build Coastguard Worker
4842*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\
4843*6236dae4SAndroid Build Coastguard Worker/* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */
4844*6236dae4SAndroid Build Coastguard Worker/* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */
4845*6236dae4SAndroid Build Coastguard Worker
4846*6236dae4SAndroid Build Coastguard Worker#ifdef __cplusplus
4847*6236dae4SAndroid Build Coastguard Workerextern \"C\" {
4848*6236dae4SAndroid Build Coastguard Worker#endif
4849*6236dae4SAndroid Build Coastguard Worker
4850*6236dae4SAndroid Build Coastguard Worker#if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4))
4851*6236dae4SAndroid Build Coastguard Worker#pragma GCC diagnostic ignored \"-Wstrict-prototypes\"
4852*6236dae4SAndroid Build Coastguard Worker#endif
4853*6236dae4SAndroid Build Coastguard Worker
4854*6236dae4SAndroid Build Coastguard Worker/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests.  */
4855*6236dae4SAndroid Build Coastguard Worker#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
4856*6236dae4SAndroid Build Coastguard Worker/* DATA imports from DLLs on WIN32 can't be const, because runtime
4857*6236dae4SAndroid Build Coastguard Worker   relocations are performed -- see ld's documentation on pseudo-relocs.  */
4858*6236dae4SAndroid Build Coastguard Worker# define LT_DLSYM_CONST
4859*6236dae4SAndroid Build Coastguard Worker#elif defined __osf__
4860*6236dae4SAndroid Build Coastguard Worker/* This system does not cope well with relocations in const data.  */
4861*6236dae4SAndroid Build Coastguard Worker# define LT_DLSYM_CONST
4862*6236dae4SAndroid Build Coastguard Worker#else
4863*6236dae4SAndroid Build Coastguard Worker# define LT_DLSYM_CONST const
4864*6236dae4SAndroid Build Coastguard Worker#endif
4865*6236dae4SAndroid Build Coastguard Worker
4866*6236dae4SAndroid Build Coastguard Worker#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
4867*6236dae4SAndroid Build Coastguard Worker
4868*6236dae4SAndroid Build Coastguard Worker/* External symbol declarations for the compiler. */\
4869*6236dae4SAndroid Build Coastguard Worker"
4870*6236dae4SAndroid Build Coastguard Worker
4871*6236dae4SAndroid Build Coastguard Worker	if test yes = "$dlself"; then
4872*6236dae4SAndroid Build Coastguard Worker	  func_verbose "generating symbol list for '$output'"
4873*6236dae4SAndroid Build Coastguard Worker
4874*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist"
4875*6236dae4SAndroid Build Coastguard Worker
4876*6236dae4SAndroid Build Coastguard Worker	  # Add our own program objects to the symbol list.
4877*6236dae4SAndroid Build Coastguard Worker	  progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP`
4878*6236dae4SAndroid Build Coastguard Worker	  for progfile in $progfiles; do
4879*6236dae4SAndroid Build Coastguard Worker	    func_to_tool_file "$progfile" func_convert_file_msys_to_w32
4880*6236dae4SAndroid Build Coastguard Worker	    func_verbose "extracting global C symbols from '$func_to_tool_file_result'"
4881*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'"
4882*6236dae4SAndroid Build Coastguard Worker	  done
4883*6236dae4SAndroid Build Coastguard Worker
4884*6236dae4SAndroid Build Coastguard Worker	  if test -n "$exclude_expsyms"; then
4885*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || {
4886*6236dae4SAndroid Build Coastguard Worker	      eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T'
4887*6236dae4SAndroid Build Coastguard Worker	      eval '$MV "$nlist"T "$nlist"'
4888*6236dae4SAndroid Build Coastguard Worker	    }
4889*6236dae4SAndroid Build Coastguard Worker	  fi
4890*6236dae4SAndroid Build Coastguard Worker
4891*6236dae4SAndroid Build Coastguard Worker	  if test -n "$export_symbols_regex"; then
4892*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || {
4893*6236dae4SAndroid Build Coastguard Worker	      eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T'
4894*6236dae4SAndroid Build Coastguard Worker	      eval '$MV "$nlist"T "$nlist"'
4895*6236dae4SAndroid Build Coastguard Worker	    }
4896*6236dae4SAndroid Build Coastguard Worker	  fi
4897*6236dae4SAndroid Build Coastguard Worker
4898*6236dae4SAndroid Build Coastguard Worker	  # Prepare the list of exported symbols
4899*6236dae4SAndroid Build Coastguard Worker	  if test -z "$export_symbols"; then
4900*6236dae4SAndroid Build Coastguard Worker	    export_symbols=$output_objdir/$outputname.exp
4901*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || {
4902*6236dae4SAndroid Build Coastguard Worker	      $RM $export_symbols
4903*6236dae4SAndroid Build Coastguard Worker	      eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
4904*6236dae4SAndroid Build Coastguard Worker	      case $host in
4905*6236dae4SAndroid Build Coastguard Worker	      *cygwin* | *mingw* | *cegcc* )
4906*6236dae4SAndroid Build Coastguard Worker                eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
4907*6236dae4SAndroid Build Coastguard Worker                eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"'
4908*6236dae4SAndroid Build Coastguard Worker	        ;;
4909*6236dae4SAndroid Build Coastguard Worker	      esac
4910*6236dae4SAndroid Build Coastguard Worker	    }
4911*6236dae4SAndroid Build Coastguard Worker	  else
4912*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || {
4913*6236dae4SAndroid Build Coastguard Worker	      eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
4914*6236dae4SAndroid Build Coastguard Worker	      eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T'
4915*6236dae4SAndroid Build Coastguard Worker	      eval '$MV "$nlist"T "$nlist"'
4916*6236dae4SAndroid Build Coastguard Worker	      case $host in
4917*6236dae4SAndroid Build Coastguard Worker	        *cygwin* | *mingw* | *cegcc* )
4918*6236dae4SAndroid Build Coastguard Worker	          eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
4919*6236dae4SAndroid Build Coastguard Worker	          eval 'cat "$nlist" >> "$output_objdir/$outputname.def"'
4920*6236dae4SAndroid Build Coastguard Worker	          ;;
4921*6236dae4SAndroid Build Coastguard Worker	      esac
4922*6236dae4SAndroid Build Coastguard Worker	    }
4923*6236dae4SAndroid Build Coastguard Worker	  fi
4924*6236dae4SAndroid Build Coastguard Worker	fi
4925*6236dae4SAndroid Build Coastguard Worker
4926*6236dae4SAndroid Build Coastguard Worker	for dlprefile in $dlprefiles; do
4927*6236dae4SAndroid Build Coastguard Worker	  func_verbose "extracting global C symbols from '$dlprefile'"
4928*6236dae4SAndroid Build Coastguard Worker	  func_basename "$dlprefile"
4929*6236dae4SAndroid Build Coastguard Worker	  name=$func_basename_result
4930*6236dae4SAndroid Build Coastguard Worker          case $host in
4931*6236dae4SAndroid Build Coastguard Worker	    *cygwin* | *mingw* | *cegcc* )
4932*6236dae4SAndroid Build Coastguard Worker	      # if an import library, we need to obtain dlname
4933*6236dae4SAndroid Build Coastguard Worker	      if func_win32_import_lib_p "$dlprefile"; then
4934*6236dae4SAndroid Build Coastguard Worker	        func_tr_sh "$dlprefile"
4935*6236dae4SAndroid Build Coastguard Worker	        eval "curr_lafile=\$libfile_$func_tr_sh_result"
4936*6236dae4SAndroid Build Coastguard Worker	        dlprefile_dlbasename=
4937*6236dae4SAndroid Build Coastguard Worker	        if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then
4938*6236dae4SAndroid Build Coastguard Worker	          # Use subshell, to avoid clobbering current variable values
4939*6236dae4SAndroid Build Coastguard Worker	          dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"`
4940*6236dae4SAndroid Build Coastguard Worker	          if test -n "$dlprefile_dlname"; then
4941*6236dae4SAndroid Build Coastguard Worker	            func_basename "$dlprefile_dlname"
4942*6236dae4SAndroid Build Coastguard Worker	            dlprefile_dlbasename=$func_basename_result
4943*6236dae4SAndroid Build Coastguard Worker	          else
4944*6236dae4SAndroid Build Coastguard Worker	            # no lafile. user explicitly requested -dlpreopen <import library>.
4945*6236dae4SAndroid Build Coastguard Worker	            $sharedlib_from_linklib_cmd "$dlprefile"
4946*6236dae4SAndroid Build Coastguard Worker	            dlprefile_dlbasename=$sharedlib_from_linklib_result
4947*6236dae4SAndroid Build Coastguard Worker	          fi
4948*6236dae4SAndroid Build Coastguard Worker	        fi
4949*6236dae4SAndroid Build Coastguard Worker	        $opt_dry_run || {
4950*6236dae4SAndroid Build Coastguard Worker	          if test -n "$dlprefile_dlbasename"; then
4951*6236dae4SAndroid Build Coastguard Worker	            eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"'
4952*6236dae4SAndroid Build Coastguard Worker	          else
4953*6236dae4SAndroid Build Coastguard Worker	            func_warning "Could not compute DLL name from $name"
4954*6236dae4SAndroid Build Coastguard Worker	            eval '$ECHO ": $name " >> "$nlist"'
4955*6236dae4SAndroid Build Coastguard Worker	          fi
4956*6236dae4SAndroid Build Coastguard Worker	          func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32
4957*6236dae4SAndroid Build Coastguard Worker	          eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe |
4958*6236dae4SAndroid Build Coastguard Worker	            $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'"
4959*6236dae4SAndroid Build Coastguard Worker	        }
4960*6236dae4SAndroid Build Coastguard Worker	      else # not an import lib
4961*6236dae4SAndroid Build Coastguard Worker	        $opt_dry_run || {
4962*6236dae4SAndroid Build Coastguard Worker	          eval '$ECHO ": $name " >> "$nlist"'
4963*6236dae4SAndroid Build Coastguard Worker	          func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32
4964*6236dae4SAndroid Build Coastguard Worker	          eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'"
4965*6236dae4SAndroid Build Coastguard Worker	        }
4966*6236dae4SAndroid Build Coastguard Worker	      fi
4967*6236dae4SAndroid Build Coastguard Worker	    ;;
4968*6236dae4SAndroid Build Coastguard Worker	    *)
4969*6236dae4SAndroid Build Coastguard Worker	      $opt_dry_run || {
4970*6236dae4SAndroid Build Coastguard Worker	        eval '$ECHO ": $name " >> "$nlist"'
4971*6236dae4SAndroid Build Coastguard Worker	        func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32
4972*6236dae4SAndroid Build Coastguard Worker	        eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'"
4973*6236dae4SAndroid Build Coastguard Worker	      }
4974*6236dae4SAndroid Build Coastguard Worker	    ;;
4975*6236dae4SAndroid Build Coastguard Worker          esac
4976*6236dae4SAndroid Build Coastguard Worker	done
4977*6236dae4SAndroid Build Coastguard Worker
4978*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || {
4979*6236dae4SAndroid Build Coastguard Worker	  # Make sure we have at least an empty file.
4980*6236dae4SAndroid Build Coastguard Worker	  test -f "$nlist" || : > "$nlist"
4981*6236dae4SAndroid Build Coastguard Worker
4982*6236dae4SAndroid Build Coastguard Worker	  if test -n "$exclude_expsyms"; then
4983*6236dae4SAndroid Build Coastguard Worker	    $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T
4984*6236dae4SAndroid Build Coastguard Worker	    $MV "$nlist"T "$nlist"
4985*6236dae4SAndroid Build Coastguard Worker	  fi
4986*6236dae4SAndroid Build Coastguard Worker
4987*6236dae4SAndroid Build Coastguard Worker	  # Try sorting and uniquifying the output.
4988*6236dae4SAndroid Build Coastguard Worker	  if $GREP -v "^: " < "$nlist" |
4989*6236dae4SAndroid Build Coastguard Worker	      if sort -k 3 </dev/null >/dev/null 2>&1; then
4990*6236dae4SAndroid Build Coastguard Worker		sort -k 3
4991*6236dae4SAndroid Build Coastguard Worker	      else
4992*6236dae4SAndroid Build Coastguard Worker		sort +2
4993*6236dae4SAndroid Build Coastguard Worker	      fi |
4994*6236dae4SAndroid Build Coastguard Worker	      uniq > "$nlist"S; then
4995*6236dae4SAndroid Build Coastguard Worker	    :
4996*6236dae4SAndroid Build Coastguard Worker	  else
4997*6236dae4SAndroid Build Coastguard Worker	    $GREP -v "^: " < "$nlist" > "$nlist"S
4998*6236dae4SAndroid Build Coastguard Worker	  fi
4999*6236dae4SAndroid Build Coastguard Worker
5000*6236dae4SAndroid Build Coastguard Worker	  if test -f "$nlist"S; then
5001*6236dae4SAndroid Build Coastguard Worker	    eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"'
5002*6236dae4SAndroid Build Coastguard Worker	  else
5003*6236dae4SAndroid Build Coastguard Worker	    echo '/* NONE */' >> "$output_objdir/$my_dlsyms"
5004*6236dae4SAndroid Build Coastguard Worker	  fi
5005*6236dae4SAndroid Build Coastguard Worker
5006*6236dae4SAndroid Build Coastguard Worker	  func_show_eval '$RM "${nlist}I"'
5007*6236dae4SAndroid Build Coastguard Worker	  if test -n "$global_symbol_to_import"; then
5008*6236dae4SAndroid Build Coastguard Worker	    eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I'
5009*6236dae4SAndroid Build Coastguard Worker	  fi
5010*6236dae4SAndroid Build Coastguard Worker
5011*6236dae4SAndroid Build Coastguard Worker	  echo >> "$output_objdir/$my_dlsyms" "\
5012*6236dae4SAndroid Build Coastguard Worker
5013*6236dae4SAndroid Build Coastguard Worker/* The mapping between symbol names and symbols.  */
5014*6236dae4SAndroid Build Coastguard Workertypedef struct {
5015*6236dae4SAndroid Build Coastguard Worker  const char *name;
5016*6236dae4SAndroid Build Coastguard Worker  void *address;
5017*6236dae4SAndroid Build Coastguard Worker} lt_dlsymlist;
5018*6236dae4SAndroid Build Coastguard Workerextern LT_DLSYM_CONST lt_dlsymlist
5019*6236dae4SAndroid Build Coastguard Workerlt_${my_prefix}_LTX_preloaded_symbols[];\
5020*6236dae4SAndroid Build Coastguard Worker"
5021*6236dae4SAndroid Build Coastguard Worker
5022*6236dae4SAndroid Build Coastguard Worker	  if test -s "$nlist"I; then
5023*6236dae4SAndroid Build Coastguard Worker	    echo >> "$output_objdir/$my_dlsyms" "\
5024*6236dae4SAndroid Build Coastguard Workerstatic void lt_syminit(void)
5025*6236dae4SAndroid Build Coastguard Worker{
5026*6236dae4SAndroid Build Coastguard Worker  LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols;
5027*6236dae4SAndroid Build Coastguard Worker  for (; symbol->name; ++symbol)
5028*6236dae4SAndroid Build Coastguard Worker    {"
5029*6236dae4SAndroid Build Coastguard Worker	    $SED 's/.*/      if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms"
5030*6236dae4SAndroid Build Coastguard Worker	    echo >> "$output_objdir/$my_dlsyms" "\
5031*6236dae4SAndroid Build Coastguard Worker    }
5032*6236dae4SAndroid Build Coastguard Worker}"
5033*6236dae4SAndroid Build Coastguard Worker	  fi
5034*6236dae4SAndroid Build Coastguard Worker	  echo >> "$output_objdir/$my_dlsyms" "\
5035*6236dae4SAndroid Build Coastguard WorkerLT_DLSYM_CONST lt_dlsymlist
5036*6236dae4SAndroid Build Coastguard Workerlt_${my_prefix}_LTX_preloaded_symbols[] =
5037*6236dae4SAndroid Build Coastguard Worker{ {\"$my_originator\", (void *) 0},"
5038*6236dae4SAndroid Build Coastguard Worker
5039*6236dae4SAndroid Build Coastguard Worker	  if test -s "$nlist"I; then
5040*6236dae4SAndroid Build Coastguard Worker	    echo >> "$output_objdir/$my_dlsyms" "\
5041*6236dae4SAndroid Build Coastguard Worker  {\"@INIT@\", (void *) &lt_syminit},"
5042*6236dae4SAndroid Build Coastguard Worker	  fi
5043*6236dae4SAndroid Build Coastguard Worker
5044*6236dae4SAndroid Build Coastguard Worker	  case $need_lib_prefix in
5045*6236dae4SAndroid Build Coastguard Worker	  no)
5046*6236dae4SAndroid Build Coastguard Worker	    eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms"
5047*6236dae4SAndroid Build Coastguard Worker	    ;;
5048*6236dae4SAndroid Build Coastguard Worker	  *)
5049*6236dae4SAndroid Build Coastguard Worker	    eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms"
5050*6236dae4SAndroid Build Coastguard Worker	    ;;
5051*6236dae4SAndroid Build Coastguard Worker	  esac
5052*6236dae4SAndroid Build Coastguard Worker	  echo >> "$output_objdir/$my_dlsyms" "\
5053*6236dae4SAndroid Build Coastguard Worker  {0, (void *) 0}
5054*6236dae4SAndroid Build Coastguard Worker};
5055*6236dae4SAndroid Build Coastguard Worker
5056*6236dae4SAndroid Build Coastguard Worker/* This works around a problem in FreeBSD linker */
5057*6236dae4SAndroid Build Coastguard Worker#ifdef FREEBSD_WORKAROUND
5058*6236dae4SAndroid Build Coastguard Workerstatic const void *lt_preloaded_setup() {
5059*6236dae4SAndroid Build Coastguard Worker  return lt_${my_prefix}_LTX_preloaded_symbols;
5060*6236dae4SAndroid Build Coastguard Worker}
5061*6236dae4SAndroid Build Coastguard Worker#endif
5062*6236dae4SAndroid Build Coastguard Worker
5063*6236dae4SAndroid Build Coastguard Worker#ifdef __cplusplus
5064*6236dae4SAndroid Build Coastguard Worker}
5065*6236dae4SAndroid Build Coastguard Worker#endif\
5066*6236dae4SAndroid Build Coastguard Worker"
5067*6236dae4SAndroid Build Coastguard Worker	} # !$opt_dry_run
5068*6236dae4SAndroid Build Coastguard Worker
5069*6236dae4SAndroid Build Coastguard Worker	pic_flag_for_symtable=
5070*6236dae4SAndroid Build Coastguard Worker	case "$compile_command " in
5071*6236dae4SAndroid Build Coastguard Worker	*" -static "*) ;;
5072*6236dae4SAndroid Build Coastguard Worker	*)
5073*6236dae4SAndroid Build Coastguard Worker	  case $host in
5074*6236dae4SAndroid Build Coastguard Worker	  # compiling the symbol table file with pic_flag works around
5075*6236dae4SAndroid Build Coastguard Worker	  # a FreeBSD bug that causes programs to crash when -lm is
5076*6236dae4SAndroid Build Coastguard Worker	  # linked before any other PIC object.  But we must not use
5077*6236dae4SAndroid Build Coastguard Worker	  # pic_flag when linking with -static.  The problem exists in
5078*6236dae4SAndroid Build Coastguard Worker	  # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1.
5079*6236dae4SAndroid Build Coastguard Worker	  *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*)
5080*6236dae4SAndroid Build Coastguard Worker	    pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;;
5081*6236dae4SAndroid Build Coastguard Worker	  *-*-hpux*)
5082*6236dae4SAndroid Build Coastguard Worker	    pic_flag_for_symtable=" $pic_flag"  ;;
5083*6236dae4SAndroid Build Coastguard Worker	  *)
5084*6236dae4SAndroid Build Coastguard Worker	    $my_pic_p && pic_flag_for_symtable=" $pic_flag"
5085*6236dae4SAndroid Build Coastguard Worker	    ;;
5086*6236dae4SAndroid Build Coastguard Worker	  esac
5087*6236dae4SAndroid Build Coastguard Worker	  ;;
5088*6236dae4SAndroid Build Coastguard Worker	esac
5089*6236dae4SAndroid Build Coastguard Worker	symtab_cflags=
5090*6236dae4SAndroid Build Coastguard Worker	for arg in $LTCFLAGS; do
5091*6236dae4SAndroid Build Coastguard Worker	  case $arg in
5092*6236dae4SAndroid Build Coastguard Worker	  -pie | -fpie | -fPIE) ;;
5093*6236dae4SAndroid Build Coastguard Worker	  *) func_append symtab_cflags " $arg" ;;
5094*6236dae4SAndroid Build Coastguard Worker	  esac
5095*6236dae4SAndroid Build Coastguard Worker	done
5096*6236dae4SAndroid Build Coastguard Worker
5097*6236dae4SAndroid Build Coastguard Worker	# Now compile the dynamic symbol file.
5098*6236dae4SAndroid Build Coastguard Worker	func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?'
5099*6236dae4SAndroid Build Coastguard Worker
5100*6236dae4SAndroid Build Coastguard Worker	# Clean up the generated files.
5101*6236dae4SAndroid Build Coastguard Worker	func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"'
5102*6236dae4SAndroid Build Coastguard Worker
5103*6236dae4SAndroid Build Coastguard Worker	# Transform the symbol file into the correct name.
5104*6236dae4SAndroid Build Coastguard Worker	symfileobj=$output_objdir/${my_outputname}S.$objext
5105*6236dae4SAndroid Build Coastguard Worker	case $host in
5106*6236dae4SAndroid Build Coastguard Worker	*cygwin* | *mingw* | *cegcc* )
5107*6236dae4SAndroid Build Coastguard Worker	  if test -f "$output_objdir/$my_outputname.def"; then
5108*6236dae4SAndroid Build Coastguard Worker	    compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
5109*6236dae4SAndroid Build Coastguard Worker	    finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
5110*6236dae4SAndroid Build Coastguard Worker	  else
5111*6236dae4SAndroid Build Coastguard Worker	    compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"`
5112*6236dae4SAndroid Build Coastguard Worker	    finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"`
5113*6236dae4SAndroid Build Coastguard Worker	  fi
5114*6236dae4SAndroid Build Coastguard Worker	  ;;
5115*6236dae4SAndroid Build Coastguard Worker	*)
5116*6236dae4SAndroid Build Coastguard Worker	  compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"`
5117*6236dae4SAndroid Build Coastguard Worker	  finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"`
5118*6236dae4SAndroid Build Coastguard Worker	  ;;
5119*6236dae4SAndroid Build Coastguard Worker	esac
5120*6236dae4SAndroid Build Coastguard Worker	;;
5121*6236dae4SAndroid Build Coastguard Worker      *)
5122*6236dae4SAndroid Build Coastguard Worker	func_fatal_error "unknown suffix for '$my_dlsyms'"
5123*6236dae4SAndroid Build Coastguard Worker	;;
5124*6236dae4SAndroid Build Coastguard Worker      esac
5125*6236dae4SAndroid Build Coastguard Worker    else
5126*6236dae4SAndroid Build Coastguard Worker      # We keep going just in case the user didn't refer to
5127*6236dae4SAndroid Build Coastguard Worker      # lt_preloaded_symbols.  The linker will fail if global_symbol_pipe
5128*6236dae4SAndroid Build Coastguard Worker      # really was required.
5129*6236dae4SAndroid Build Coastguard Worker
5130*6236dae4SAndroid Build Coastguard Worker      # Nullify the symbol file.
5131*6236dae4SAndroid Build Coastguard Worker      compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"`
5132*6236dae4SAndroid Build Coastguard Worker      finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"`
5133*6236dae4SAndroid Build Coastguard Worker    fi
5134*6236dae4SAndroid Build Coastguard Worker}
5135*6236dae4SAndroid Build Coastguard Worker
5136*6236dae4SAndroid Build Coastguard Worker# func_cygming_gnu_implib_p ARG
5137*6236dae4SAndroid Build Coastguard Worker# This predicate returns with zero status (TRUE) if
5138*6236dae4SAndroid Build Coastguard Worker# ARG is a GNU/binutils-style import library. Returns
5139*6236dae4SAndroid Build Coastguard Worker# with nonzero status (FALSE) otherwise.
5140*6236dae4SAndroid Build Coastguard Workerfunc_cygming_gnu_implib_p ()
5141*6236dae4SAndroid Build Coastguard Worker{
5142*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
5143*6236dae4SAndroid Build Coastguard Worker
5144*6236dae4SAndroid Build Coastguard Worker  func_to_tool_file "$1" func_convert_file_msys_to_w32
5145*6236dae4SAndroid Build Coastguard Worker  func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'`
5146*6236dae4SAndroid Build Coastguard Worker  test -n "$func_cygming_gnu_implib_tmp"
5147*6236dae4SAndroid Build Coastguard Worker}
5148*6236dae4SAndroid Build Coastguard Worker
5149*6236dae4SAndroid Build Coastguard Worker# func_cygming_ms_implib_p ARG
5150*6236dae4SAndroid Build Coastguard Worker# This predicate returns with zero status (TRUE) if
5151*6236dae4SAndroid Build Coastguard Worker# ARG is an MS-style import library. Returns
5152*6236dae4SAndroid Build Coastguard Worker# with nonzero status (FALSE) otherwise.
5153*6236dae4SAndroid Build Coastguard Workerfunc_cygming_ms_implib_p ()
5154*6236dae4SAndroid Build Coastguard Worker{
5155*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
5156*6236dae4SAndroid Build Coastguard Worker
5157*6236dae4SAndroid Build Coastguard Worker  func_to_tool_file "$1" func_convert_file_msys_to_w32
5158*6236dae4SAndroid Build Coastguard Worker  func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
5159*6236dae4SAndroid Build Coastguard Worker  test -n "$func_cygming_ms_implib_tmp"
5160*6236dae4SAndroid Build Coastguard Worker}
5161*6236dae4SAndroid Build Coastguard Worker
5162*6236dae4SAndroid Build Coastguard Worker# func_win32_libid arg
5163*6236dae4SAndroid Build Coastguard Worker# return the library type of file 'arg'
5164*6236dae4SAndroid Build Coastguard Worker#
5165*6236dae4SAndroid Build Coastguard Worker# Need a lot of goo to handle *both* DLLs and import libs
5166*6236dae4SAndroid Build Coastguard Worker# Has to be a shell function in order to 'eat' the argument
5167*6236dae4SAndroid Build Coastguard Worker# that is supplied when $file_magic_command is called.
5168*6236dae4SAndroid Build Coastguard Worker# Despite the name, also deal with 64 bit binaries.
5169*6236dae4SAndroid Build Coastguard Workerfunc_win32_libid ()
5170*6236dae4SAndroid Build Coastguard Worker{
5171*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
5172*6236dae4SAndroid Build Coastguard Worker
5173*6236dae4SAndroid Build Coastguard Worker  win32_libid_type=unknown
5174*6236dae4SAndroid Build Coastguard Worker  win32_fileres=`file -L $1 2>/dev/null`
5175*6236dae4SAndroid Build Coastguard Worker  case $win32_fileres in
5176*6236dae4SAndroid Build Coastguard Worker  *ar\ archive\ import\ library*) # definitely import
5177*6236dae4SAndroid Build Coastguard Worker    win32_libid_type="x86 archive import"
5178*6236dae4SAndroid Build Coastguard Worker    ;;
5179*6236dae4SAndroid Build Coastguard Worker  *ar\ archive*) # could be an import, or static
5180*6236dae4SAndroid Build Coastguard Worker    # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD.
5181*6236dae4SAndroid Build Coastguard Worker    if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null |
5182*6236dae4SAndroid Build Coastguard Worker       $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then
5183*6236dae4SAndroid Build Coastguard Worker      case $nm_interface in
5184*6236dae4SAndroid Build Coastguard Worker      "MS dumpbin")
5185*6236dae4SAndroid Build Coastguard Worker	if func_cygming_ms_implib_p "$1" ||
5186*6236dae4SAndroid Build Coastguard Worker	   func_cygming_gnu_implib_p "$1"
5187*6236dae4SAndroid Build Coastguard Worker	then
5188*6236dae4SAndroid Build Coastguard Worker	  win32_nmres=import
5189*6236dae4SAndroid Build Coastguard Worker	else
5190*6236dae4SAndroid Build Coastguard Worker	  win32_nmres=
5191*6236dae4SAndroid Build Coastguard Worker	fi
5192*6236dae4SAndroid Build Coastguard Worker	;;
5193*6236dae4SAndroid Build Coastguard Worker      *)
5194*6236dae4SAndroid Build Coastguard Worker	func_to_tool_file "$1" func_convert_file_msys_to_w32
5195*6236dae4SAndroid Build Coastguard Worker	win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" |
5196*6236dae4SAndroid Build Coastguard Worker	  $SED -n -e '
5197*6236dae4SAndroid Build Coastguard Worker	    1,100{
5198*6236dae4SAndroid Build Coastguard Worker		/ I /{
5199*6236dae4SAndroid Build Coastguard Worker		    s|.*|import|
5200*6236dae4SAndroid Build Coastguard Worker		    p
5201*6236dae4SAndroid Build Coastguard Worker		    q
5202*6236dae4SAndroid Build Coastguard Worker		}
5203*6236dae4SAndroid Build Coastguard Worker	    }'`
5204*6236dae4SAndroid Build Coastguard Worker	;;
5205*6236dae4SAndroid Build Coastguard Worker      esac
5206*6236dae4SAndroid Build Coastguard Worker      case $win32_nmres in
5207*6236dae4SAndroid Build Coastguard Worker      import*)  win32_libid_type="x86 archive import";;
5208*6236dae4SAndroid Build Coastguard Worker      *)        win32_libid_type="x86 archive static";;
5209*6236dae4SAndroid Build Coastguard Worker      esac
5210*6236dae4SAndroid Build Coastguard Worker    fi
5211*6236dae4SAndroid Build Coastguard Worker    ;;
5212*6236dae4SAndroid Build Coastguard Worker  *DLL*)
5213*6236dae4SAndroid Build Coastguard Worker    win32_libid_type="x86 DLL"
5214*6236dae4SAndroid Build Coastguard Worker    ;;
5215*6236dae4SAndroid Build Coastguard Worker  *executable*) # but shell scripts are "executable" too...
5216*6236dae4SAndroid Build Coastguard Worker    case $win32_fileres in
5217*6236dae4SAndroid Build Coastguard Worker    *MS\ Windows\ PE\ Intel*)
5218*6236dae4SAndroid Build Coastguard Worker      win32_libid_type="x86 DLL"
5219*6236dae4SAndroid Build Coastguard Worker      ;;
5220*6236dae4SAndroid Build Coastguard Worker    esac
5221*6236dae4SAndroid Build Coastguard Worker    ;;
5222*6236dae4SAndroid Build Coastguard Worker  esac
5223*6236dae4SAndroid Build Coastguard Worker  $ECHO "$win32_libid_type"
5224*6236dae4SAndroid Build Coastguard Worker}
5225*6236dae4SAndroid Build Coastguard Worker
5226*6236dae4SAndroid Build Coastguard Worker# func_cygming_dll_for_implib ARG
5227*6236dae4SAndroid Build Coastguard Worker#
5228*6236dae4SAndroid Build Coastguard Worker# Platform-specific function to extract the
5229*6236dae4SAndroid Build Coastguard Worker# name of the DLL associated with the specified
5230*6236dae4SAndroid Build Coastguard Worker# import library ARG.
5231*6236dae4SAndroid Build Coastguard Worker# Invoked by eval'ing the libtool variable
5232*6236dae4SAndroid Build Coastguard Worker#    $sharedlib_from_linklib_cmd
5233*6236dae4SAndroid Build Coastguard Worker# Result is available in the variable
5234*6236dae4SAndroid Build Coastguard Worker#    $sharedlib_from_linklib_result
5235*6236dae4SAndroid Build Coastguard Workerfunc_cygming_dll_for_implib ()
5236*6236dae4SAndroid Build Coastguard Worker{
5237*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
5238*6236dae4SAndroid Build Coastguard Worker
5239*6236dae4SAndroid Build Coastguard Worker  sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"`
5240*6236dae4SAndroid Build Coastguard Worker}
5241*6236dae4SAndroid Build Coastguard Worker
5242*6236dae4SAndroid Build Coastguard Worker# func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs
5243*6236dae4SAndroid Build Coastguard Worker#
5244*6236dae4SAndroid Build Coastguard Worker# The is the core of a fallback implementation of a
5245*6236dae4SAndroid Build Coastguard Worker# platform-specific function to extract the name of the
5246*6236dae4SAndroid Build Coastguard Worker# DLL associated with the specified import library LIBNAME.
5247*6236dae4SAndroid Build Coastguard Worker#
5248*6236dae4SAndroid Build Coastguard Worker# SECTION_NAME is either .idata$6 or .idata$7, depending
5249*6236dae4SAndroid Build Coastguard Worker# on the platform and compiler that created the implib.
5250*6236dae4SAndroid Build Coastguard Worker#
5251*6236dae4SAndroid Build Coastguard Worker# Echos the name of the DLL associated with the
5252*6236dae4SAndroid Build Coastguard Worker# specified import library.
5253*6236dae4SAndroid Build Coastguard Workerfunc_cygming_dll_for_implib_fallback_core ()
5254*6236dae4SAndroid Build Coastguard Worker{
5255*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
5256*6236dae4SAndroid Build Coastguard Worker
5257*6236dae4SAndroid Build Coastguard Worker  match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"`
5258*6236dae4SAndroid Build Coastguard Worker  $OBJDUMP -s --section "$1" "$2" 2>/dev/null |
5259*6236dae4SAndroid Build Coastguard Worker    $SED '/^Contents of section '"$match_literal"':/{
5260*6236dae4SAndroid Build Coastguard Worker      # Place marker at beginning of archive member dllname section
5261*6236dae4SAndroid Build Coastguard Worker      s/.*/====MARK====/
5262*6236dae4SAndroid Build Coastguard Worker      p
5263*6236dae4SAndroid Build Coastguard Worker      d
5264*6236dae4SAndroid Build Coastguard Worker    }
5265*6236dae4SAndroid Build Coastguard Worker    # These lines can sometimes be longer than 43 characters, but
5266*6236dae4SAndroid Build Coastguard Worker    # are always uninteresting
5267*6236dae4SAndroid Build Coastguard Worker    /:[	 ]*file format pe[i]\{,1\}-/d
5268*6236dae4SAndroid Build Coastguard Worker    /^In archive [^:]*:/d
5269*6236dae4SAndroid Build Coastguard Worker    # Ensure marker is printed
5270*6236dae4SAndroid Build Coastguard Worker    /^====MARK====/p
5271*6236dae4SAndroid Build Coastguard Worker    # Remove all lines with less than 43 characters
5272*6236dae4SAndroid Build Coastguard Worker    /^.\{43\}/!d
5273*6236dae4SAndroid Build Coastguard Worker    # From remaining lines, remove first 43 characters
5274*6236dae4SAndroid Build Coastguard Worker    s/^.\{43\}//' |
5275*6236dae4SAndroid Build Coastguard Worker    $SED -n '
5276*6236dae4SAndroid Build Coastguard Worker      # Join marker and all lines until next marker into a single line
5277*6236dae4SAndroid Build Coastguard Worker      /^====MARK====/ b para
5278*6236dae4SAndroid Build Coastguard Worker      H
5279*6236dae4SAndroid Build Coastguard Worker      $ b para
5280*6236dae4SAndroid Build Coastguard Worker      b
5281*6236dae4SAndroid Build Coastguard Worker      :para
5282*6236dae4SAndroid Build Coastguard Worker      x
5283*6236dae4SAndroid Build Coastguard Worker      s/\n//g
5284*6236dae4SAndroid Build Coastguard Worker      # Remove the marker
5285*6236dae4SAndroid Build Coastguard Worker      s/^====MARK====//
5286*6236dae4SAndroid Build Coastguard Worker      # Remove trailing dots and whitespace
5287*6236dae4SAndroid Build Coastguard Worker      s/[\. \t]*$//
5288*6236dae4SAndroid Build Coastguard Worker      # Print
5289*6236dae4SAndroid Build Coastguard Worker      /./p' |
5290*6236dae4SAndroid Build Coastguard Worker    # we now have a list, one entry per line, of the stringified
5291*6236dae4SAndroid Build Coastguard Worker    # contents of the appropriate section of all members of the
5292*6236dae4SAndroid Build Coastguard Worker    # archive that possess that section. Heuristic: eliminate
5293*6236dae4SAndroid Build Coastguard Worker    # all those that have a first or second character that is
5294*6236dae4SAndroid Build Coastguard Worker    # a '.' (that is, objdump's representation of an unprintable
5295*6236dae4SAndroid Build Coastguard Worker    # character.) This should work for all archives with less than
5296*6236dae4SAndroid Build Coastguard Worker    # 0x302f exports -- but will fail for DLLs whose name actually
5297*6236dae4SAndroid Build Coastguard Worker    # begins with a literal '.' or a single character followed by
5298*6236dae4SAndroid Build Coastguard Worker    # a '.'.
5299*6236dae4SAndroid Build Coastguard Worker    #
5300*6236dae4SAndroid Build Coastguard Worker    # Of those that remain, print the first one.
5301*6236dae4SAndroid Build Coastguard Worker    $SED -e '/^\./d;/^.\./d;q'
5302*6236dae4SAndroid Build Coastguard Worker}
5303*6236dae4SAndroid Build Coastguard Worker
5304*6236dae4SAndroid Build Coastguard Worker# func_cygming_dll_for_implib_fallback ARG
5305*6236dae4SAndroid Build Coastguard Worker# Platform-specific function to extract the
5306*6236dae4SAndroid Build Coastguard Worker# name of the DLL associated with the specified
5307*6236dae4SAndroid Build Coastguard Worker# import library ARG.
5308*6236dae4SAndroid Build Coastguard Worker#
5309*6236dae4SAndroid Build Coastguard Worker# This fallback implementation is for use when $DLLTOOL
5310*6236dae4SAndroid Build Coastguard Worker# does not support the --identify-strict option.
5311*6236dae4SAndroid Build Coastguard Worker# Invoked by eval'ing the libtool variable
5312*6236dae4SAndroid Build Coastguard Worker#    $sharedlib_from_linklib_cmd
5313*6236dae4SAndroid Build Coastguard Worker# Result is available in the variable
5314*6236dae4SAndroid Build Coastguard Worker#    $sharedlib_from_linklib_result
5315*6236dae4SAndroid Build Coastguard Workerfunc_cygming_dll_for_implib_fallback ()
5316*6236dae4SAndroid Build Coastguard Worker{
5317*6236dae4SAndroid Build Coastguard Worker  $debug_cmd
5318*6236dae4SAndroid Build Coastguard Worker
5319*6236dae4SAndroid Build Coastguard Worker  if func_cygming_gnu_implib_p "$1"; then
5320*6236dae4SAndroid Build Coastguard Worker    # binutils import library
5321*6236dae4SAndroid Build Coastguard Worker    sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"`
5322*6236dae4SAndroid Build Coastguard Worker  elif func_cygming_ms_implib_p "$1"; then
5323*6236dae4SAndroid Build Coastguard Worker    # ms-generated import library
5324*6236dae4SAndroid Build Coastguard Worker    sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"`
5325*6236dae4SAndroid Build Coastguard Worker  else
5326*6236dae4SAndroid Build Coastguard Worker    # unknown
5327*6236dae4SAndroid Build Coastguard Worker    sharedlib_from_linklib_result=
5328*6236dae4SAndroid Build Coastguard Worker  fi
5329*6236dae4SAndroid Build Coastguard Worker}
5330*6236dae4SAndroid Build Coastguard Worker
5331*6236dae4SAndroid Build Coastguard Worker
5332*6236dae4SAndroid Build Coastguard Worker# func_extract_an_archive dir oldlib
5333*6236dae4SAndroid Build Coastguard Workerfunc_extract_an_archive ()
5334*6236dae4SAndroid Build Coastguard Worker{
5335*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
5336*6236dae4SAndroid Build Coastguard Worker
5337*6236dae4SAndroid Build Coastguard Worker    f_ex_an_ar_dir=$1; shift
5338*6236dae4SAndroid Build Coastguard Worker    f_ex_an_ar_oldlib=$1
5339*6236dae4SAndroid Build Coastguard Worker    if test yes = "$lock_old_archive_extraction"; then
5340*6236dae4SAndroid Build Coastguard Worker      lockfile=$f_ex_an_ar_oldlib.lock
5341*6236dae4SAndroid Build Coastguard Worker      until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
5342*6236dae4SAndroid Build Coastguard Worker	func_echo "Waiting for $lockfile to be removed"
5343*6236dae4SAndroid Build Coastguard Worker	sleep 2
5344*6236dae4SAndroid Build Coastguard Worker      done
5345*6236dae4SAndroid Build Coastguard Worker    fi
5346*6236dae4SAndroid Build Coastguard Worker    func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \
5347*6236dae4SAndroid Build Coastguard Worker		   'stat=$?; rm -f "$lockfile"; exit $stat'
5348*6236dae4SAndroid Build Coastguard Worker    if test yes = "$lock_old_archive_extraction"; then
5349*6236dae4SAndroid Build Coastguard Worker      $opt_dry_run || rm -f "$lockfile"
5350*6236dae4SAndroid Build Coastguard Worker    fi
5351*6236dae4SAndroid Build Coastguard Worker    if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
5352*6236dae4SAndroid Build Coastguard Worker     :
5353*6236dae4SAndroid Build Coastguard Worker    else
5354*6236dae4SAndroid Build Coastguard Worker      func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib"
5355*6236dae4SAndroid Build Coastguard Worker    fi
5356*6236dae4SAndroid Build Coastguard Worker}
5357*6236dae4SAndroid Build Coastguard Worker
5358*6236dae4SAndroid Build Coastguard Worker
5359*6236dae4SAndroid Build Coastguard Worker# func_extract_archives gentop oldlib ...
5360*6236dae4SAndroid Build Coastguard Workerfunc_extract_archives ()
5361*6236dae4SAndroid Build Coastguard Worker{
5362*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
5363*6236dae4SAndroid Build Coastguard Worker
5364*6236dae4SAndroid Build Coastguard Worker    my_gentop=$1; shift
5365*6236dae4SAndroid Build Coastguard Worker    my_oldlibs=${1+"$@"}
5366*6236dae4SAndroid Build Coastguard Worker    my_oldobjs=
5367*6236dae4SAndroid Build Coastguard Worker    my_xlib=
5368*6236dae4SAndroid Build Coastguard Worker    my_xabs=
5369*6236dae4SAndroid Build Coastguard Worker    my_xdir=
5370*6236dae4SAndroid Build Coastguard Worker
5371*6236dae4SAndroid Build Coastguard Worker    for my_xlib in $my_oldlibs; do
5372*6236dae4SAndroid Build Coastguard Worker      # Extract the objects.
5373*6236dae4SAndroid Build Coastguard Worker      case $my_xlib in
5374*6236dae4SAndroid Build Coastguard Worker	[\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;;
5375*6236dae4SAndroid Build Coastguard Worker	*) my_xabs=`pwd`"/$my_xlib" ;;
5376*6236dae4SAndroid Build Coastguard Worker      esac
5377*6236dae4SAndroid Build Coastguard Worker      func_basename "$my_xlib"
5378*6236dae4SAndroid Build Coastguard Worker      my_xlib=$func_basename_result
5379*6236dae4SAndroid Build Coastguard Worker      my_xlib_u=$my_xlib
5380*6236dae4SAndroid Build Coastguard Worker      while :; do
5381*6236dae4SAndroid Build Coastguard Worker        case " $extracted_archives " in
5382*6236dae4SAndroid Build Coastguard Worker	*" $my_xlib_u "*)
5383*6236dae4SAndroid Build Coastguard Worker	  func_arith $extracted_serial + 1
5384*6236dae4SAndroid Build Coastguard Worker	  extracted_serial=$func_arith_result
5385*6236dae4SAndroid Build Coastguard Worker	  my_xlib_u=lt$extracted_serial-$my_xlib ;;
5386*6236dae4SAndroid Build Coastguard Worker	*) break ;;
5387*6236dae4SAndroid Build Coastguard Worker	esac
5388*6236dae4SAndroid Build Coastguard Worker      done
5389*6236dae4SAndroid Build Coastguard Worker      extracted_archives="$extracted_archives $my_xlib_u"
5390*6236dae4SAndroid Build Coastguard Worker      my_xdir=$my_gentop/$my_xlib_u
5391*6236dae4SAndroid Build Coastguard Worker
5392*6236dae4SAndroid Build Coastguard Worker      func_mkdir_p "$my_xdir"
5393*6236dae4SAndroid Build Coastguard Worker
5394*6236dae4SAndroid Build Coastguard Worker      case $host in
5395*6236dae4SAndroid Build Coastguard Worker      *-darwin*)
5396*6236dae4SAndroid Build Coastguard Worker	func_verbose "Extracting $my_xabs"
5397*6236dae4SAndroid Build Coastguard Worker	# Do not bother doing anything if just a dry run
5398*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || {
5399*6236dae4SAndroid Build Coastguard Worker	  darwin_orig_dir=`pwd`
5400*6236dae4SAndroid Build Coastguard Worker	  cd $my_xdir || exit $?
5401*6236dae4SAndroid Build Coastguard Worker	  darwin_archive=$my_xabs
5402*6236dae4SAndroid Build Coastguard Worker	  darwin_curdir=`pwd`
5403*6236dae4SAndroid Build Coastguard Worker	  func_basename "$darwin_archive"
5404*6236dae4SAndroid Build Coastguard Worker	  darwin_base_archive=$func_basename_result
5405*6236dae4SAndroid Build Coastguard Worker	  darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true`
5406*6236dae4SAndroid Build Coastguard Worker	  if test -n "$darwin_arches"; then
5407*6236dae4SAndroid Build Coastguard Worker	    darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'`
5408*6236dae4SAndroid Build Coastguard Worker	    darwin_arch=
5409*6236dae4SAndroid Build Coastguard Worker	    func_verbose "$darwin_base_archive has multiple architectures $darwin_arches"
5410*6236dae4SAndroid Build Coastguard Worker	    for darwin_arch in  $darwin_arches; do
5411*6236dae4SAndroid Build Coastguard Worker	      func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch"
5412*6236dae4SAndroid Build Coastguard Worker	      $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" "$darwin_archive"
5413*6236dae4SAndroid Build Coastguard Worker	      cd "unfat-$$/$darwin_base_archive-$darwin_arch"
5414*6236dae4SAndroid Build Coastguard Worker	      func_extract_an_archive "`pwd`" "$darwin_base_archive"
5415*6236dae4SAndroid Build Coastguard Worker	      cd "$darwin_curdir"
5416*6236dae4SAndroid Build Coastguard Worker	      $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive"
5417*6236dae4SAndroid Build Coastguard Worker	    done # $darwin_arches
5418*6236dae4SAndroid Build Coastguard Worker            ## Okay now we've a bunch of thin objects, gotta fatten them up :)
5419*6236dae4SAndroid Build Coastguard Worker	    darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u`
5420*6236dae4SAndroid Build Coastguard Worker	    darwin_file=
5421*6236dae4SAndroid Build Coastguard Worker	    darwin_files=
5422*6236dae4SAndroid Build Coastguard Worker	    for darwin_file in $darwin_filelist; do
5423*6236dae4SAndroid Build Coastguard Worker	      darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP`
5424*6236dae4SAndroid Build Coastguard Worker	      $LIPO -create -output "$darwin_file" $darwin_files
5425*6236dae4SAndroid Build Coastguard Worker	    done # $darwin_filelist
5426*6236dae4SAndroid Build Coastguard Worker	    $RM -rf unfat-$$
5427*6236dae4SAndroid Build Coastguard Worker	    cd "$darwin_orig_dir"
5428*6236dae4SAndroid Build Coastguard Worker	  else
5429*6236dae4SAndroid Build Coastguard Worker	    cd $darwin_orig_dir
5430*6236dae4SAndroid Build Coastguard Worker	    func_extract_an_archive "$my_xdir" "$my_xabs"
5431*6236dae4SAndroid Build Coastguard Worker	  fi # $darwin_arches
5432*6236dae4SAndroid Build Coastguard Worker	} # !$opt_dry_run
5433*6236dae4SAndroid Build Coastguard Worker	;;
5434*6236dae4SAndroid Build Coastguard Worker      *)
5435*6236dae4SAndroid Build Coastguard Worker        func_extract_an_archive "$my_xdir" "$my_xabs"
5436*6236dae4SAndroid Build Coastguard Worker	;;
5437*6236dae4SAndroid Build Coastguard Worker      esac
5438*6236dae4SAndroid Build Coastguard Worker      my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP`
5439*6236dae4SAndroid Build Coastguard Worker    done
5440*6236dae4SAndroid Build Coastguard Worker
5441*6236dae4SAndroid Build Coastguard Worker    func_extract_archives_result=$my_oldobjs
5442*6236dae4SAndroid Build Coastguard Worker}
5443*6236dae4SAndroid Build Coastguard Worker
5444*6236dae4SAndroid Build Coastguard Worker
5445*6236dae4SAndroid Build Coastguard Worker# func_emit_wrapper [arg=no]
5446*6236dae4SAndroid Build Coastguard Worker#
5447*6236dae4SAndroid Build Coastguard Worker# Emit a libtool wrapper script on stdout.
5448*6236dae4SAndroid Build Coastguard Worker# Don't directly open a file because we may want to
5449*6236dae4SAndroid Build Coastguard Worker# incorporate the script contents within a cygwin/mingw
5450*6236dae4SAndroid Build Coastguard Worker# wrapper executable.  Must ONLY be called from within
5451*6236dae4SAndroid Build Coastguard Worker# func_mode_link because it depends on a number of variables
5452*6236dae4SAndroid Build Coastguard Worker# set therein.
5453*6236dae4SAndroid Build Coastguard Worker#
5454*6236dae4SAndroid Build Coastguard Worker# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR
5455*6236dae4SAndroid Build Coastguard Worker# variable will take.  If 'yes', then the emitted script
5456*6236dae4SAndroid Build Coastguard Worker# will assume that the directory where it is stored is
5457*6236dae4SAndroid Build Coastguard Worker# the $objdir directory.  This is a cygwin/mingw-specific
5458*6236dae4SAndroid Build Coastguard Worker# behavior.
5459*6236dae4SAndroid Build Coastguard Workerfunc_emit_wrapper ()
5460*6236dae4SAndroid Build Coastguard Worker{
5461*6236dae4SAndroid Build Coastguard Worker	func_emit_wrapper_arg1=${1-no}
5462*6236dae4SAndroid Build Coastguard Worker
5463*6236dae4SAndroid Build Coastguard Worker	$ECHO "\
5464*6236dae4SAndroid Build Coastguard Worker#! $SHELL
5465*6236dae4SAndroid Build Coastguard Worker
5466*6236dae4SAndroid Build Coastguard Worker# $output - temporary wrapper script for $objdir/$outputname
5467*6236dae4SAndroid Build Coastguard Worker# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
5468*6236dae4SAndroid Build Coastguard Worker#
5469*6236dae4SAndroid Build Coastguard Worker# The $output program cannot be directly executed until all the libtool
5470*6236dae4SAndroid Build Coastguard Worker# libraries that it depends on are installed.
5471*6236dae4SAndroid Build Coastguard Worker#
5472*6236dae4SAndroid Build Coastguard Worker# This wrapper script should never be moved out of the build directory.
5473*6236dae4SAndroid Build Coastguard Worker# If it is, it will not operate correctly.
5474*6236dae4SAndroid Build Coastguard Worker
5475*6236dae4SAndroid Build Coastguard Worker# Sed substitution that helps us do robust quoting.  It backslashifies
5476*6236dae4SAndroid Build Coastguard Worker# metacharacters that are still active within double-quoted strings.
5477*6236dae4SAndroid Build Coastguard Workersed_quote_subst='$sed_quote_subst'
5478*6236dae4SAndroid Build Coastguard Worker
5479*6236dae4SAndroid Build Coastguard Worker# Be Bourne compatible
5480*6236dae4SAndroid Build Coastguard Workerif test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then
5481*6236dae4SAndroid Build Coastguard Worker  emulate sh
5482*6236dae4SAndroid Build Coastguard Worker  NULLCMD=:
5483*6236dae4SAndroid Build Coastguard Worker  # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which
5484*6236dae4SAndroid Build Coastguard Worker  # is contrary to our usage.  Disable this feature.
5485*6236dae4SAndroid Build Coastguard Worker  alias -g '\${1+\"\$@\"}'='\"\$@\"'
5486*6236dae4SAndroid Build Coastguard Worker  setopt NO_GLOB_SUBST
5487*6236dae4SAndroid Build Coastguard Workerelse
5488*6236dae4SAndroid Build Coastguard Worker  case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac
5489*6236dae4SAndroid Build Coastguard Workerfi
5490*6236dae4SAndroid Build Coastguard WorkerBIN_SH=xpg4; export BIN_SH # for Tru64
5491*6236dae4SAndroid Build Coastguard WorkerDUALCASE=1; export DUALCASE # for MKS sh
5492*6236dae4SAndroid Build Coastguard Worker
5493*6236dae4SAndroid Build Coastguard Worker# The HP-UX ksh and POSIX shell print the target directory to stdout
5494*6236dae4SAndroid Build Coastguard Worker# if CDPATH is set.
5495*6236dae4SAndroid Build Coastguard Worker(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
5496*6236dae4SAndroid Build Coastguard Worker
5497*6236dae4SAndroid Build Coastguard Workerrelink_command=\"$relink_command\"
5498*6236dae4SAndroid Build Coastguard Worker
5499*6236dae4SAndroid Build Coastguard Worker# This environment variable determines our operation mode.
5500*6236dae4SAndroid Build Coastguard Workerif test \"\$libtool_install_magic\" = \"$magic\"; then
5501*6236dae4SAndroid Build Coastguard Worker  # install mode needs the following variables:
5502*6236dae4SAndroid Build Coastguard Worker  generated_by_libtool_version='$macro_version'
5503*6236dae4SAndroid Build Coastguard Worker  notinst_deplibs='$notinst_deplibs'
5504*6236dae4SAndroid Build Coastguard Workerelse
5505*6236dae4SAndroid Build Coastguard Worker  # When we are sourced in execute mode, \$file and \$ECHO are already set.
5506*6236dae4SAndroid Build Coastguard Worker  if test \"\$libtool_execute_magic\" != \"$magic\"; then
5507*6236dae4SAndroid Build Coastguard Worker    file=\"\$0\""
5508*6236dae4SAndroid Build Coastguard Worker
5509*6236dae4SAndroid Build Coastguard Worker    func_quote_arg pretty "$ECHO"
5510*6236dae4SAndroid Build Coastguard Worker    qECHO=$func_quote_arg_result
5511*6236dae4SAndroid Build Coastguard Worker    $ECHO "\
5512*6236dae4SAndroid Build Coastguard Worker
5513*6236dae4SAndroid Build Coastguard Worker# A function that is used when there is no print builtin or printf.
5514*6236dae4SAndroid Build Coastguard Workerfunc_fallback_echo ()
5515*6236dae4SAndroid Build Coastguard Worker{
5516*6236dae4SAndroid Build Coastguard Worker  eval 'cat <<_LTECHO_EOF
5517*6236dae4SAndroid Build Coastguard Worker\$1
5518*6236dae4SAndroid Build Coastguard Worker_LTECHO_EOF'
5519*6236dae4SAndroid Build Coastguard Worker}
5520*6236dae4SAndroid Build Coastguard Worker    ECHO=$qECHO
5521*6236dae4SAndroid Build Coastguard Worker  fi
5522*6236dae4SAndroid Build Coastguard Worker
5523*6236dae4SAndroid Build Coastguard Worker# Very basic option parsing. These options are (a) specific to
5524*6236dae4SAndroid Build Coastguard Worker# the libtool wrapper, (b) are identical between the wrapper
5525*6236dae4SAndroid Build Coastguard Worker# /script/ and the wrapper /executable/ that is used only on
5526*6236dae4SAndroid Build Coastguard Worker# windows platforms, and (c) all begin with the string "--lt-"
5527*6236dae4SAndroid Build Coastguard Worker# (application programs are unlikely to have options that match
5528*6236dae4SAndroid Build Coastguard Worker# this pattern).
5529*6236dae4SAndroid Build Coastguard Worker#
5530*6236dae4SAndroid Build Coastguard Worker# There are only two supported options: --lt-debug and
5531*6236dae4SAndroid Build Coastguard Worker# --lt-dump-script. There is, deliberately, no --lt-help.
5532*6236dae4SAndroid Build Coastguard Worker#
5533*6236dae4SAndroid Build Coastguard Worker# The first argument to this parsing function should be the
5534*6236dae4SAndroid Build Coastguard Worker# script's $0 value, followed by "$@".
5535*6236dae4SAndroid Build Coastguard Workerlt_option_debug=
5536*6236dae4SAndroid Build Coastguard Workerfunc_parse_lt_options ()
5537*6236dae4SAndroid Build Coastguard Worker{
5538*6236dae4SAndroid Build Coastguard Worker  lt_script_arg0=\$0
5539*6236dae4SAndroid Build Coastguard Worker  shift
5540*6236dae4SAndroid Build Coastguard Worker  for lt_opt
5541*6236dae4SAndroid Build Coastguard Worker  do
5542*6236dae4SAndroid Build Coastguard Worker    case \"\$lt_opt\" in
5543*6236dae4SAndroid Build Coastguard Worker    --lt-debug) lt_option_debug=1 ;;
5544*6236dae4SAndroid Build Coastguard Worker    --lt-dump-script)
5545*6236dae4SAndroid Build Coastguard Worker        lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\`
5546*6236dae4SAndroid Build Coastguard Worker        test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=.
5547*6236dae4SAndroid Build Coastguard Worker        lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\`
5548*6236dae4SAndroid Build Coastguard Worker        cat \"\$lt_dump_D/\$lt_dump_F\"
5549*6236dae4SAndroid Build Coastguard Worker        exit 0
5550*6236dae4SAndroid Build Coastguard Worker      ;;
5551*6236dae4SAndroid Build Coastguard Worker    --lt-*)
5552*6236dae4SAndroid Build Coastguard Worker        \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2
5553*6236dae4SAndroid Build Coastguard Worker        exit 1
5554*6236dae4SAndroid Build Coastguard Worker      ;;
5555*6236dae4SAndroid Build Coastguard Worker    esac
5556*6236dae4SAndroid Build Coastguard Worker  done
5557*6236dae4SAndroid Build Coastguard Worker
5558*6236dae4SAndroid Build Coastguard Worker  # Print the debug banner immediately:
5559*6236dae4SAndroid Build Coastguard Worker  if test -n \"\$lt_option_debug\"; then
5560*6236dae4SAndroid Build Coastguard Worker    echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2
5561*6236dae4SAndroid Build Coastguard Worker  fi
5562*6236dae4SAndroid Build Coastguard Worker}
5563*6236dae4SAndroid Build Coastguard Worker
5564*6236dae4SAndroid Build Coastguard Worker# Used when --lt-debug. Prints its arguments to stdout
5565*6236dae4SAndroid Build Coastguard Worker# (redirection is the responsibility of the caller)
5566*6236dae4SAndroid Build Coastguard Workerfunc_lt_dump_args ()
5567*6236dae4SAndroid Build Coastguard Worker{
5568*6236dae4SAndroid Build Coastguard Worker  lt_dump_args_N=1;
5569*6236dae4SAndroid Build Coastguard Worker  for lt_arg
5570*6236dae4SAndroid Build Coastguard Worker  do
5571*6236dae4SAndroid Build Coastguard Worker    \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\"
5572*6236dae4SAndroid Build Coastguard Worker    lt_dump_args_N=\`expr \$lt_dump_args_N + 1\`
5573*6236dae4SAndroid Build Coastguard Worker  done
5574*6236dae4SAndroid Build Coastguard Worker}
5575*6236dae4SAndroid Build Coastguard Worker
5576*6236dae4SAndroid Build Coastguard Worker# Core function for launching the target application
5577*6236dae4SAndroid Build Coastguard Workerfunc_exec_program_core ()
5578*6236dae4SAndroid Build Coastguard Worker{
5579*6236dae4SAndroid Build Coastguard Worker"
5580*6236dae4SAndroid Build Coastguard Worker  case $host in
5581*6236dae4SAndroid Build Coastguard Worker  # Backslashes separate directories on plain windows
5582*6236dae4SAndroid Build Coastguard Worker  *-*-mingw | *-*-os2* | *-cegcc*)
5583*6236dae4SAndroid Build Coastguard Worker    $ECHO "\
5584*6236dae4SAndroid Build Coastguard Worker      if test -n \"\$lt_option_debug\"; then
5585*6236dae4SAndroid Build Coastguard Worker        \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2
5586*6236dae4SAndroid Build Coastguard Worker        func_lt_dump_args \${1+\"\$@\"} 1>&2
5587*6236dae4SAndroid Build Coastguard Worker      fi
5588*6236dae4SAndroid Build Coastguard Worker      exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
5589*6236dae4SAndroid Build Coastguard Worker"
5590*6236dae4SAndroid Build Coastguard Worker    ;;
5591*6236dae4SAndroid Build Coastguard Worker
5592*6236dae4SAndroid Build Coastguard Worker  *)
5593*6236dae4SAndroid Build Coastguard Worker    $ECHO "\
5594*6236dae4SAndroid Build Coastguard Worker      if test -n \"\$lt_option_debug\"; then
5595*6236dae4SAndroid Build Coastguard Worker        \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2
5596*6236dae4SAndroid Build Coastguard Worker        func_lt_dump_args \${1+\"\$@\"} 1>&2
5597*6236dae4SAndroid Build Coastguard Worker      fi
5598*6236dae4SAndroid Build Coastguard Worker      exec \"\$progdir/\$program\" \${1+\"\$@\"}
5599*6236dae4SAndroid Build Coastguard Worker"
5600*6236dae4SAndroid Build Coastguard Worker    ;;
5601*6236dae4SAndroid Build Coastguard Worker  esac
5602*6236dae4SAndroid Build Coastguard Worker  $ECHO "\
5603*6236dae4SAndroid Build Coastguard Worker      \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2
5604*6236dae4SAndroid Build Coastguard Worker      exit 1
5605*6236dae4SAndroid Build Coastguard Worker}
5606*6236dae4SAndroid Build Coastguard Worker
5607*6236dae4SAndroid Build Coastguard Worker# A function to encapsulate launching the target application
5608*6236dae4SAndroid Build Coastguard Worker# Strips options in the --lt-* namespace from \$@ and
5609*6236dae4SAndroid Build Coastguard Worker# launches target application with the remaining arguments.
5610*6236dae4SAndroid Build Coastguard Workerfunc_exec_program ()
5611*6236dae4SAndroid Build Coastguard Worker{
5612*6236dae4SAndroid Build Coastguard Worker  case \" \$* \" in
5613*6236dae4SAndroid Build Coastguard Worker  *\\ --lt-*)
5614*6236dae4SAndroid Build Coastguard Worker    for lt_wr_arg
5615*6236dae4SAndroid Build Coastguard Worker    do
5616*6236dae4SAndroid Build Coastguard Worker      case \$lt_wr_arg in
5617*6236dae4SAndroid Build Coastguard Worker      --lt-*) ;;
5618*6236dae4SAndroid Build Coastguard Worker      *) set x \"\$@\" \"\$lt_wr_arg\"; shift;;
5619*6236dae4SAndroid Build Coastguard Worker      esac
5620*6236dae4SAndroid Build Coastguard Worker      shift
5621*6236dae4SAndroid Build Coastguard Worker    done ;;
5622*6236dae4SAndroid Build Coastguard Worker  esac
5623*6236dae4SAndroid Build Coastguard Worker  func_exec_program_core \${1+\"\$@\"}
5624*6236dae4SAndroid Build Coastguard Worker}
5625*6236dae4SAndroid Build Coastguard Worker
5626*6236dae4SAndroid Build Coastguard Worker  # Parse options
5627*6236dae4SAndroid Build Coastguard Worker  func_parse_lt_options \"\$0\" \${1+\"\$@\"}
5628*6236dae4SAndroid Build Coastguard Worker
5629*6236dae4SAndroid Build Coastguard Worker  # Find the directory that this script lives in.
5630*6236dae4SAndroid Build Coastguard Worker  thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\`
5631*6236dae4SAndroid Build Coastguard Worker  test \"x\$thisdir\" = \"x\$file\" && thisdir=.
5632*6236dae4SAndroid Build Coastguard Worker
5633*6236dae4SAndroid Build Coastguard Worker  # Follow symbolic links until we get to the real thisdir.
5634*6236dae4SAndroid Build Coastguard Worker  file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\`
5635*6236dae4SAndroid Build Coastguard Worker  while test -n \"\$file\"; do
5636*6236dae4SAndroid Build Coastguard Worker    destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\`
5637*6236dae4SAndroid Build Coastguard Worker
5638*6236dae4SAndroid Build Coastguard Worker    # If there was a directory component, then change thisdir.
5639*6236dae4SAndroid Build Coastguard Worker    if test \"x\$destdir\" != \"x\$file\"; then
5640*6236dae4SAndroid Build Coastguard Worker      case \"\$destdir\" in
5641*6236dae4SAndroid Build Coastguard Worker      [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;;
5642*6236dae4SAndroid Build Coastguard Worker      *) thisdir=\"\$thisdir/\$destdir\" ;;
5643*6236dae4SAndroid Build Coastguard Worker      esac
5644*6236dae4SAndroid Build Coastguard Worker    fi
5645*6236dae4SAndroid Build Coastguard Worker
5646*6236dae4SAndroid Build Coastguard Worker    file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\`
5647*6236dae4SAndroid Build Coastguard Worker    file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\`
5648*6236dae4SAndroid Build Coastguard Worker  done
5649*6236dae4SAndroid Build Coastguard Worker
5650*6236dae4SAndroid Build Coastguard Worker  # Usually 'no', except on cygwin/mingw when embedded into
5651*6236dae4SAndroid Build Coastguard Worker  # the cwrapper.
5652*6236dae4SAndroid Build Coastguard Worker  WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1
5653*6236dae4SAndroid Build Coastguard Worker  if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then
5654*6236dae4SAndroid Build Coastguard Worker    # special case for '.'
5655*6236dae4SAndroid Build Coastguard Worker    if test \"\$thisdir\" = \".\"; then
5656*6236dae4SAndroid Build Coastguard Worker      thisdir=\`pwd\`
5657*6236dae4SAndroid Build Coastguard Worker    fi
5658*6236dae4SAndroid Build Coastguard Worker    # remove .libs from thisdir
5659*6236dae4SAndroid Build Coastguard Worker    case \"\$thisdir\" in
5660*6236dae4SAndroid Build Coastguard Worker    *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;;
5661*6236dae4SAndroid Build Coastguard Worker    $objdir )   thisdir=. ;;
5662*6236dae4SAndroid Build Coastguard Worker    esac
5663*6236dae4SAndroid Build Coastguard Worker  fi
5664*6236dae4SAndroid Build Coastguard Worker
5665*6236dae4SAndroid Build Coastguard Worker  # Try to get the absolute directory name.
5666*6236dae4SAndroid Build Coastguard Worker  absdir=\`cd \"\$thisdir\" && pwd\`
5667*6236dae4SAndroid Build Coastguard Worker  test -n \"\$absdir\" && thisdir=\"\$absdir\"
5668*6236dae4SAndroid Build Coastguard Worker"
5669*6236dae4SAndroid Build Coastguard Worker
5670*6236dae4SAndroid Build Coastguard Worker	if test yes = "$fast_install"; then
5671*6236dae4SAndroid Build Coastguard Worker	  $ECHO "\
5672*6236dae4SAndroid Build Coastguard Worker  program=lt-'$outputname'$exeext
5673*6236dae4SAndroid Build Coastguard Worker  progdir=\"\$thisdir/$objdir\"
5674*6236dae4SAndroid Build Coastguard Worker
5675*6236dae4SAndroid Build Coastguard Worker  if test ! -f \"\$progdir/\$program\" ||
5676*6236dae4SAndroid Build Coastguard Worker     { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\
5677*6236dae4SAndroid Build Coastguard Worker       test \"X\$file\" != \"X\$progdir/\$program\"; }; then
5678*6236dae4SAndroid Build Coastguard Worker
5679*6236dae4SAndroid Build Coastguard Worker    file=\"\$\$-\$program\"
5680*6236dae4SAndroid Build Coastguard Worker
5681*6236dae4SAndroid Build Coastguard Worker    if test ! -d \"\$progdir\"; then
5682*6236dae4SAndroid Build Coastguard Worker      $MKDIR \"\$progdir\"
5683*6236dae4SAndroid Build Coastguard Worker    else
5684*6236dae4SAndroid Build Coastguard Worker      $RM \"\$progdir/\$file\"
5685*6236dae4SAndroid Build Coastguard Worker    fi"
5686*6236dae4SAndroid Build Coastguard Worker
5687*6236dae4SAndroid Build Coastguard Worker	  $ECHO "\
5688*6236dae4SAndroid Build Coastguard Worker
5689*6236dae4SAndroid Build Coastguard Worker    # relink executable if necessary
5690*6236dae4SAndroid Build Coastguard Worker    if test -n \"\$relink_command\"; then
5691*6236dae4SAndroid Build Coastguard Worker      if relink_command_output=\`eval \$relink_command 2>&1\`; then :
5692*6236dae4SAndroid Build Coastguard Worker      else
5693*6236dae4SAndroid Build Coastguard Worker	\$ECHO \"\$relink_command_output\" >&2
5694*6236dae4SAndroid Build Coastguard Worker	$RM \"\$progdir/\$file\"
5695*6236dae4SAndroid Build Coastguard Worker	exit 1
5696*6236dae4SAndroid Build Coastguard Worker      fi
5697*6236dae4SAndroid Build Coastguard Worker    fi
5698*6236dae4SAndroid Build Coastguard Worker
5699*6236dae4SAndroid Build Coastguard Worker    $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null ||
5700*6236dae4SAndroid Build Coastguard Worker    { $RM \"\$progdir/\$program\";
5701*6236dae4SAndroid Build Coastguard Worker      $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; }
5702*6236dae4SAndroid Build Coastguard Worker    $RM \"\$progdir/\$file\"
5703*6236dae4SAndroid Build Coastguard Worker  fi"
5704*6236dae4SAndroid Build Coastguard Worker	else
5705*6236dae4SAndroid Build Coastguard Worker	  $ECHO "\
5706*6236dae4SAndroid Build Coastguard Worker  program='$outputname'
5707*6236dae4SAndroid Build Coastguard Worker  progdir=\"\$thisdir/$objdir\"
5708*6236dae4SAndroid Build Coastguard Worker"
5709*6236dae4SAndroid Build Coastguard Worker	fi
5710*6236dae4SAndroid Build Coastguard Worker
5711*6236dae4SAndroid Build Coastguard Worker	$ECHO "\
5712*6236dae4SAndroid Build Coastguard Worker
5713*6236dae4SAndroid Build Coastguard Worker  if test -f \"\$progdir/\$program\"; then"
5714*6236dae4SAndroid Build Coastguard Worker
5715*6236dae4SAndroid Build Coastguard Worker	# fixup the dll searchpath if we need to.
5716*6236dae4SAndroid Build Coastguard Worker	#
5717*6236dae4SAndroid Build Coastguard Worker	# Fix the DLL searchpath if we need to.  Do this before prepending
5718*6236dae4SAndroid Build Coastguard Worker	# to shlibpath, because on Windows, both are PATH and uninstalled
5719*6236dae4SAndroid Build Coastguard Worker	# libraries must come first.
5720*6236dae4SAndroid Build Coastguard Worker	if test -n "$dllsearchpath"; then
5721*6236dae4SAndroid Build Coastguard Worker	  $ECHO "\
5722*6236dae4SAndroid Build Coastguard Worker    # Add the dll search path components to the executable PATH
5723*6236dae4SAndroid Build Coastguard Worker    PATH=$dllsearchpath:\$PATH
5724*6236dae4SAndroid Build Coastguard Worker"
5725*6236dae4SAndroid Build Coastguard Worker	fi
5726*6236dae4SAndroid Build Coastguard Worker
5727*6236dae4SAndroid Build Coastguard Worker	# Export our shlibpath_var if we have one.
5728*6236dae4SAndroid Build Coastguard Worker	if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
5729*6236dae4SAndroid Build Coastguard Worker	  $ECHO "\
5730*6236dae4SAndroid Build Coastguard Worker    # Add our own library path to $shlibpath_var
5731*6236dae4SAndroid Build Coastguard Worker    $shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
5732*6236dae4SAndroid Build Coastguard Worker
5733*6236dae4SAndroid Build Coastguard Worker    # Some systems cannot cope with colon-terminated $shlibpath_var
5734*6236dae4SAndroid Build Coastguard Worker    # The second colon is a workaround for a bug in BeOS R4 sed
5735*6236dae4SAndroid Build Coastguard Worker    $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\`
5736*6236dae4SAndroid Build Coastguard Worker
5737*6236dae4SAndroid Build Coastguard Worker    export $shlibpath_var
5738*6236dae4SAndroid Build Coastguard Worker"
5739*6236dae4SAndroid Build Coastguard Worker	fi
5740*6236dae4SAndroid Build Coastguard Worker
5741*6236dae4SAndroid Build Coastguard Worker	$ECHO "\
5742*6236dae4SAndroid Build Coastguard Worker    if test \"\$libtool_execute_magic\" != \"$magic\"; then
5743*6236dae4SAndroid Build Coastguard Worker      # Run the actual program with our arguments.
5744*6236dae4SAndroid Build Coastguard Worker      func_exec_program \${1+\"\$@\"}
5745*6236dae4SAndroid Build Coastguard Worker    fi
5746*6236dae4SAndroid Build Coastguard Worker  else
5747*6236dae4SAndroid Build Coastguard Worker    # The program doesn't exist.
5748*6236dae4SAndroid Build Coastguard Worker    \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2
5749*6236dae4SAndroid Build Coastguard Worker    \$ECHO \"This script is just a wrapper for \$program.\" 1>&2
5750*6236dae4SAndroid Build Coastguard Worker    \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2
5751*6236dae4SAndroid Build Coastguard Worker    exit 1
5752*6236dae4SAndroid Build Coastguard Worker  fi
5753*6236dae4SAndroid Build Coastguard Workerfi\
5754*6236dae4SAndroid Build Coastguard Worker"
5755*6236dae4SAndroid Build Coastguard Worker}
5756*6236dae4SAndroid Build Coastguard Worker
5757*6236dae4SAndroid Build Coastguard Worker
5758*6236dae4SAndroid Build Coastguard Worker# func_emit_cwrapperexe_src
5759*6236dae4SAndroid Build Coastguard Worker# emit the source code for a wrapper executable on stdout
5760*6236dae4SAndroid Build Coastguard Worker# Must ONLY be called from within func_mode_link because
5761*6236dae4SAndroid Build Coastguard Worker# it depends on a number of variable set therein.
5762*6236dae4SAndroid Build Coastguard Workerfunc_emit_cwrapperexe_src ()
5763*6236dae4SAndroid Build Coastguard Worker{
5764*6236dae4SAndroid Build Coastguard Worker	cat <<EOF
5765*6236dae4SAndroid Build Coastguard Worker
5766*6236dae4SAndroid Build Coastguard Worker/* $cwrappersource - temporary wrapper executable for $objdir/$outputname
5767*6236dae4SAndroid Build Coastguard Worker   Generated by $PROGRAM (GNU $PACKAGE) $VERSION
5768*6236dae4SAndroid Build Coastguard Worker
5769*6236dae4SAndroid Build Coastguard Worker   The $output program cannot be directly executed until all the libtool
5770*6236dae4SAndroid Build Coastguard Worker   libraries that it depends on are installed.
5771*6236dae4SAndroid Build Coastguard Worker
5772*6236dae4SAndroid Build Coastguard Worker   This wrapper executable should never be moved out of the build directory.
5773*6236dae4SAndroid Build Coastguard Worker   If it is, it will not operate correctly.
5774*6236dae4SAndroid Build Coastguard Worker*/
5775*6236dae4SAndroid Build Coastguard WorkerEOF
5776*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
5777*6236dae4SAndroid Build Coastguard Worker#ifdef _MSC_VER
5778*6236dae4SAndroid Build Coastguard Worker# define _CRT_SECURE_NO_DEPRECATE 1
5779*6236dae4SAndroid Build Coastguard Worker#endif
5780*6236dae4SAndroid Build Coastguard Worker#include <stdio.h>
5781*6236dae4SAndroid Build Coastguard Worker#include <stdlib.h>
5782*6236dae4SAndroid Build Coastguard Worker#ifdef _MSC_VER
5783*6236dae4SAndroid Build Coastguard Worker# include <direct.h>
5784*6236dae4SAndroid Build Coastguard Worker# include <process.h>
5785*6236dae4SAndroid Build Coastguard Worker# include <io.h>
5786*6236dae4SAndroid Build Coastguard Worker#else
5787*6236dae4SAndroid Build Coastguard Worker# include <unistd.h>
5788*6236dae4SAndroid Build Coastguard Worker# include <stdint.h>
5789*6236dae4SAndroid Build Coastguard Worker# ifdef __CYGWIN__
5790*6236dae4SAndroid Build Coastguard Worker#  include <io.h>
5791*6236dae4SAndroid Build Coastguard Worker# endif
5792*6236dae4SAndroid Build Coastguard Worker#endif
5793*6236dae4SAndroid Build Coastguard Worker#include <malloc.h>
5794*6236dae4SAndroid Build Coastguard Worker#include <stdarg.h>
5795*6236dae4SAndroid Build Coastguard Worker#include <assert.h>
5796*6236dae4SAndroid Build Coastguard Worker#include <string.h>
5797*6236dae4SAndroid Build Coastguard Worker#include <ctype.h>
5798*6236dae4SAndroid Build Coastguard Worker#include <errno.h>
5799*6236dae4SAndroid Build Coastguard Worker#include <fcntl.h>
5800*6236dae4SAndroid Build Coastguard Worker#include <sys/stat.h>
5801*6236dae4SAndroid Build Coastguard Worker
5802*6236dae4SAndroid Build Coastguard Worker#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
5803*6236dae4SAndroid Build Coastguard Worker
5804*6236dae4SAndroid Build Coastguard Worker/* declarations of non-ANSI functions */
5805*6236dae4SAndroid Build Coastguard Worker#if defined __MINGW32__
5806*6236dae4SAndroid Build Coastguard Worker# ifdef __STRICT_ANSI__
5807*6236dae4SAndroid Build Coastguard Workerint _putenv (const char *);
5808*6236dae4SAndroid Build Coastguard Worker# endif
5809*6236dae4SAndroid Build Coastguard Worker#elif defined __CYGWIN__
5810*6236dae4SAndroid Build Coastguard Worker# ifdef __STRICT_ANSI__
5811*6236dae4SAndroid Build Coastguard Workerchar *realpath (const char *, char *);
5812*6236dae4SAndroid Build Coastguard Workerint putenv (char *);
5813*6236dae4SAndroid Build Coastguard Workerint setenv (const char *, const char *, int);
5814*6236dae4SAndroid Build Coastguard Worker# endif
5815*6236dae4SAndroid Build Coastguard Worker/* #elif defined other_platform || defined ... */
5816*6236dae4SAndroid Build Coastguard Worker#endif
5817*6236dae4SAndroid Build Coastguard Worker
5818*6236dae4SAndroid Build Coastguard Worker/* portability defines, excluding path handling macros */
5819*6236dae4SAndroid Build Coastguard Worker#if defined _MSC_VER
5820*6236dae4SAndroid Build Coastguard Worker# define setmode _setmode
5821*6236dae4SAndroid Build Coastguard Worker# define stat    _stat
5822*6236dae4SAndroid Build Coastguard Worker# define chmod   _chmod
5823*6236dae4SAndroid Build Coastguard Worker# define getcwd  _getcwd
5824*6236dae4SAndroid Build Coastguard Worker# define putenv  _putenv
5825*6236dae4SAndroid Build Coastguard Worker# define S_IXUSR _S_IEXEC
5826*6236dae4SAndroid Build Coastguard Worker#elif defined __MINGW32__
5827*6236dae4SAndroid Build Coastguard Worker# define setmode _setmode
5828*6236dae4SAndroid Build Coastguard Worker# define stat    _stat
5829*6236dae4SAndroid Build Coastguard Worker# define chmod   _chmod
5830*6236dae4SAndroid Build Coastguard Worker# define getcwd  _getcwd
5831*6236dae4SAndroid Build Coastguard Worker# define putenv  _putenv
5832*6236dae4SAndroid Build Coastguard Worker#elif defined __CYGWIN__
5833*6236dae4SAndroid Build Coastguard Worker# define HAVE_SETENV
5834*6236dae4SAndroid Build Coastguard Worker# define FOPEN_WB "wb"
5835*6236dae4SAndroid Build Coastguard Worker/* #elif defined other platforms ... */
5836*6236dae4SAndroid Build Coastguard Worker#endif
5837*6236dae4SAndroid Build Coastguard Worker
5838*6236dae4SAndroid Build Coastguard Worker#if defined PATH_MAX
5839*6236dae4SAndroid Build Coastguard Worker# define LT_PATHMAX PATH_MAX
5840*6236dae4SAndroid Build Coastguard Worker#elif defined MAXPATHLEN
5841*6236dae4SAndroid Build Coastguard Worker# define LT_PATHMAX MAXPATHLEN
5842*6236dae4SAndroid Build Coastguard Worker#else
5843*6236dae4SAndroid Build Coastguard Worker# define LT_PATHMAX 1024
5844*6236dae4SAndroid Build Coastguard Worker#endif
5845*6236dae4SAndroid Build Coastguard Worker
5846*6236dae4SAndroid Build Coastguard Worker#ifndef S_IXOTH
5847*6236dae4SAndroid Build Coastguard Worker# define S_IXOTH 0
5848*6236dae4SAndroid Build Coastguard Worker#endif
5849*6236dae4SAndroid Build Coastguard Worker#ifndef S_IXGRP
5850*6236dae4SAndroid Build Coastguard Worker# define S_IXGRP 0
5851*6236dae4SAndroid Build Coastguard Worker#endif
5852*6236dae4SAndroid Build Coastguard Worker
5853*6236dae4SAndroid Build Coastguard Worker/* path handling portability macros */
5854*6236dae4SAndroid Build Coastguard Worker#ifndef DIR_SEPARATOR
5855*6236dae4SAndroid Build Coastguard Worker# define DIR_SEPARATOR '/'
5856*6236dae4SAndroid Build Coastguard Worker# define PATH_SEPARATOR ':'
5857*6236dae4SAndroid Build Coastguard Worker#endif
5858*6236dae4SAndroid Build Coastguard Worker
5859*6236dae4SAndroid Build Coastguard Worker#if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \
5860*6236dae4SAndroid Build Coastguard Worker  defined __OS2__
5861*6236dae4SAndroid Build Coastguard Worker# define HAVE_DOS_BASED_FILE_SYSTEM
5862*6236dae4SAndroid Build Coastguard Worker# define FOPEN_WB "wb"
5863*6236dae4SAndroid Build Coastguard Worker# ifndef DIR_SEPARATOR_2
5864*6236dae4SAndroid Build Coastguard Worker#  define DIR_SEPARATOR_2 '\\'
5865*6236dae4SAndroid Build Coastguard Worker# endif
5866*6236dae4SAndroid Build Coastguard Worker# ifndef PATH_SEPARATOR_2
5867*6236dae4SAndroid Build Coastguard Worker#  define PATH_SEPARATOR_2 ';'
5868*6236dae4SAndroid Build Coastguard Worker# endif
5869*6236dae4SAndroid Build Coastguard Worker#endif
5870*6236dae4SAndroid Build Coastguard Worker
5871*6236dae4SAndroid Build Coastguard Worker#ifndef DIR_SEPARATOR_2
5872*6236dae4SAndroid Build Coastguard Worker# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR)
5873*6236dae4SAndroid Build Coastguard Worker#else /* DIR_SEPARATOR_2 */
5874*6236dae4SAndroid Build Coastguard Worker# define IS_DIR_SEPARATOR(ch) \
5875*6236dae4SAndroid Build Coastguard Worker	(((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2))
5876*6236dae4SAndroid Build Coastguard Worker#endif /* DIR_SEPARATOR_2 */
5877*6236dae4SAndroid Build Coastguard Worker
5878*6236dae4SAndroid Build Coastguard Worker#ifndef PATH_SEPARATOR_2
5879*6236dae4SAndroid Build Coastguard Worker# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR)
5880*6236dae4SAndroid Build Coastguard Worker#else /* PATH_SEPARATOR_2 */
5881*6236dae4SAndroid Build Coastguard Worker# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2)
5882*6236dae4SAndroid Build Coastguard Worker#endif /* PATH_SEPARATOR_2 */
5883*6236dae4SAndroid Build Coastguard Worker
5884*6236dae4SAndroid Build Coastguard Worker#ifndef FOPEN_WB
5885*6236dae4SAndroid Build Coastguard Worker# define FOPEN_WB "w"
5886*6236dae4SAndroid Build Coastguard Worker#endif
5887*6236dae4SAndroid Build Coastguard Worker#ifndef _O_BINARY
5888*6236dae4SAndroid Build Coastguard Worker# define _O_BINARY 0
5889*6236dae4SAndroid Build Coastguard Worker#endif
5890*6236dae4SAndroid Build Coastguard Worker
5891*6236dae4SAndroid Build Coastguard Worker#define XMALLOC(type, num)      ((type *) xmalloc ((num) * sizeof(type)))
5892*6236dae4SAndroid Build Coastguard Worker#define XFREE(stale) do { \
5893*6236dae4SAndroid Build Coastguard Worker  if (stale) { free (stale); stale = 0; } \
5894*6236dae4SAndroid Build Coastguard Worker} while (0)
5895*6236dae4SAndroid Build Coastguard Worker
5896*6236dae4SAndroid Build Coastguard Worker#if defined LT_DEBUGWRAPPER
5897*6236dae4SAndroid Build Coastguard Workerstatic int lt_debug = 1;
5898*6236dae4SAndroid Build Coastguard Worker#else
5899*6236dae4SAndroid Build Coastguard Workerstatic int lt_debug = 0;
5900*6236dae4SAndroid Build Coastguard Worker#endif
5901*6236dae4SAndroid Build Coastguard Worker
5902*6236dae4SAndroid Build Coastguard Workerconst char *program_name = "libtool-wrapper"; /* in case xstrdup fails */
5903*6236dae4SAndroid Build Coastguard Worker
5904*6236dae4SAndroid Build Coastguard Workervoid *xmalloc (size_t num);
5905*6236dae4SAndroid Build Coastguard Workerchar *xstrdup (const char *string);
5906*6236dae4SAndroid Build Coastguard Workerconst char *base_name (const char *name);
5907*6236dae4SAndroid Build Coastguard Workerchar *find_executable (const char *wrapper);
5908*6236dae4SAndroid Build Coastguard Workerchar *chase_symlinks (const char *pathspec);
5909*6236dae4SAndroid Build Coastguard Workerint make_executable (const char *path);
5910*6236dae4SAndroid Build Coastguard Workerint check_executable (const char *path);
5911*6236dae4SAndroid Build Coastguard Workerchar *strendzap (char *str, const char *pat);
5912*6236dae4SAndroid Build Coastguard Workervoid lt_debugprintf (const char *file, int line, const char *fmt, ...);
5913*6236dae4SAndroid Build Coastguard Workervoid lt_fatal (const char *file, int line, const char *message, ...);
5914*6236dae4SAndroid Build Coastguard Workerstatic const char *nonnull (const char *s);
5915*6236dae4SAndroid Build Coastguard Workerstatic const char *nonempty (const char *s);
5916*6236dae4SAndroid Build Coastguard Workervoid lt_setenv (const char *name, const char *value);
5917*6236dae4SAndroid Build Coastguard Workerchar *lt_extend_str (const char *orig_value, const char *add, int to_end);
5918*6236dae4SAndroid Build Coastguard Workervoid lt_update_exe_path (const char *name, const char *value);
5919*6236dae4SAndroid Build Coastguard Workervoid lt_update_lib_path (const char *name, const char *value);
5920*6236dae4SAndroid Build Coastguard Workerchar **prepare_spawn (char **argv);
5921*6236dae4SAndroid Build Coastguard Workervoid lt_dump_script (FILE *f);
5922*6236dae4SAndroid Build Coastguard WorkerEOF
5923*6236dae4SAndroid Build Coastguard Worker
5924*6236dae4SAndroid Build Coastguard Worker	    cat <<EOF
5925*6236dae4SAndroid Build Coastguard Worker#if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 5)
5926*6236dae4SAndroid Build Coastguard Worker# define externally_visible volatile
5927*6236dae4SAndroid Build Coastguard Worker#else
5928*6236dae4SAndroid Build Coastguard Worker# define externally_visible __attribute__((externally_visible)) volatile
5929*6236dae4SAndroid Build Coastguard Worker#endif
5930*6236dae4SAndroid Build Coastguard Workerexternally_visible const char * MAGIC_EXE = "$magic_exe";
5931*6236dae4SAndroid Build Coastguard Workerconst char * LIB_PATH_VARNAME = "$shlibpath_var";
5932*6236dae4SAndroid Build Coastguard WorkerEOF
5933*6236dae4SAndroid Build Coastguard Worker
5934*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
5935*6236dae4SAndroid Build Coastguard Worker              func_to_host_path "$temp_rpath"
5936*6236dae4SAndroid Build Coastguard Worker	      cat <<EOF
5937*6236dae4SAndroid Build Coastguard Workerconst char * LIB_PATH_VALUE   = "$func_to_host_path_result";
5938*6236dae4SAndroid Build Coastguard WorkerEOF
5939*6236dae4SAndroid Build Coastguard Worker	    else
5940*6236dae4SAndroid Build Coastguard Worker	      cat <<"EOF"
5941*6236dae4SAndroid Build Coastguard Workerconst char * LIB_PATH_VALUE   = "";
5942*6236dae4SAndroid Build Coastguard WorkerEOF
5943*6236dae4SAndroid Build Coastguard Worker	    fi
5944*6236dae4SAndroid Build Coastguard Worker
5945*6236dae4SAndroid Build Coastguard Worker	    if test -n "$dllsearchpath"; then
5946*6236dae4SAndroid Build Coastguard Worker              func_to_host_path "$dllsearchpath:"
5947*6236dae4SAndroid Build Coastguard Worker	      cat <<EOF
5948*6236dae4SAndroid Build Coastguard Workerconst char * EXE_PATH_VARNAME = "PATH";
5949*6236dae4SAndroid Build Coastguard Workerconst char * EXE_PATH_VALUE   = "$func_to_host_path_result";
5950*6236dae4SAndroid Build Coastguard WorkerEOF
5951*6236dae4SAndroid Build Coastguard Worker	    else
5952*6236dae4SAndroid Build Coastguard Worker	      cat <<"EOF"
5953*6236dae4SAndroid Build Coastguard Workerconst char * EXE_PATH_VARNAME = "";
5954*6236dae4SAndroid Build Coastguard Workerconst char * EXE_PATH_VALUE   = "";
5955*6236dae4SAndroid Build Coastguard WorkerEOF
5956*6236dae4SAndroid Build Coastguard Worker	    fi
5957*6236dae4SAndroid Build Coastguard Worker
5958*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$fast_install"; then
5959*6236dae4SAndroid Build Coastguard Worker	      cat <<EOF
5960*6236dae4SAndroid Build Coastguard Workerconst char * TARGET_PROGRAM_NAME = "lt-$outputname"; /* hopefully, no .exe */
5961*6236dae4SAndroid Build Coastguard WorkerEOF
5962*6236dae4SAndroid Build Coastguard Worker	    else
5963*6236dae4SAndroid Build Coastguard Worker	      cat <<EOF
5964*6236dae4SAndroid Build Coastguard Workerconst char * TARGET_PROGRAM_NAME = "$outputname"; /* hopefully, no .exe */
5965*6236dae4SAndroid Build Coastguard WorkerEOF
5966*6236dae4SAndroid Build Coastguard Worker	    fi
5967*6236dae4SAndroid Build Coastguard Worker
5968*6236dae4SAndroid Build Coastguard Worker
5969*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
5970*6236dae4SAndroid Build Coastguard Worker
5971*6236dae4SAndroid Build Coastguard Worker#define LTWRAPPER_OPTION_PREFIX         "--lt-"
5972*6236dae4SAndroid Build Coastguard Worker
5973*6236dae4SAndroid Build Coastguard Workerstatic const char *ltwrapper_option_prefix = LTWRAPPER_OPTION_PREFIX;
5974*6236dae4SAndroid Build Coastguard Workerstatic const char *dumpscript_opt       = LTWRAPPER_OPTION_PREFIX "dump-script";
5975*6236dae4SAndroid Build Coastguard Workerstatic const char *debug_opt            = LTWRAPPER_OPTION_PREFIX "debug";
5976*6236dae4SAndroid Build Coastguard Worker
5977*6236dae4SAndroid Build Coastguard Workerint
5978*6236dae4SAndroid Build Coastguard Workermain (int argc, char *argv[])
5979*6236dae4SAndroid Build Coastguard Worker{
5980*6236dae4SAndroid Build Coastguard Worker  char **newargz;
5981*6236dae4SAndroid Build Coastguard Worker  int  newargc;
5982*6236dae4SAndroid Build Coastguard Worker  char *tmp_pathspec;
5983*6236dae4SAndroid Build Coastguard Worker  char *actual_cwrapper_path;
5984*6236dae4SAndroid Build Coastguard Worker  char *actual_cwrapper_name;
5985*6236dae4SAndroid Build Coastguard Worker  char *target_name;
5986*6236dae4SAndroid Build Coastguard Worker  char *lt_argv_zero;
5987*6236dae4SAndroid Build Coastguard Worker  int rval = 127;
5988*6236dae4SAndroid Build Coastguard Worker
5989*6236dae4SAndroid Build Coastguard Worker  int i;
5990*6236dae4SAndroid Build Coastguard Worker
5991*6236dae4SAndroid Build Coastguard Worker  program_name = (char *) xstrdup (base_name (argv[0]));
5992*6236dae4SAndroid Build Coastguard Worker  newargz = XMALLOC (char *, (size_t) argc + 1);
5993*6236dae4SAndroid Build Coastguard Worker
5994*6236dae4SAndroid Build Coastguard Worker  /* very simple arg parsing; don't want to rely on getopt
5995*6236dae4SAndroid Build Coastguard Worker   * also, copy all non cwrapper options to newargz, except
5996*6236dae4SAndroid Build Coastguard Worker   * argz[0], which is handled differently
5997*6236dae4SAndroid Build Coastguard Worker   */
5998*6236dae4SAndroid Build Coastguard Worker  newargc=0;
5999*6236dae4SAndroid Build Coastguard Worker  for (i = 1; i < argc; i++)
6000*6236dae4SAndroid Build Coastguard Worker    {
6001*6236dae4SAndroid Build Coastguard Worker      if (STREQ (argv[i], dumpscript_opt))
6002*6236dae4SAndroid Build Coastguard Worker	{
6003*6236dae4SAndroid Build Coastguard WorkerEOF
6004*6236dae4SAndroid Build Coastguard Worker	    case $host in
6005*6236dae4SAndroid Build Coastguard Worker	      *mingw* | *cygwin* )
6006*6236dae4SAndroid Build Coastguard Worker		# make stdout use "unix" line endings
6007*6236dae4SAndroid Build Coastguard Worker		echo "          setmode(1,_O_BINARY);"
6008*6236dae4SAndroid Build Coastguard Worker		;;
6009*6236dae4SAndroid Build Coastguard Worker	      esac
6010*6236dae4SAndroid Build Coastguard Worker
6011*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
6012*6236dae4SAndroid Build Coastguard Worker	  lt_dump_script (stdout);
6013*6236dae4SAndroid Build Coastguard Worker	  return 0;
6014*6236dae4SAndroid Build Coastguard Worker	}
6015*6236dae4SAndroid Build Coastguard Worker      if (STREQ (argv[i], debug_opt))
6016*6236dae4SAndroid Build Coastguard Worker	{
6017*6236dae4SAndroid Build Coastguard Worker          lt_debug = 1;
6018*6236dae4SAndroid Build Coastguard Worker          continue;
6019*6236dae4SAndroid Build Coastguard Worker	}
6020*6236dae4SAndroid Build Coastguard Worker      if (STREQ (argv[i], ltwrapper_option_prefix))
6021*6236dae4SAndroid Build Coastguard Worker        {
6022*6236dae4SAndroid Build Coastguard Worker          /* however, if there is an option in the LTWRAPPER_OPTION_PREFIX
6023*6236dae4SAndroid Build Coastguard Worker             namespace, but it is not one of the ones we know about and
6024*6236dae4SAndroid Build Coastguard Worker             have already dealt with, above (inluding dump-script), then
6025*6236dae4SAndroid Build Coastguard Worker             report an error. Otherwise, targets might begin to believe
6026*6236dae4SAndroid Build Coastguard Worker             they are allowed to use options in the LTWRAPPER_OPTION_PREFIX
6027*6236dae4SAndroid Build Coastguard Worker             namespace. The first time any user complains about this, we'll
6028*6236dae4SAndroid Build Coastguard Worker             need to make LTWRAPPER_OPTION_PREFIX a configure-time option
6029*6236dae4SAndroid Build Coastguard Worker             or a configure.ac-settable value.
6030*6236dae4SAndroid Build Coastguard Worker           */
6031*6236dae4SAndroid Build Coastguard Worker          lt_fatal (__FILE__, __LINE__,
6032*6236dae4SAndroid Build Coastguard Worker		    "unrecognized %s option: '%s'",
6033*6236dae4SAndroid Build Coastguard Worker                    ltwrapper_option_prefix, argv[i]);
6034*6236dae4SAndroid Build Coastguard Worker        }
6035*6236dae4SAndroid Build Coastguard Worker      /* otherwise ... */
6036*6236dae4SAndroid Build Coastguard Worker      newargz[++newargc] = xstrdup (argv[i]);
6037*6236dae4SAndroid Build Coastguard Worker    }
6038*6236dae4SAndroid Build Coastguard Worker  newargz[++newargc] = NULL;
6039*6236dae4SAndroid Build Coastguard Worker
6040*6236dae4SAndroid Build Coastguard WorkerEOF
6041*6236dae4SAndroid Build Coastguard Worker	    cat <<EOF
6042*6236dae4SAndroid Build Coastguard Worker  /* The GNU banner must be the first non-error debug message */
6043*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE) $VERSION\n");
6044*6236dae4SAndroid Build Coastguard WorkerEOF
6045*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
6046*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__, "(main) argv[0]: %s\n", argv[0]);
6047*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__, "(main) program_name: %s\n", program_name);
6048*6236dae4SAndroid Build Coastguard Worker
6049*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = find_executable (argv[0]);
6050*6236dae4SAndroid Build Coastguard Worker  if (tmp_pathspec == NULL)
6051*6236dae4SAndroid Build Coastguard Worker    lt_fatal (__FILE__, __LINE__, "couldn't find %s", argv[0]);
6052*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__,
6053*6236dae4SAndroid Build Coastguard Worker                  "(main) found exe (before symlink chase) at: %s\n",
6054*6236dae4SAndroid Build Coastguard Worker		  tmp_pathspec);
6055*6236dae4SAndroid Build Coastguard Worker
6056*6236dae4SAndroid Build Coastguard Worker  actual_cwrapper_path = chase_symlinks (tmp_pathspec);
6057*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__,
6058*6236dae4SAndroid Build Coastguard Worker                  "(main) found exe (after symlink chase) at: %s\n",
6059*6236dae4SAndroid Build Coastguard Worker		  actual_cwrapper_path);
6060*6236dae4SAndroid Build Coastguard Worker  XFREE (tmp_pathspec);
6061*6236dae4SAndroid Build Coastguard Worker
6062*6236dae4SAndroid Build Coastguard Worker  actual_cwrapper_name = xstrdup (base_name (actual_cwrapper_path));
6063*6236dae4SAndroid Build Coastguard Worker  strendzap (actual_cwrapper_path, actual_cwrapper_name);
6064*6236dae4SAndroid Build Coastguard Worker
6065*6236dae4SAndroid Build Coastguard Worker  /* wrapper name transforms */
6066*6236dae4SAndroid Build Coastguard Worker  strendzap (actual_cwrapper_name, ".exe");
6067*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = lt_extend_str (actual_cwrapper_name, ".exe", 1);
6068*6236dae4SAndroid Build Coastguard Worker  XFREE (actual_cwrapper_name);
6069*6236dae4SAndroid Build Coastguard Worker  actual_cwrapper_name = tmp_pathspec;
6070*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = 0;
6071*6236dae4SAndroid Build Coastguard Worker
6072*6236dae4SAndroid Build Coastguard Worker  /* target_name transforms -- use actual target program name; might have lt- prefix */
6073*6236dae4SAndroid Build Coastguard Worker  target_name = xstrdup (base_name (TARGET_PROGRAM_NAME));
6074*6236dae4SAndroid Build Coastguard Worker  strendzap (target_name, ".exe");
6075*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = lt_extend_str (target_name, ".exe", 1);
6076*6236dae4SAndroid Build Coastguard Worker  XFREE (target_name);
6077*6236dae4SAndroid Build Coastguard Worker  target_name = tmp_pathspec;
6078*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = 0;
6079*6236dae4SAndroid Build Coastguard Worker
6080*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__,
6081*6236dae4SAndroid Build Coastguard Worker		  "(main) libtool target name: %s\n",
6082*6236dae4SAndroid Build Coastguard Worker		  target_name);
6083*6236dae4SAndroid Build Coastguard WorkerEOF
6084*6236dae4SAndroid Build Coastguard Worker
6085*6236dae4SAndroid Build Coastguard Worker	    cat <<EOF
6086*6236dae4SAndroid Build Coastguard Worker  newargz[0] =
6087*6236dae4SAndroid Build Coastguard Worker    XMALLOC (char, (strlen (actual_cwrapper_path) +
6088*6236dae4SAndroid Build Coastguard Worker		    strlen ("$objdir") + 1 + strlen (actual_cwrapper_name) + 1));
6089*6236dae4SAndroid Build Coastguard Worker  strcpy (newargz[0], actual_cwrapper_path);
6090*6236dae4SAndroid Build Coastguard Worker  strcat (newargz[0], "$objdir");
6091*6236dae4SAndroid Build Coastguard Worker  strcat (newargz[0], "/");
6092*6236dae4SAndroid Build Coastguard WorkerEOF
6093*6236dae4SAndroid Build Coastguard Worker
6094*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
6095*6236dae4SAndroid Build Coastguard Worker  /* stop here, and copy so we don't have to do this twice */
6096*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = xstrdup (newargz[0]);
6097*6236dae4SAndroid Build Coastguard Worker
6098*6236dae4SAndroid Build Coastguard Worker  /* do NOT want the lt- prefix here, so use actual_cwrapper_name */
6099*6236dae4SAndroid Build Coastguard Worker  strcat (newargz[0], actual_cwrapper_name);
6100*6236dae4SAndroid Build Coastguard Worker
6101*6236dae4SAndroid Build Coastguard Worker  /* DO want the lt- prefix here if it exists, so use target_name */
6102*6236dae4SAndroid Build Coastguard Worker  lt_argv_zero = lt_extend_str (tmp_pathspec, target_name, 1);
6103*6236dae4SAndroid Build Coastguard Worker  XFREE (tmp_pathspec);
6104*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = NULL;
6105*6236dae4SAndroid Build Coastguard WorkerEOF
6106*6236dae4SAndroid Build Coastguard Worker
6107*6236dae4SAndroid Build Coastguard Worker	    case $host_os in
6108*6236dae4SAndroid Build Coastguard Worker	      mingw*)
6109*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
6110*6236dae4SAndroid Build Coastguard Worker  {
6111*6236dae4SAndroid Build Coastguard Worker    char* p;
6112*6236dae4SAndroid Build Coastguard Worker    while ((p = strchr (newargz[0], '\\')) != NULL)
6113*6236dae4SAndroid Build Coastguard Worker      {
6114*6236dae4SAndroid Build Coastguard Worker	*p = '/';
6115*6236dae4SAndroid Build Coastguard Worker      }
6116*6236dae4SAndroid Build Coastguard Worker    while ((p = strchr (lt_argv_zero, '\\')) != NULL)
6117*6236dae4SAndroid Build Coastguard Worker      {
6118*6236dae4SAndroid Build Coastguard Worker	*p = '/';
6119*6236dae4SAndroid Build Coastguard Worker      }
6120*6236dae4SAndroid Build Coastguard Worker  }
6121*6236dae4SAndroid Build Coastguard WorkerEOF
6122*6236dae4SAndroid Build Coastguard Worker	    ;;
6123*6236dae4SAndroid Build Coastguard Worker	    esac
6124*6236dae4SAndroid Build Coastguard Worker
6125*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
6126*6236dae4SAndroid Build Coastguard Worker  XFREE (target_name);
6127*6236dae4SAndroid Build Coastguard Worker  XFREE (actual_cwrapper_path);
6128*6236dae4SAndroid Build Coastguard Worker  XFREE (actual_cwrapper_name);
6129*6236dae4SAndroid Build Coastguard Worker
6130*6236dae4SAndroid Build Coastguard Worker  lt_setenv ("BIN_SH", "xpg4"); /* for Tru64 */
6131*6236dae4SAndroid Build Coastguard Worker  lt_setenv ("DUALCASE", "1");  /* for MSK sh */
6132*6236dae4SAndroid Build Coastguard Worker  /* Update the DLL searchpath.  EXE_PATH_VALUE ($dllsearchpath) must
6133*6236dae4SAndroid Build Coastguard Worker     be prepended before (that is, appear after) LIB_PATH_VALUE ($temp_rpath)
6134*6236dae4SAndroid Build Coastguard Worker     because on Windows, both *_VARNAMEs are PATH but uninstalled
6135*6236dae4SAndroid Build Coastguard Worker     libraries must come first. */
6136*6236dae4SAndroid Build Coastguard Worker  lt_update_exe_path (EXE_PATH_VARNAME, EXE_PATH_VALUE);
6137*6236dae4SAndroid Build Coastguard Worker  lt_update_lib_path (LIB_PATH_VARNAME, LIB_PATH_VALUE);
6138*6236dae4SAndroid Build Coastguard Worker
6139*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__, "(main) lt_argv_zero: %s\n",
6140*6236dae4SAndroid Build Coastguard Worker		  nonnull (lt_argv_zero));
6141*6236dae4SAndroid Build Coastguard Worker  for (i = 0; i < newargc; i++)
6142*6236dae4SAndroid Build Coastguard Worker    {
6143*6236dae4SAndroid Build Coastguard Worker      lt_debugprintf (__FILE__, __LINE__, "(main) newargz[%d]: %s\n",
6144*6236dae4SAndroid Build Coastguard Worker		      i, nonnull (newargz[i]));
6145*6236dae4SAndroid Build Coastguard Worker    }
6146*6236dae4SAndroid Build Coastguard Worker
6147*6236dae4SAndroid Build Coastguard WorkerEOF
6148*6236dae4SAndroid Build Coastguard Worker
6149*6236dae4SAndroid Build Coastguard Worker	    case $host_os in
6150*6236dae4SAndroid Build Coastguard Worker	      mingw*)
6151*6236dae4SAndroid Build Coastguard Worker		cat <<"EOF"
6152*6236dae4SAndroid Build Coastguard Worker  /* execv doesn't actually work on mingw as expected on unix */
6153*6236dae4SAndroid Build Coastguard Worker  newargz = prepare_spawn (newargz);
6154*6236dae4SAndroid Build Coastguard Worker  rval = (int) _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
6155*6236dae4SAndroid Build Coastguard Worker  if (rval == -1)
6156*6236dae4SAndroid Build Coastguard Worker    {
6157*6236dae4SAndroid Build Coastguard Worker      /* failed to start process */
6158*6236dae4SAndroid Build Coastguard Worker      lt_debugprintf (__FILE__, __LINE__,
6159*6236dae4SAndroid Build Coastguard Worker		      "(main) failed to launch target \"%s\": %s\n",
6160*6236dae4SAndroid Build Coastguard Worker		      lt_argv_zero, nonnull (strerror (errno)));
6161*6236dae4SAndroid Build Coastguard Worker      return 127;
6162*6236dae4SAndroid Build Coastguard Worker    }
6163*6236dae4SAndroid Build Coastguard Worker  return rval;
6164*6236dae4SAndroid Build Coastguard WorkerEOF
6165*6236dae4SAndroid Build Coastguard Worker		;;
6166*6236dae4SAndroid Build Coastguard Worker	      *)
6167*6236dae4SAndroid Build Coastguard Worker		cat <<"EOF"
6168*6236dae4SAndroid Build Coastguard Worker  execv (lt_argv_zero, newargz);
6169*6236dae4SAndroid Build Coastguard Worker  return rval; /* =127, but avoids unused variable warning */
6170*6236dae4SAndroid Build Coastguard WorkerEOF
6171*6236dae4SAndroid Build Coastguard Worker		;;
6172*6236dae4SAndroid Build Coastguard Worker	    esac
6173*6236dae4SAndroid Build Coastguard Worker
6174*6236dae4SAndroid Build Coastguard Worker	    cat <<"EOF"
6175*6236dae4SAndroid Build Coastguard Worker}
6176*6236dae4SAndroid Build Coastguard Worker
6177*6236dae4SAndroid Build Coastguard Workervoid *
6178*6236dae4SAndroid Build Coastguard Workerxmalloc (size_t num)
6179*6236dae4SAndroid Build Coastguard Worker{
6180*6236dae4SAndroid Build Coastguard Worker  void *p = (void *) malloc (num);
6181*6236dae4SAndroid Build Coastguard Worker  if (!p)
6182*6236dae4SAndroid Build Coastguard Worker    lt_fatal (__FILE__, __LINE__, "memory exhausted");
6183*6236dae4SAndroid Build Coastguard Worker
6184*6236dae4SAndroid Build Coastguard Worker  return p;
6185*6236dae4SAndroid Build Coastguard Worker}
6186*6236dae4SAndroid Build Coastguard Worker
6187*6236dae4SAndroid Build Coastguard Workerchar *
6188*6236dae4SAndroid Build Coastguard Workerxstrdup (const char *string)
6189*6236dae4SAndroid Build Coastguard Worker{
6190*6236dae4SAndroid Build Coastguard Worker  return string ? strcpy ((char *) xmalloc (strlen (string) + 1),
6191*6236dae4SAndroid Build Coastguard Worker			  string) : NULL;
6192*6236dae4SAndroid Build Coastguard Worker}
6193*6236dae4SAndroid Build Coastguard Worker
6194*6236dae4SAndroid Build Coastguard Workerconst char *
6195*6236dae4SAndroid Build Coastguard Workerbase_name (const char *name)
6196*6236dae4SAndroid Build Coastguard Worker{
6197*6236dae4SAndroid Build Coastguard Worker  const char *base;
6198*6236dae4SAndroid Build Coastguard Worker
6199*6236dae4SAndroid Build Coastguard Worker#if defined HAVE_DOS_BASED_FILE_SYSTEM
6200*6236dae4SAndroid Build Coastguard Worker  /* Skip over the disk name in MSDOS pathnames. */
6201*6236dae4SAndroid Build Coastguard Worker  if (isalpha ((unsigned char) name[0]) && name[1] == ':')
6202*6236dae4SAndroid Build Coastguard Worker    name += 2;
6203*6236dae4SAndroid Build Coastguard Worker#endif
6204*6236dae4SAndroid Build Coastguard Worker
6205*6236dae4SAndroid Build Coastguard Worker  for (base = name; *name; name++)
6206*6236dae4SAndroid Build Coastguard Worker    if (IS_DIR_SEPARATOR (*name))
6207*6236dae4SAndroid Build Coastguard Worker      base = name + 1;
6208*6236dae4SAndroid Build Coastguard Worker  return base;
6209*6236dae4SAndroid Build Coastguard Worker}
6210*6236dae4SAndroid Build Coastguard Worker
6211*6236dae4SAndroid Build Coastguard Workerint
6212*6236dae4SAndroid Build Coastguard Workercheck_executable (const char *path)
6213*6236dae4SAndroid Build Coastguard Worker{
6214*6236dae4SAndroid Build Coastguard Worker  struct stat st;
6215*6236dae4SAndroid Build Coastguard Worker
6216*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__, "(check_executable): %s\n",
6217*6236dae4SAndroid Build Coastguard Worker                  nonempty (path));
6218*6236dae4SAndroid Build Coastguard Worker  if ((!path) || (!*path))
6219*6236dae4SAndroid Build Coastguard Worker    return 0;
6220*6236dae4SAndroid Build Coastguard Worker
6221*6236dae4SAndroid Build Coastguard Worker  if ((stat (path, &st) >= 0)
6222*6236dae4SAndroid Build Coastguard Worker      && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH)))
6223*6236dae4SAndroid Build Coastguard Worker    return 1;
6224*6236dae4SAndroid Build Coastguard Worker  else
6225*6236dae4SAndroid Build Coastguard Worker    return 0;
6226*6236dae4SAndroid Build Coastguard Worker}
6227*6236dae4SAndroid Build Coastguard Worker
6228*6236dae4SAndroid Build Coastguard Workerint
6229*6236dae4SAndroid Build Coastguard Workermake_executable (const char *path)
6230*6236dae4SAndroid Build Coastguard Worker{
6231*6236dae4SAndroid Build Coastguard Worker  int rval = 0;
6232*6236dae4SAndroid Build Coastguard Worker  struct stat st;
6233*6236dae4SAndroid Build Coastguard Worker
6234*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n",
6235*6236dae4SAndroid Build Coastguard Worker                  nonempty (path));
6236*6236dae4SAndroid Build Coastguard Worker  if ((!path) || (!*path))
6237*6236dae4SAndroid Build Coastguard Worker    return 0;
6238*6236dae4SAndroid Build Coastguard Worker
6239*6236dae4SAndroid Build Coastguard Worker  if (stat (path, &st) >= 0)
6240*6236dae4SAndroid Build Coastguard Worker    {
6241*6236dae4SAndroid Build Coastguard Worker      rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR);
6242*6236dae4SAndroid Build Coastguard Worker    }
6243*6236dae4SAndroid Build Coastguard Worker  return rval;
6244*6236dae4SAndroid Build Coastguard Worker}
6245*6236dae4SAndroid Build Coastguard Worker
6246*6236dae4SAndroid Build Coastguard Worker/* Searches for the full path of the wrapper.  Returns
6247*6236dae4SAndroid Build Coastguard Worker   newly allocated full path name if found, NULL otherwise
6248*6236dae4SAndroid Build Coastguard Worker   Does not chase symlinks, even on platforms that support them.
6249*6236dae4SAndroid Build Coastguard Worker*/
6250*6236dae4SAndroid Build Coastguard Workerchar *
6251*6236dae4SAndroid Build Coastguard Workerfind_executable (const char *wrapper)
6252*6236dae4SAndroid Build Coastguard Worker{
6253*6236dae4SAndroid Build Coastguard Worker  int has_slash = 0;
6254*6236dae4SAndroid Build Coastguard Worker  const char *p;
6255*6236dae4SAndroid Build Coastguard Worker  const char *p_next;
6256*6236dae4SAndroid Build Coastguard Worker  /* static buffer for getcwd */
6257*6236dae4SAndroid Build Coastguard Worker  char tmp[LT_PATHMAX + 1];
6258*6236dae4SAndroid Build Coastguard Worker  size_t tmp_len;
6259*6236dae4SAndroid Build Coastguard Worker  char *concat_name;
6260*6236dae4SAndroid Build Coastguard Worker
6261*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n",
6262*6236dae4SAndroid Build Coastguard Worker                  nonempty (wrapper));
6263*6236dae4SAndroid Build Coastguard Worker
6264*6236dae4SAndroid Build Coastguard Worker  if ((wrapper == NULL) || (*wrapper == '\0'))
6265*6236dae4SAndroid Build Coastguard Worker    return NULL;
6266*6236dae4SAndroid Build Coastguard Worker
6267*6236dae4SAndroid Build Coastguard Worker  /* Absolute path? */
6268*6236dae4SAndroid Build Coastguard Worker#if defined HAVE_DOS_BASED_FILE_SYSTEM
6269*6236dae4SAndroid Build Coastguard Worker  if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':')
6270*6236dae4SAndroid Build Coastguard Worker    {
6271*6236dae4SAndroid Build Coastguard Worker      concat_name = xstrdup (wrapper);
6272*6236dae4SAndroid Build Coastguard Worker      if (check_executable (concat_name))
6273*6236dae4SAndroid Build Coastguard Worker	return concat_name;
6274*6236dae4SAndroid Build Coastguard Worker      XFREE (concat_name);
6275*6236dae4SAndroid Build Coastguard Worker    }
6276*6236dae4SAndroid Build Coastguard Worker  else
6277*6236dae4SAndroid Build Coastguard Worker    {
6278*6236dae4SAndroid Build Coastguard Worker#endif
6279*6236dae4SAndroid Build Coastguard Worker      if (IS_DIR_SEPARATOR (wrapper[0]))
6280*6236dae4SAndroid Build Coastguard Worker	{
6281*6236dae4SAndroid Build Coastguard Worker	  concat_name = xstrdup (wrapper);
6282*6236dae4SAndroid Build Coastguard Worker	  if (check_executable (concat_name))
6283*6236dae4SAndroid Build Coastguard Worker	    return concat_name;
6284*6236dae4SAndroid Build Coastguard Worker	  XFREE (concat_name);
6285*6236dae4SAndroid Build Coastguard Worker	}
6286*6236dae4SAndroid Build Coastguard Worker#if defined HAVE_DOS_BASED_FILE_SYSTEM
6287*6236dae4SAndroid Build Coastguard Worker    }
6288*6236dae4SAndroid Build Coastguard Worker#endif
6289*6236dae4SAndroid Build Coastguard Worker
6290*6236dae4SAndroid Build Coastguard Worker  for (p = wrapper; *p; p++)
6291*6236dae4SAndroid Build Coastguard Worker    if (*p == '/')
6292*6236dae4SAndroid Build Coastguard Worker      {
6293*6236dae4SAndroid Build Coastguard Worker	has_slash = 1;
6294*6236dae4SAndroid Build Coastguard Worker	break;
6295*6236dae4SAndroid Build Coastguard Worker      }
6296*6236dae4SAndroid Build Coastguard Worker  if (!has_slash)
6297*6236dae4SAndroid Build Coastguard Worker    {
6298*6236dae4SAndroid Build Coastguard Worker      /* no slashes; search PATH */
6299*6236dae4SAndroid Build Coastguard Worker      const char *path = getenv ("PATH");
6300*6236dae4SAndroid Build Coastguard Worker      if (path != NULL)
6301*6236dae4SAndroid Build Coastguard Worker	{
6302*6236dae4SAndroid Build Coastguard Worker	  for (p = path; *p; p = p_next)
6303*6236dae4SAndroid Build Coastguard Worker	    {
6304*6236dae4SAndroid Build Coastguard Worker	      const char *q;
6305*6236dae4SAndroid Build Coastguard Worker	      size_t p_len;
6306*6236dae4SAndroid Build Coastguard Worker	      for (q = p; *q; q++)
6307*6236dae4SAndroid Build Coastguard Worker		if (IS_PATH_SEPARATOR (*q))
6308*6236dae4SAndroid Build Coastguard Worker		  break;
6309*6236dae4SAndroid Build Coastguard Worker	      p_len = (size_t) (q - p);
6310*6236dae4SAndroid Build Coastguard Worker	      p_next = (*q == '\0' ? q : q + 1);
6311*6236dae4SAndroid Build Coastguard Worker	      if (p_len == 0)
6312*6236dae4SAndroid Build Coastguard Worker		{
6313*6236dae4SAndroid Build Coastguard Worker		  /* empty path: current directory */
6314*6236dae4SAndroid Build Coastguard Worker		  if (getcwd (tmp, LT_PATHMAX) == NULL)
6315*6236dae4SAndroid Build Coastguard Worker		    lt_fatal (__FILE__, __LINE__, "getcwd failed: %s",
6316*6236dae4SAndroid Build Coastguard Worker                              nonnull (strerror (errno)));
6317*6236dae4SAndroid Build Coastguard Worker		  tmp_len = strlen (tmp);
6318*6236dae4SAndroid Build Coastguard Worker		  concat_name =
6319*6236dae4SAndroid Build Coastguard Worker		    XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1);
6320*6236dae4SAndroid Build Coastguard Worker		  memcpy (concat_name, tmp, tmp_len);
6321*6236dae4SAndroid Build Coastguard Worker		  concat_name[tmp_len] = '/';
6322*6236dae4SAndroid Build Coastguard Worker		  strcpy (concat_name + tmp_len + 1, wrapper);
6323*6236dae4SAndroid Build Coastguard Worker		}
6324*6236dae4SAndroid Build Coastguard Worker	      else
6325*6236dae4SAndroid Build Coastguard Worker		{
6326*6236dae4SAndroid Build Coastguard Worker		  concat_name =
6327*6236dae4SAndroid Build Coastguard Worker		    XMALLOC (char, p_len + 1 + strlen (wrapper) + 1);
6328*6236dae4SAndroid Build Coastguard Worker		  memcpy (concat_name, p, p_len);
6329*6236dae4SAndroid Build Coastguard Worker		  concat_name[p_len] = '/';
6330*6236dae4SAndroid Build Coastguard Worker		  strcpy (concat_name + p_len + 1, wrapper);
6331*6236dae4SAndroid Build Coastguard Worker		}
6332*6236dae4SAndroid Build Coastguard Worker	      if (check_executable (concat_name))
6333*6236dae4SAndroid Build Coastguard Worker		return concat_name;
6334*6236dae4SAndroid Build Coastguard Worker	      XFREE (concat_name);
6335*6236dae4SAndroid Build Coastguard Worker	    }
6336*6236dae4SAndroid Build Coastguard Worker	}
6337*6236dae4SAndroid Build Coastguard Worker      /* not found in PATH; assume curdir */
6338*6236dae4SAndroid Build Coastguard Worker    }
6339*6236dae4SAndroid Build Coastguard Worker  /* Relative path | not found in path: prepend cwd */
6340*6236dae4SAndroid Build Coastguard Worker  if (getcwd (tmp, LT_PATHMAX) == NULL)
6341*6236dae4SAndroid Build Coastguard Worker    lt_fatal (__FILE__, __LINE__, "getcwd failed: %s",
6342*6236dae4SAndroid Build Coastguard Worker              nonnull (strerror (errno)));
6343*6236dae4SAndroid Build Coastguard Worker  tmp_len = strlen (tmp);
6344*6236dae4SAndroid Build Coastguard Worker  concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1);
6345*6236dae4SAndroid Build Coastguard Worker  memcpy (concat_name, tmp, tmp_len);
6346*6236dae4SAndroid Build Coastguard Worker  concat_name[tmp_len] = '/';
6347*6236dae4SAndroid Build Coastguard Worker  strcpy (concat_name + tmp_len + 1, wrapper);
6348*6236dae4SAndroid Build Coastguard Worker
6349*6236dae4SAndroid Build Coastguard Worker  if (check_executable (concat_name))
6350*6236dae4SAndroid Build Coastguard Worker    return concat_name;
6351*6236dae4SAndroid Build Coastguard Worker  XFREE (concat_name);
6352*6236dae4SAndroid Build Coastguard Worker  return NULL;
6353*6236dae4SAndroid Build Coastguard Worker}
6354*6236dae4SAndroid Build Coastguard Worker
6355*6236dae4SAndroid Build Coastguard Workerchar *
6356*6236dae4SAndroid Build Coastguard Workerchase_symlinks (const char *pathspec)
6357*6236dae4SAndroid Build Coastguard Worker{
6358*6236dae4SAndroid Build Coastguard Worker#ifndef S_ISLNK
6359*6236dae4SAndroid Build Coastguard Worker  return xstrdup (pathspec);
6360*6236dae4SAndroid Build Coastguard Worker#else
6361*6236dae4SAndroid Build Coastguard Worker  char buf[LT_PATHMAX];
6362*6236dae4SAndroid Build Coastguard Worker  struct stat s;
6363*6236dae4SAndroid Build Coastguard Worker  char *tmp_pathspec = xstrdup (pathspec);
6364*6236dae4SAndroid Build Coastguard Worker  char *p;
6365*6236dae4SAndroid Build Coastguard Worker  int has_symlinks = 0;
6366*6236dae4SAndroid Build Coastguard Worker  while (strlen (tmp_pathspec) && !has_symlinks)
6367*6236dae4SAndroid Build Coastguard Worker    {
6368*6236dae4SAndroid Build Coastguard Worker      lt_debugprintf (__FILE__, __LINE__,
6369*6236dae4SAndroid Build Coastguard Worker		      "checking path component for symlinks: %s\n",
6370*6236dae4SAndroid Build Coastguard Worker		      tmp_pathspec);
6371*6236dae4SAndroid Build Coastguard Worker      if (lstat (tmp_pathspec, &s) == 0)
6372*6236dae4SAndroid Build Coastguard Worker	{
6373*6236dae4SAndroid Build Coastguard Worker	  if (S_ISLNK (s.st_mode) != 0)
6374*6236dae4SAndroid Build Coastguard Worker	    {
6375*6236dae4SAndroid Build Coastguard Worker	      has_symlinks = 1;
6376*6236dae4SAndroid Build Coastguard Worker	      break;
6377*6236dae4SAndroid Build Coastguard Worker	    }
6378*6236dae4SAndroid Build Coastguard Worker
6379*6236dae4SAndroid Build Coastguard Worker	  /* search backwards for last DIR_SEPARATOR */
6380*6236dae4SAndroid Build Coastguard Worker	  p = tmp_pathspec + strlen (tmp_pathspec) - 1;
6381*6236dae4SAndroid Build Coastguard Worker	  while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p)))
6382*6236dae4SAndroid Build Coastguard Worker	    p--;
6383*6236dae4SAndroid Build Coastguard Worker	  if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p)))
6384*6236dae4SAndroid Build Coastguard Worker	    {
6385*6236dae4SAndroid Build Coastguard Worker	      /* no more DIR_SEPARATORS left */
6386*6236dae4SAndroid Build Coastguard Worker	      break;
6387*6236dae4SAndroid Build Coastguard Worker	    }
6388*6236dae4SAndroid Build Coastguard Worker	  *p = '\0';
6389*6236dae4SAndroid Build Coastguard Worker	}
6390*6236dae4SAndroid Build Coastguard Worker      else
6391*6236dae4SAndroid Build Coastguard Worker	{
6392*6236dae4SAndroid Build Coastguard Worker	  lt_fatal (__FILE__, __LINE__,
6393*6236dae4SAndroid Build Coastguard Worker		    "error accessing file \"%s\": %s",
6394*6236dae4SAndroid Build Coastguard Worker		    tmp_pathspec, nonnull (strerror (errno)));
6395*6236dae4SAndroid Build Coastguard Worker	}
6396*6236dae4SAndroid Build Coastguard Worker    }
6397*6236dae4SAndroid Build Coastguard Worker  XFREE (tmp_pathspec);
6398*6236dae4SAndroid Build Coastguard Worker
6399*6236dae4SAndroid Build Coastguard Worker  if (!has_symlinks)
6400*6236dae4SAndroid Build Coastguard Worker    {
6401*6236dae4SAndroid Build Coastguard Worker      return xstrdup (pathspec);
6402*6236dae4SAndroid Build Coastguard Worker    }
6403*6236dae4SAndroid Build Coastguard Worker
6404*6236dae4SAndroid Build Coastguard Worker  tmp_pathspec = realpath (pathspec, buf);
6405*6236dae4SAndroid Build Coastguard Worker  if (tmp_pathspec == 0)
6406*6236dae4SAndroid Build Coastguard Worker    {
6407*6236dae4SAndroid Build Coastguard Worker      lt_fatal (__FILE__, __LINE__,
6408*6236dae4SAndroid Build Coastguard Worker		"could not follow symlinks for %s", pathspec);
6409*6236dae4SAndroid Build Coastguard Worker    }
6410*6236dae4SAndroid Build Coastguard Worker  return xstrdup (tmp_pathspec);
6411*6236dae4SAndroid Build Coastguard Worker#endif
6412*6236dae4SAndroid Build Coastguard Worker}
6413*6236dae4SAndroid Build Coastguard Worker
6414*6236dae4SAndroid Build Coastguard Workerchar *
6415*6236dae4SAndroid Build Coastguard Workerstrendzap (char *str, const char *pat)
6416*6236dae4SAndroid Build Coastguard Worker{
6417*6236dae4SAndroid Build Coastguard Worker  size_t len, patlen;
6418*6236dae4SAndroid Build Coastguard Worker
6419*6236dae4SAndroid Build Coastguard Worker  assert (str != NULL);
6420*6236dae4SAndroid Build Coastguard Worker  assert (pat != NULL);
6421*6236dae4SAndroid Build Coastguard Worker
6422*6236dae4SAndroid Build Coastguard Worker  len = strlen (str);
6423*6236dae4SAndroid Build Coastguard Worker  patlen = strlen (pat);
6424*6236dae4SAndroid Build Coastguard Worker
6425*6236dae4SAndroid Build Coastguard Worker  if (patlen <= len)
6426*6236dae4SAndroid Build Coastguard Worker    {
6427*6236dae4SAndroid Build Coastguard Worker      str += len - patlen;
6428*6236dae4SAndroid Build Coastguard Worker      if (STREQ (str, pat))
6429*6236dae4SAndroid Build Coastguard Worker	*str = '\0';
6430*6236dae4SAndroid Build Coastguard Worker    }
6431*6236dae4SAndroid Build Coastguard Worker  return str;
6432*6236dae4SAndroid Build Coastguard Worker}
6433*6236dae4SAndroid Build Coastguard Worker
6434*6236dae4SAndroid Build Coastguard Workervoid
6435*6236dae4SAndroid Build Coastguard Workerlt_debugprintf (const char *file, int line, const char *fmt, ...)
6436*6236dae4SAndroid Build Coastguard Worker{
6437*6236dae4SAndroid Build Coastguard Worker  va_list args;
6438*6236dae4SAndroid Build Coastguard Worker  if (lt_debug)
6439*6236dae4SAndroid Build Coastguard Worker    {
6440*6236dae4SAndroid Build Coastguard Worker      (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line);
6441*6236dae4SAndroid Build Coastguard Worker      va_start (args, fmt);
6442*6236dae4SAndroid Build Coastguard Worker      (void) vfprintf (stderr, fmt, args);
6443*6236dae4SAndroid Build Coastguard Worker      va_end (args);
6444*6236dae4SAndroid Build Coastguard Worker    }
6445*6236dae4SAndroid Build Coastguard Worker}
6446*6236dae4SAndroid Build Coastguard Worker
6447*6236dae4SAndroid Build Coastguard Workerstatic void
6448*6236dae4SAndroid Build Coastguard Workerlt_error_core (int exit_status, const char *file,
6449*6236dae4SAndroid Build Coastguard Worker	       int line, const char *mode,
6450*6236dae4SAndroid Build Coastguard Worker	       const char *message, va_list ap)
6451*6236dae4SAndroid Build Coastguard Worker{
6452*6236dae4SAndroid Build Coastguard Worker  fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode);
6453*6236dae4SAndroid Build Coastguard Worker  vfprintf (stderr, message, ap);
6454*6236dae4SAndroid Build Coastguard Worker  fprintf (stderr, ".\n");
6455*6236dae4SAndroid Build Coastguard Worker
6456*6236dae4SAndroid Build Coastguard Worker  if (exit_status >= 0)
6457*6236dae4SAndroid Build Coastguard Worker    exit (exit_status);
6458*6236dae4SAndroid Build Coastguard Worker}
6459*6236dae4SAndroid Build Coastguard Worker
6460*6236dae4SAndroid Build Coastguard Workervoid
6461*6236dae4SAndroid Build Coastguard Workerlt_fatal (const char *file, int line, const char *message, ...)
6462*6236dae4SAndroid Build Coastguard Worker{
6463*6236dae4SAndroid Build Coastguard Worker  va_list ap;
6464*6236dae4SAndroid Build Coastguard Worker  va_start (ap, message);
6465*6236dae4SAndroid Build Coastguard Worker  lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap);
6466*6236dae4SAndroid Build Coastguard Worker  va_end (ap);
6467*6236dae4SAndroid Build Coastguard Worker}
6468*6236dae4SAndroid Build Coastguard Worker
6469*6236dae4SAndroid Build Coastguard Workerstatic const char *
6470*6236dae4SAndroid Build Coastguard Workernonnull (const char *s)
6471*6236dae4SAndroid Build Coastguard Worker{
6472*6236dae4SAndroid Build Coastguard Worker  return s ? s : "(null)";
6473*6236dae4SAndroid Build Coastguard Worker}
6474*6236dae4SAndroid Build Coastguard Worker
6475*6236dae4SAndroid Build Coastguard Workerstatic const char *
6476*6236dae4SAndroid Build Coastguard Workernonempty (const char *s)
6477*6236dae4SAndroid Build Coastguard Worker{
6478*6236dae4SAndroid Build Coastguard Worker  return (s && !*s) ? "(empty)" : nonnull (s);
6479*6236dae4SAndroid Build Coastguard Worker}
6480*6236dae4SAndroid Build Coastguard Worker
6481*6236dae4SAndroid Build Coastguard Workervoid
6482*6236dae4SAndroid Build Coastguard Workerlt_setenv (const char *name, const char *value)
6483*6236dae4SAndroid Build Coastguard Worker{
6484*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__,
6485*6236dae4SAndroid Build Coastguard Worker		  "(lt_setenv) setting '%s' to '%s'\n",
6486*6236dae4SAndroid Build Coastguard Worker                  nonnull (name), nonnull (value));
6487*6236dae4SAndroid Build Coastguard Worker  {
6488*6236dae4SAndroid Build Coastguard Worker#ifdef HAVE_SETENV
6489*6236dae4SAndroid Build Coastguard Worker    /* always make a copy, for consistency with !HAVE_SETENV */
6490*6236dae4SAndroid Build Coastguard Worker    char *str = xstrdup (value);
6491*6236dae4SAndroid Build Coastguard Worker    setenv (name, str, 1);
6492*6236dae4SAndroid Build Coastguard Worker#else
6493*6236dae4SAndroid Build Coastguard Worker    size_t len = strlen (name) + 1 + strlen (value) + 1;
6494*6236dae4SAndroid Build Coastguard Worker    char *str = XMALLOC (char, len);
6495*6236dae4SAndroid Build Coastguard Worker    sprintf (str, "%s=%s", name, value);
6496*6236dae4SAndroid Build Coastguard Worker    if (putenv (str) != EXIT_SUCCESS)
6497*6236dae4SAndroid Build Coastguard Worker      {
6498*6236dae4SAndroid Build Coastguard Worker        XFREE (str);
6499*6236dae4SAndroid Build Coastguard Worker      }
6500*6236dae4SAndroid Build Coastguard Worker#endif
6501*6236dae4SAndroid Build Coastguard Worker  }
6502*6236dae4SAndroid Build Coastguard Worker}
6503*6236dae4SAndroid Build Coastguard Worker
6504*6236dae4SAndroid Build Coastguard Workerchar *
6505*6236dae4SAndroid Build Coastguard Workerlt_extend_str (const char *orig_value, const char *add, int to_end)
6506*6236dae4SAndroid Build Coastguard Worker{
6507*6236dae4SAndroid Build Coastguard Worker  char *new_value;
6508*6236dae4SAndroid Build Coastguard Worker  if (orig_value && *orig_value)
6509*6236dae4SAndroid Build Coastguard Worker    {
6510*6236dae4SAndroid Build Coastguard Worker      size_t orig_value_len = strlen (orig_value);
6511*6236dae4SAndroid Build Coastguard Worker      size_t add_len = strlen (add);
6512*6236dae4SAndroid Build Coastguard Worker      new_value = XMALLOC (char, add_len + orig_value_len + 1);
6513*6236dae4SAndroid Build Coastguard Worker      if (to_end)
6514*6236dae4SAndroid Build Coastguard Worker        {
6515*6236dae4SAndroid Build Coastguard Worker          strcpy (new_value, orig_value);
6516*6236dae4SAndroid Build Coastguard Worker          strcpy (new_value + orig_value_len, add);
6517*6236dae4SAndroid Build Coastguard Worker        }
6518*6236dae4SAndroid Build Coastguard Worker      else
6519*6236dae4SAndroid Build Coastguard Worker        {
6520*6236dae4SAndroid Build Coastguard Worker          strcpy (new_value, add);
6521*6236dae4SAndroid Build Coastguard Worker          strcpy (new_value + add_len, orig_value);
6522*6236dae4SAndroid Build Coastguard Worker        }
6523*6236dae4SAndroid Build Coastguard Worker    }
6524*6236dae4SAndroid Build Coastguard Worker  else
6525*6236dae4SAndroid Build Coastguard Worker    {
6526*6236dae4SAndroid Build Coastguard Worker      new_value = xstrdup (add);
6527*6236dae4SAndroid Build Coastguard Worker    }
6528*6236dae4SAndroid Build Coastguard Worker  return new_value;
6529*6236dae4SAndroid Build Coastguard Worker}
6530*6236dae4SAndroid Build Coastguard Worker
6531*6236dae4SAndroid Build Coastguard Workervoid
6532*6236dae4SAndroid Build Coastguard Workerlt_update_exe_path (const char *name, const char *value)
6533*6236dae4SAndroid Build Coastguard Worker{
6534*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__,
6535*6236dae4SAndroid Build Coastguard Worker		  "(lt_update_exe_path) modifying '%s' by prepending '%s'\n",
6536*6236dae4SAndroid Build Coastguard Worker                  nonnull (name), nonnull (value));
6537*6236dae4SAndroid Build Coastguard Worker
6538*6236dae4SAndroid Build Coastguard Worker  if (name && *name && value && *value)
6539*6236dae4SAndroid Build Coastguard Worker    {
6540*6236dae4SAndroid Build Coastguard Worker      char *new_value = lt_extend_str (getenv (name), value, 0);
6541*6236dae4SAndroid Build Coastguard Worker      /* some systems can't cope with a ':'-terminated path #' */
6542*6236dae4SAndroid Build Coastguard Worker      size_t len = strlen (new_value);
6543*6236dae4SAndroid Build Coastguard Worker      while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1]))
6544*6236dae4SAndroid Build Coastguard Worker        {
6545*6236dae4SAndroid Build Coastguard Worker          new_value[--len] = '\0';
6546*6236dae4SAndroid Build Coastguard Worker        }
6547*6236dae4SAndroid Build Coastguard Worker      lt_setenv (name, new_value);
6548*6236dae4SAndroid Build Coastguard Worker      XFREE (new_value);
6549*6236dae4SAndroid Build Coastguard Worker    }
6550*6236dae4SAndroid Build Coastguard Worker}
6551*6236dae4SAndroid Build Coastguard Worker
6552*6236dae4SAndroid Build Coastguard Workervoid
6553*6236dae4SAndroid Build Coastguard Workerlt_update_lib_path (const char *name, const char *value)
6554*6236dae4SAndroid Build Coastguard Worker{
6555*6236dae4SAndroid Build Coastguard Worker  lt_debugprintf (__FILE__, __LINE__,
6556*6236dae4SAndroid Build Coastguard Worker		  "(lt_update_lib_path) modifying '%s' by prepending '%s'\n",
6557*6236dae4SAndroid Build Coastguard Worker                  nonnull (name), nonnull (value));
6558*6236dae4SAndroid Build Coastguard Worker
6559*6236dae4SAndroid Build Coastguard Worker  if (name && *name && value && *value)
6560*6236dae4SAndroid Build Coastguard Worker    {
6561*6236dae4SAndroid Build Coastguard Worker      char *new_value = lt_extend_str (getenv (name), value, 0);
6562*6236dae4SAndroid Build Coastguard Worker      lt_setenv (name, new_value);
6563*6236dae4SAndroid Build Coastguard Worker      XFREE (new_value);
6564*6236dae4SAndroid Build Coastguard Worker    }
6565*6236dae4SAndroid Build Coastguard Worker}
6566*6236dae4SAndroid Build Coastguard Worker
6567*6236dae4SAndroid Build Coastguard WorkerEOF
6568*6236dae4SAndroid Build Coastguard Worker	    case $host_os in
6569*6236dae4SAndroid Build Coastguard Worker	      mingw*)
6570*6236dae4SAndroid Build Coastguard Worker		cat <<"EOF"
6571*6236dae4SAndroid Build Coastguard Worker
6572*6236dae4SAndroid Build Coastguard Worker/* Prepares an argument vector before calling spawn().
6573*6236dae4SAndroid Build Coastguard Worker   Note that spawn() does not by itself call the command interpreter
6574*6236dae4SAndroid Build Coastguard Worker     (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") :
6575*6236dae4SAndroid Build Coastguard Worker      ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
6576*6236dae4SAndroid Build Coastguard Worker         GetVersionEx(&v);
6577*6236dae4SAndroid Build Coastguard Worker         v.dwPlatformId == VER_PLATFORM_WIN32_NT;
6578*6236dae4SAndroid Build Coastguard Worker      }) ? "cmd.exe" : "command.com").
6579*6236dae4SAndroid Build Coastguard Worker   Instead it simply concatenates the arguments, separated by ' ', and calls
6580*6236dae4SAndroid Build Coastguard Worker   CreateProcess().  We must quote the arguments since Win32 CreateProcess()
6581*6236dae4SAndroid Build Coastguard Worker   interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a
6582*6236dae4SAndroid Build Coastguard Worker   special way:
6583*6236dae4SAndroid Build Coastguard Worker   - Space and tab are interpreted as delimiters. They are not treated as
6584*6236dae4SAndroid Build Coastguard Worker     delimiters if they are surrounded by double quotes: "...".
6585*6236dae4SAndroid Build Coastguard Worker   - Unescaped double quotes are removed from the input. Their only effect is
6586*6236dae4SAndroid Build Coastguard Worker     that within double quotes, space and tab are treated like normal
6587*6236dae4SAndroid Build Coastguard Worker     characters.
6588*6236dae4SAndroid Build Coastguard Worker   - Backslashes not followed by double quotes are not special.
6589*6236dae4SAndroid Build Coastguard Worker   - But 2*n+1 backslashes followed by a double quote become
6590*6236dae4SAndroid Build Coastguard Worker     n backslashes followed by a double quote (n >= 0):
6591*6236dae4SAndroid Build Coastguard Worker       \" -> "
6592*6236dae4SAndroid Build Coastguard Worker       \\\" -> \"
6593*6236dae4SAndroid Build Coastguard Worker       \\\\\" -> \\"
6594*6236dae4SAndroid Build Coastguard Worker */
6595*6236dae4SAndroid Build Coastguard Worker#define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037"
6596*6236dae4SAndroid Build Coastguard Worker#define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037"
6597*6236dae4SAndroid Build Coastguard Workerchar **
6598*6236dae4SAndroid Build Coastguard Workerprepare_spawn (char **argv)
6599*6236dae4SAndroid Build Coastguard Worker{
6600*6236dae4SAndroid Build Coastguard Worker  size_t argc;
6601*6236dae4SAndroid Build Coastguard Worker  char **new_argv;
6602*6236dae4SAndroid Build Coastguard Worker  size_t i;
6603*6236dae4SAndroid Build Coastguard Worker
6604*6236dae4SAndroid Build Coastguard Worker  /* Count number of arguments.  */
6605*6236dae4SAndroid Build Coastguard Worker  for (argc = 0; argv[argc] != NULL; argc++)
6606*6236dae4SAndroid Build Coastguard Worker    ;
6607*6236dae4SAndroid Build Coastguard Worker
6608*6236dae4SAndroid Build Coastguard Worker  /* Allocate new argument vector.  */
6609*6236dae4SAndroid Build Coastguard Worker  new_argv = XMALLOC (char *, argc + 1);
6610*6236dae4SAndroid Build Coastguard Worker
6611*6236dae4SAndroid Build Coastguard Worker  /* Put quoted arguments into the new argument vector.  */
6612*6236dae4SAndroid Build Coastguard Worker  for (i = 0; i < argc; i++)
6613*6236dae4SAndroid Build Coastguard Worker    {
6614*6236dae4SAndroid Build Coastguard Worker      const char *string = argv[i];
6615*6236dae4SAndroid Build Coastguard Worker
6616*6236dae4SAndroid Build Coastguard Worker      if (string[0] == '\0')
6617*6236dae4SAndroid Build Coastguard Worker	new_argv[i] = xstrdup ("\"\"");
6618*6236dae4SAndroid Build Coastguard Worker      else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL)
6619*6236dae4SAndroid Build Coastguard Worker	{
6620*6236dae4SAndroid Build Coastguard Worker	  int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL);
6621*6236dae4SAndroid Build Coastguard Worker	  size_t length;
6622*6236dae4SAndroid Build Coastguard Worker	  unsigned int backslashes;
6623*6236dae4SAndroid Build Coastguard Worker	  const char *s;
6624*6236dae4SAndroid Build Coastguard Worker	  char *quoted_string;
6625*6236dae4SAndroid Build Coastguard Worker	  char *p;
6626*6236dae4SAndroid Build Coastguard Worker
6627*6236dae4SAndroid Build Coastguard Worker	  length = 0;
6628*6236dae4SAndroid Build Coastguard Worker	  backslashes = 0;
6629*6236dae4SAndroid Build Coastguard Worker	  if (quote_around)
6630*6236dae4SAndroid Build Coastguard Worker	    length++;
6631*6236dae4SAndroid Build Coastguard Worker	  for (s = string; *s != '\0'; s++)
6632*6236dae4SAndroid Build Coastguard Worker	    {
6633*6236dae4SAndroid Build Coastguard Worker	      char c = *s;
6634*6236dae4SAndroid Build Coastguard Worker	      if (c == '"')
6635*6236dae4SAndroid Build Coastguard Worker		length += backslashes + 1;
6636*6236dae4SAndroid Build Coastguard Worker	      length++;
6637*6236dae4SAndroid Build Coastguard Worker	      if (c == '\\')
6638*6236dae4SAndroid Build Coastguard Worker		backslashes++;
6639*6236dae4SAndroid Build Coastguard Worker	      else
6640*6236dae4SAndroid Build Coastguard Worker		backslashes = 0;
6641*6236dae4SAndroid Build Coastguard Worker	    }
6642*6236dae4SAndroid Build Coastguard Worker	  if (quote_around)
6643*6236dae4SAndroid Build Coastguard Worker	    length += backslashes + 1;
6644*6236dae4SAndroid Build Coastguard Worker
6645*6236dae4SAndroid Build Coastguard Worker	  quoted_string = XMALLOC (char, length + 1);
6646*6236dae4SAndroid Build Coastguard Worker
6647*6236dae4SAndroid Build Coastguard Worker	  p = quoted_string;
6648*6236dae4SAndroid Build Coastguard Worker	  backslashes = 0;
6649*6236dae4SAndroid Build Coastguard Worker	  if (quote_around)
6650*6236dae4SAndroid Build Coastguard Worker	    *p++ = '"';
6651*6236dae4SAndroid Build Coastguard Worker	  for (s = string; *s != '\0'; s++)
6652*6236dae4SAndroid Build Coastguard Worker	    {
6653*6236dae4SAndroid Build Coastguard Worker	      char c = *s;
6654*6236dae4SAndroid Build Coastguard Worker	      if (c == '"')
6655*6236dae4SAndroid Build Coastguard Worker		{
6656*6236dae4SAndroid Build Coastguard Worker		  unsigned int j;
6657*6236dae4SAndroid Build Coastguard Worker		  for (j = backslashes + 1; j > 0; j--)
6658*6236dae4SAndroid Build Coastguard Worker		    *p++ = '\\';
6659*6236dae4SAndroid Build Coastguard Worker		}
6660*6236dae4SAndroid Build Coastguard Worker	      *p++ = c;
6661*6236dae4SAndroid Build Coastguard Worker	      if (c == '\\')
6662*6236dae4SAndroid Build Coastguard Worker		backslashes++;
6663*6236dae4SAndroid Build Coastguard Worker	      else
6664*6236dae4SAndroid Build Coastguard Worker		backslashes = 0;
6665*6236dae4SAndroid Build Coastguard Worker	    }
6666*6236dae4SAndroid Build Coastguard Worker	  if (quote_around)
6667*6236dae4SAndroid Build Coastguard Worker	    {
6668*6236dae4SAndroid Build Coastguard Worker	      unsigned int j;
6669*6236dae4SAndroid Build Coastguard Worker	      for (j = backslashes; j > 0; j--)
6670*6236dae4SAndroid Build Coastguard Worker		*p++ = '\\';
6671*6236dae4SAndroid Build Coastguard Worker	      *p++ = '"';
6672*6236dae4SAndroid Build Coastguard Worker	    }
6673*6236dae4SAndroid Build Coastguard Worker	  *p = '\0';
6674*6236dae4SAndroid Build Coastguard Worker
6675*6236dae4SAndroid Build Coastguard Worker	  new_argv[i] = quoted_string;
6676*6236dae4SAndroid Build Coastguard Worker	}
6677*6236dae4SAndroid Build Coastguard Worker      else
6678*6236dae4SAndroid Build Coastguard Worker	new_argv[i] = (char *) string;
6679*6236dae4SAndroid Build Coastguard Worker    }
6680*6236dae4SAndroid Build Coastguard Worker  new_argv[argc] = NULL;
6681*6236dae4SAndroid Build Coastguard Worker
6682*6236dae4SAndroid Build Coastguard Worker  return new_argv;
6683*6236dae4SAndroid Build Coastguard Worker}
6684*6236dae4SAndroid Build Coastguard WorkerEOF
6685*6236dae4SAndroid Build Coastguard Worker		;;
6686*6236dae4SAndroid Build Coastguard Worker	    esac
6687*6236dae4SAndroid Build Coastguard Worker
6688*6236dae4SAndroid Build Coastguard Worker            cat <<"EOF"
6689*6236dae4SAndroid Build Coastguard Workervoid lt_dump_script (FILE* f)
6690*6236dae4SAndroid Build Coastguard Worker{
6691*6236dae4SAndroid Build Coastguard WorkerEOF
6692*6236dae4SAndroid Build Coastguard Worker	    func_emit_wrapper yes |
6693*6236dae4SAndroid Build Coastguard Worker	      $SED -n -e '
6694*6236dae4SAndroid Build Coastguard Workers/^\(.\{79\}\)\(..*\)/\1\
6695*6236dae4SAndroid Build Coastguard Worker\2/
6696*6236dae4SAndroid Build Coastguard Workerh
6697*6236dae4SAndroid Build Coastguard Workers/\([\\"]\)/\\\1/g
6698*6236dae4SAndroid Build Coastguard Workers/$/\\n/
6699*6236dae4SAndroid Build Coastguard Workers/\([^\n]*\).*/  fputs ("\1", f);/p
6700*6236dae4SAndroid Build Coastguard Workerg
6701*6236dae4SAndroid Build Coastguard WorkerD'
6702*6236dae4SAndroid Build Coastguard Worker            cat <<"EOF"
6703*6236dae4SAndroid Build Coastguard Worker}
6704*6236dae4SAndroid Build Coastguard WorkerEOF
6705*6236dae4SAndroid Build Coastguard Worker}
6706*6236dae4SAndroid Build Coastguard Worker# end: func_emit_cwrapperexe_src
6707*6236dae4SAndroid Build Coastguard Worker
6708*6236dae4SAndroid Build Coastguard Worker# func_win32_import_lib_p ARG
6709*6236dae4SAndroid Build Coastguard Worker# True if ARG is an import lib, as indicated by $file_magic_cmd
6710*6236dae4SAndroid Build Coastguard Workerfunc_win32_import_lib_p ()
6711*6236dae4SAndroid Build Coastguard Worker{
6712*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
6713*6236dae4SAndroid Build Coastguard Worker
6714*6236dae4SAndroid Build Coastguard Worker    case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in
6715*6236dae4SAndroid Build Coastguard Worker    *import*) : ;;
6716*6236dae4SAndroid Build Coastguard Worker    *) false ;;
6717*6236dae4SAndroid Build Coastguard Worker    esac
6718*6236dae4SAndroid Build Coastguard Worker}
6719*6236dae4SAndroid Build Coastguard Worker
6720*6236dae4SAndroid Build Coastguard Worker# func_suncc_cstd_abi
6721*6236dae4SAndroid Build Coastguard Worker# !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!!
6722*6236dae4SAndroid Build Coastguard Worker# Several compiler flags select an ABI that is incompatible with the
6723*6236dae4SAndroid Build Coastguard Worker# Cstd library. Avoid specifying it if any are in CXXFLAGS.
6724*6236dae4SAndroid Build Coastguard Workerfunc_suncc_cstd_abi ()
6725*6236dae4SAndroid Build Coastguard Worker{
6726*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
6727*6236dae4SAndroid Build Coastguard Worker
6728*6236dae4SAndroid Build Coastguard Worker    case " $compile_command " in
6729*6236dae4SAndroid Build Coastguard Worker    *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*)
6730*6236dae4SAndroid Build Coastguard Worker      suncc_use_cstd_abi=no
6731*6236dae4SAndroid Build Coastguard Worker      ;;
6732*6236dae4SAndroid Build Coastguard Worker    *)
6733*6236dae4SAndroid Build Coastguard Worker      suncc_use_cstd_abi=yes
6734*6236dae4SAndroid Build Coastguard Worker      ;;
6735*6236dae4SAndroid Build Coastguard Worker    esac
6736*6236dae4SAndroid Build Coastguard Worker}
6737*6236dae4SAndroid Build Coastguard Worker
6738*6236dae4SAndroid Build Coastguard Worker# func_mode_link arg...
6739*6236dae4SAndroid Build Coastguard Workerfunc_mode_link ()
6740*6236dae4SAndroid Build Coastguard Worker{
6741*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
6742*6236dae4SAndroid Build Coastguard Worker
6743*6236dae4SAndroid Build Coastguard Worker    case $host in
6744*6236dae4SAndroid Build Coastguard Worker    *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
6745*6236dae4SAndroid Build Coastguard Worker      # It is impossible to link a dll without this setting, and
6746*6236dae4SAndroid Build Coastguard Worker      # we shouldn't force the makefile maintainer to figure out
6747*6236dae4SAndroid Build Coastguard Worker      # what system we are compiling for in order to pass an extra
6748*6236dae4SAndroid Build Coastguard Worker      # flag for every libtool invocation.
6749*6236dae4SAndroid Build Coastguard Worker      # allow_undefined=no
6750*6236dae4SAndroid Build Coastguard Worker
6751*6236dae4SAndroid Build Coastguard Worker      # FIXME: Unfortunately, there are problems with the above when trying
6752*6236dae4SAndroid Build Coastguard Worker      # to make a dll that has undefined symbols, in which case not
6753*6236dae4SAndroid Build Coastguard Worker      # even a static library is built.  For now, we need to specify
6754*6236dae4SAndroid Build Coastguard Worker      # -no-undefined on the libtool link line when we can be certain
6755*6236dae4SAndroid Build Coastguard Worker      # that all symbols are satisfied, otherwise we get a static library.
6756*6236dae4SAndroid Build Coastguard Worker      allow_undefined=yes
6757*6236dae4SAndroid Build Coastguard Worker      ;;
6758*6236dae4SAndroid Build Coastguard Worker    *)
6759*6236dae4SAndroid Build Coastguard Worker      allow_undefined=yes
6760*6236dae4SAndroid Build Coastguard Worker      ;;
6761*6236dae4SAndroid Build Coastguard Worker    esac
6762*6236dae4SAndroid Build Coastguard Worker    libtool_args=$nonopt
6763*6236dae4SAndroid Build Coastguard Worker    base_compile="$nonopt $@"
6764*6236dae4SAndroid Build Coastguard Worker    compile_command=$nonopt
6765*6236dae4SAndroid Build Coastguard Worker    finalize_command=$nonopt
6766*6236dae4SAndroid Build Coastguard Worker
6767*6236dae4SAndroid Build Coastguard Worker    compile_rpath=
6768*6236dae4SAndroid Build Coastguard Worker    finalize_rpath=
6769*6236dae4SAndroid Build Coastguard Worker    compile_shlibpath=
6770*6236dae4SAndroid Build Coastguard Worker    finalize_shlibpath=
6771*6236dae4SAndroid Build Coastguard Worker    convenience=
6772*6236dae4SAndroid Build Coastguard Worker    old_convenience=
6773*6236dae4SAndroid Build Coastguard Worker    deplibs=
6774*6236dae4SAndroid Build Coastguard Worker    old_deplibs=
6775*6236dae4SAndroid Build Coastguard Worker    compiler_flags=
6776*6236dae4SAndroid Build Coastguard Worker    linker_flags=
6777*6236dae4SAndroid Build Coastguard Worker    dllsearchpath=
6778*6236dae4SAndroid Build Coastguard Worker    lib_search_path=`pwd`
6779*6236dae4SAndroid Build Coastguard Worker    inst_prefix_dir=
6780*6236dae4SAndroid Build Coastguard Worker    new_inherited_linker_flags=
6781*6236dae4SAndroid Build Coastguard Worker
6782*6236dae4SAndroid Build Coastguard Worker    avoid_version=no
6783*6236dae4SAndroid Build Coastguard Worker    bindir=
6784*6236dae4SAndroid Build Coastguard Worker    dlfiles=
6785*6236dae4SAndroid Build Coastguard Worker    dlprefiles=
6786*6236dae4SAndroid Build Coastguard Worker    dlself=no
6787*6236dae4SAndroid Build Coastguard Worker    export_dynamic=no
6788*6236dae4SAndroid Build Coastguard Worker    export_symbols=
6789*6236dae4SAndroid Build Coastguard Worker    export_symbols_regex=
6790*6236dae4SAndroid Build Coastguard Worker    generated=
6791*6236dae4SAndroid Build Coastguard Worker    libobjs=
6792*6236dae4SAndroid Build Coastguard Worker    ltlibs=
6793*6236dae4SAndroid Build Coastguard Worker    module=no
6794*6236dae4SAndroid Build Coastguard Worker    no_install=no
6795*6236dae4SAndroid Build Coastguard Worker    objs=
6796*6236dae4SAndroid Build Coastguard Worker    os2dllname=
6797*6236dae4SAndroid Build Coastguard Worker    non_pic_objects=
6798*6236dae4SAndroid Build Coastguard Worker    precious_files_regex=
6799*6236dae4SAndroid Build Coastguard Worker    prefer_static_libs=no
6800*6236dae4SAndroid Build Coastguard Worker    preload=false
6801*6236dae4SAndroid Build Coastguard Worker    prev=
6802*6236dae4SAndroid Build Coastguard Worker    prevarg=
6803*6236dae4SAndroid Build Coastguard Worker    release=
6804*6236dae4SAndroid Build Coastguard Worker    rpath=
6805*6236dae4SAndroid Build Coastguard Worker    xrpath=
6806*6236dae4SAndroid Build Coastguard Worker    perm_rpath=
6807*6236dae4SAndroid Build Coastguard Worker    temp_rpath=
6808*6236dae4SAndroid Build Coastguard Worker    thread_safe=no
6809*6236dae4SAndroid Build Coastguard Worker    vinfo=
6810*6236dae4SAndroid Build Coastguard Worker    vinfo_number=no
6811*6236dae4SAndroid Build Coastguard Worker    weak_libs=
6812*6236dae4SAndroid Build Coastguard Worker    single_module=$wl-single_module
6813*6236dae4SAndroid Build Coastguard Worker    func_infer_tag $base_compile
6814*6236dae4SAndroid Build Coastguard Worker
6815*6236dae4SAndroid Build Coastguard Worker    # We need to know -static, to get the right output filenames.
6816*6236dae4SAndroid Build Coastguard Worker    for arg
6817*6236dae4SAndroid Build Coastguard Worker    do
6818*6236dae4SAndroid Build Coastguard Worker      case $arg in
6819*6236dae4SAndroid Build Coastguard Worker      -shared)
6820*6236dae4SAndroid Build Coastguard Worker	test yes != "$build_libtool_libs" \
6821*6236dae4SAndroid Build Coastguard Worker	  && func_fatal_configuration "cannot build a shared library"
6822*6236dae4SAndroid Build Coastguard Worker	build_old_libs=no
6823*6236dae4SAndroid Build Coastguard Worker	break
6824*6236dae4SAndroid Build Coastguard Worker	;;
6825*6236dae4SAndroid Build Coastguard Worker      -all-static | -static | -static-libtool-libs)
6826*6236dae4SAndroid Build Coastguard Worker	case $arg in
6827*6236dae4SAndroid Build Coastguard Worker	-all-static)
6828*6236dae4SAndroid Build Coastguard Worker	  if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then
6829*6236dae4SAndroid Build Coastguard Worker	    func_warning "complete static linking is impossible in this configuration"
6830*6236dae4SAndroid Build Coastguard Worker	  fi
6831*6236dae4SAndroid Build Coastguard Worker	  if test -n "$link_static_flag"; then
6832*6236dae4SAndroid Build Coastguard Worker	    dlopen_self=$dlopen_self_static
6833*6236dae4SAndroid Build Coastguard Worker	  fi
6834*6236dae4SAndroid Build Coastguard Worker	  prefer_static_libs=yes
6835*6236dae4SAndroid Build Coastguard Worker	  ;;
6836*6236dae4SAndroid Build Coastguard Worker	-static)
6837*6236dae4SAndroid Build Coastguard Worker	  if test -z "$pic_flag" && test -n "$link_static_flag"; then
6838*6236dae4SAndroid Build Coastguard Worker	    dlopen_self=$dlopen_self_static
6839*6236dae4SAndroid Build Coastguard Worker	  fi
6840*6236dae4SAndroid Build Coastguard Worker	  prefer_static_libs=built
6841*6236dae4SAndroid Build Coastguard Worker	  ;;
6842*6236dae4SAndroid Build Coastguard Worker	-static-libtool-libs)
6843*6236dae4SAndroid Build Coastguard Worker	  if test -z "$pic_flag" && test -n "$link_static_flag"; then
6844*6236dae4SAndroid Build Coastguard Worker	    dlopen_self=$dlopen_self_static
6845*6236dae4SAndroid Build Coastguard Worker	  fi
6846*6236dae4SAndroid Build Coastguard Worker	  prefer_static_libs=yes
6847*6236dae4SAndroid Build Coastguard Worker	  ;;
6848*6236dae4SAndroid Build Coastguard Worker	esac
6849*6236dae4SAndroid Build Coastguard Worker	build_libtool_libs=no
6850*6236dae4SAndroid Build Coastguard Worker	build_old_libs=yes
6851*6236dae4SAndroid Build Coastguard Worker	break
6852*6236dae4SAndroid Build Coastguard Worker	;;
6853*6236dae4SAndroid Build Coastguard Worker      esac
6854*6236dae4SAndroid Build Coastguard Worker    done
6855*6236dae4SAndroid Build Coastguard Worker
6856*6236dae4SAndroid Build Coastguard Worker    # See if our shared archives depend on static archives.
6857*6236dae4SAndroid Build Coastguard Worker    test -n "$old_archive_from_new_cmds" && build_old_libs=yes
6858*6236dae4SAndroid Build Coastguard Worker
6859*6236dae4SAndroid Build Coastguard Worker    # Go through the arguments, transforming them on the way.
6860*6236dae4SAndroid Build Coastguard Worker    while test "$#" -gt 0; do
6861*6236dae4SAndroid Build Coastguard Worker      arg=$1
6862*6236dae4SAndroid Build Coastguard Worker      shift
6863*6236dae4SAndroid Build Coastguard Worker      func_quote_arg pretty,unquoted "$arg"
6864*6236dae4SAndroid Build Coastguard Worker      qarg=$func_quote_arg_unquoted_result
6865*6236dae4SAndroid Build Coastguard Worker      func_append libtool_args " $func_quote_arg_result"
6866*6236dae4SAndroid Build Coastguard Worker
6867*6236dae4SAndroid Build Coastguard Worker      # If the previous option needs an argument, assign it.
6868*6236dae4SAndroid Build Coastguard Worker      if test -n "$prev"; then
6869*6236dae4SAndroid Build Coastguard Worker	case $prev in
6870*6236dae4SAndroid Build Coastguard Worker	output)
6871*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " @OUTPUT@"
6872*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " @OUTPUT@"
6873*6236dae4SAndroid Build Coastguard Worker	  ;;
6874*6236dae4SAndroid Build Coastguard Worker	esac
6875*6236dae4SAndroid Build Coastguard Worker
6876*6236dae4SAndroid Build Coastguard Worker	case $prev in
6877*6236dae4SAndroid Build Coastguard Worker	bindir)
6878*6236dae4SAndroid Build Coastguard Worker	  bindir=$arg
6879*6236dae4SAndroid Build Coastguard Worker	  prev=
6880*6236dae4SAndroid Build Coastguard Worker	  continue
6881*6236dae4SAndroid Build Coastguard Worker	  ;;
6882*6236dae4SAndroid Build Coastguard Worker	dlfiles|dlprefiles)
6883*6236dae4SAndroid Build Coastguard Worker	  $preload || {
6884*6236dae4SAndroid Build Coastguard Worker	    # Add the symbol object into the linking commands.
6885*6236dae4SAndroid Build Coastguard Worker	    func_append compile_command " @SYMFILE@"
6886*6236dae4SAndroid Build Coastguard Worker	    func_append finalize_command " @SYMFILE@"
6887*6236dae4SAndroid Build Coastguard Worker	    preload=:
6888*6236dae4SAndroid Build Coastguard Worker	  }
6889*6236dae4SAndroid Build Coastguard Worker	  case $arg in
6890*6236dae4SAndroid Build Coastguard Worker	  *.la | *.lo) ;;  # We handle these cases below.
6891*6236dae4SAndroid Build Coastguard Worker	  force)
6892*6236dae4SAndroid Build Coastguard Worker	    if test no = "$dlself"; then
6893*6236dae4SAndroid Build Coastguard Worker	      dlself=needless
6894*6236dae4SAndroid Build Coastguard Worker	      export_dynamic=yes
6895*6236dae4SAndroid Build Coastguard Worker	    fi
6896*6236dae4SAndroid Build Coastguard Worker	    prev=
6897*6236dae4SAndroid Build Coastguard Worker	    continue
6898*6236dae4SAndroid Build Coastguard Worker	    ;;
6899*6236dae4SAndroid Build Coastguard Worker	  self)
6900*6236dae4SAndroid Build Coastguard Worker	    if test dlprefiles = "$prev"; then
6901*6236dae4SAndroid Build Coastguard Worker	      dlself=yes
6902*6236dae4SAndroid Build Coastguard Worker	    elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then
6903*6236dae4SAndroid Build Coastguard Worker	      dlself=yes
6904*6236dae4SAndroid Build Coastguard Worker	    else
6905*6236dae4SAndroid Build Coastguard Worker	      dlself=needless
6906*6236dae4SAndroid Build Coastguard Worker	      export_dynamic=yes
6907*6236dae4SAndroid Build Coastguard Worker	    fi
6908*6236dae4SAndroid Build Coastguard Worker	    prev=
6909*6236dae4SAndroid Build Coastguard Worker	    continue
6910*6236dae4SAndroid Build Coastguard Worker	    ;;
6911*6236dae4SAndroid Build Coastguard Worker	  *)
6912*6236dae4SAndroid Build Coastguard Worker	    if test dlfiles = "$prev"; then
6913*6236dae4SAndroid Build Coastguard Worker	      func_append dlfiles " $arg"
6914*6236dae4SAndroid Build Coastguard Worker	    else
6915*6236dae4SAndroid Build Coastguard Worker	      func_append dlprefiles " $arg"
6916*6236dae4SAndroid Build Coastguard Worker	    fi
6917*6236dae4SAndroid Build Coastguard Worker	    prev=
6918*6236dae4SAndroid Build Coastguard Worker	    continue
6919*6236dae4SAndroid Build Coastguard Worker	    ;;
6920*6236dae4SAndroid Build Coastguard Worker	  esac
6921*6236dae4SAndroid Build Coastguard Worker	  ;;
6922*6236dae4SAndroid Build Coastguard Worker	expsyms)
6923*6236dae4SAndroid Build Coastguard Worker	  export_symbols=$arg
6924*6236dae4SAndroid Build Coastguard Worker	  test -f "$arg" \
6925*6236dae4SAndroid Build Coastguard Worker	    || func_fatal_error "symbol file '$arg' does not exist"
6926*6236dae4SAndroid Build Coastguard Worker	  prev=
6927*6236dae4SAndroid Build Coastguard Worker	  continue
6928*6236dae4SAndroid Build Coastguard Worker	  ;;
6929*6236dae4SAndroid Build Coastguard Worker	expsyms_regex)
6930*6236dae4SAndroid Build Coastguard Worker	  export_symbols_regex=$arg
6931*6236dae4SAndroid Build Coastguard Worker	  prev=
6932*6236dae4SAndroid Build Coastguard Worker	  continue
6933*6236dae4SAndroid Build Coastguard Worker	  ;;
6934*6236dae4SAndroid Build Coastguard Worker	framework)
6935*6236dae4SAndroid Build Coastguard Worker	  case $host in
6936*6236dae4SAndroid Build Coastguard Worker	    *-*-darwin*)
6937*6236dae4SAndroid Build Coastguard Worker	      case "$deplibs " in
6938*6236dae4SAndroid Build Coastguard Worker		*" $qarg.ltframework "*) ;;
6939*6236dae4SAndroid Build Coastguard Worker		*) func_append deplibs " $qarg.ltframework" # this is fixed later
6940*6236dae4SAndroid Build Coastguard Worker		   ;;
6941*6236dae4SAndroid Build Coastguard Worker	      esac
6942*6236dae4SAndroid Build Coastguard Worker	      ;;
6943*6236dae4SAndroid Build Coastguard Worker	  esac
6944*6236dae4SAndroid Build Coastguard Worker	  prev=
6945*6236dae4SAndroid Build Coastguard Worker	  continue
6946*6236dae4SAndroid Build Coastguard Worker	  ;;
6947*6236dae4SAndroid Build Coastguard Worker	inst_prefix)
6948*6236dae4SAndroid Build Coastguard Worker	  inst_prefix_dir=$arg
6949*6236dae4SAndroid Build Coastguard Worker	  prev=
6950*6236dae4SAndroid Build Coastguard Worker	  continue
6951*6236dae4SAndroid Build Coastguard Worker	  ;;
6952*6236dae4SAndroid Build Coastguard Worker	mllvm)
6953*6236dae4SAndroid Build Coastguard Worker	  # Clang does not use LLVM to link, so we can simply discard any
6954*6236dae4SAndroid Build Coastguard Worker	  # '-mllvm $arg' options when doing the link step.
6955*6236dae4SAndroid Build Coastguard Worker	  prev=
6956*6236dae4SAndroid Build Coastguard Worker	  continue
6957*6236dae4SAndroid Build Coastguard Worker	  ;;
6958*6236dae4SAndroid Build Coastguard Worker	objectlist)
6959*6236dae4SAndroid Build Coastguard Worker	  if test -f "$arg"; then
6960*6236dae4SAndroid Build Coastguard Worker	    save_arg=$arg
6961*6236dae4SAndroid Build Coastguard Worker	    moreargs=
6962*6236dae4SAndroid Build Coastguard Worker	    for fil in `cat "$save_arg"`
6963*6236dae4SAndroid Build Coastguard Worker	    do
6964*6236dae4SAndroid Build Coastguard Worker#	      func_append moreargs " $fil"
6965*6236dae4SAndroid Build Coastguard Worker	      arg=$fil
6966*6236dae4SAndroid Build Coastguard Worker	      # A libtool-controlled object.
6967*6236dae4SAndroid Build Coastguard Worker
6968*6236dae4SAndroid Build Coastguard Worker	      # Check to see that this really is a libtool object.
6969*6236dae4SAndroid Build Coastguard Worker	      if func_lalib_unsafe_p "$arg"; then
6970*6236dae4SAndroid Build Coastguard Worker		pic_object=
6971*6236dae4SAndroid Build Coastguard Worker		non_pic_object=
6972*6236dae4SAndroid Build Coastguard Worker
6973*6236dae4SAndroid Build Coastguard Worker		# Read the .lo file
6974*6236dae4SAndroid Build Coastguard Worker		func_source "$arg"
6975*6236dae4SAndroid Build Coastguard Worker
6976*6236dae4SAndroid Build Coastguard Worker		if test -z "$pic_object" ||
6977*6236dae4SAndroid Build Coastguard Worker		   test -z "$non_pic_object" ||
6978*6236dae4SAndroid Build Coastguard Worker		   test none = "$pic_object" &&
6979*6236dae4SAndroid Build Coastguard Worker		   test none = "$non_pic_object"; then
6980*6236dae4SAndroid Build Coastguard Worker		  func_fatal_error "cannot find name of object for '$arg'"
6981*6236dae4SAndroid Build Coastguard Worker		fi
6982*6236dae4SAndroid Build Coastguard Worker
6983*6236dae4SAndroid Build Coastguard Worker		# Extract subdirectory from the argument.
6984*6236dae4SAndroid Build Coastguard Worker		func_dirname "$arg" "/" ""
6985*6236dae4SAndroid Build Coastguard Worker		xdir=$func_dirname_result
6986*6236dae4SAndroid Build Coastguard Worker
6987*6236dae4SAndroid Build Coastguard Worker		if test none != "$pic_object"; then
6988*6236dae4SAndroid Build Coastguard Worker		  # Prepend the subdirectory the object is found in.
6989*6236dae4SAndroid Build Coastguard Worker		  pic_object=$xdir$pic_object
6990*6236dae4SAndroid Build Coastguard Worker
6991*6236dae4SAndroid Build Coastguard Worker		  if test dlfiles = "$prev"; then
6992*6236dae4SAndroid Build Coastguard Worker		    if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then
6993*6236dae4SAndroid Build Coastguard Worker		      func_append dlfiles " $pic_object"
6994*6236dae4SAndroid Build Coastguard Worker		      prev=
6995*6236dae4SAndroid Build Coastguard Worker		      continue
6996*6236dae4SAndroid Build Coastguard Worker		    else
6997*6236dae4SAndroid Build Coastguard Worker		      # If libtool objects are unsupported, then we need to preload.
6998*6236dae4SAndroid Build Coastguard Worker		      prev=dlprefiles
6999*6236dae4SAndroid Build Coastguard Worker		    fi
7000*6236dae4SAndroid Build Coastguard Worker		  fi
7001*6236dae4SAndroid Build Coastguard Worker
7002*6236dae4SAndroid Build Coastguard Worker		  # CHECK ME:  I think I busted this.  -Ossama
7003*6236dae4SAndroid Build Coastguard Worker		  if test dlprefiles = "$prev"; then
7004*6236dae4SAndroid Build Coastguard Worker		    # Preload the old-style object.
7005*6236dae4SAndroid Build Coastguard Worker		    func_append dlprefiles " $pic_object"
7006*6236dae4SAndroid Build Coastguard Worker		    prev=
7007*6236dae4SAndroid Build Coastguard Worker		  fi
7008*6236dae4SAndroid Build Coastguard Worker
7009*6236dae4SAndroid Build Coastguard Worker		  # A PIC object.
7010*6236dae4SAndroid Build Coastguard Worker		  func_append libobjs " $pic_object"
7011*6236dae4SAndroid Build Coastguard Worker		  arg=$pic_object
7012*6236dae4SAndroid Build Coastguard Worker		fi
7013*6236dae4SAndroid Build Coastguard Worker
7014*6236dae4SAndroid Build Coastguard Worker		# Non-PIC object.
7015*6236dae4SAndroid Build Coastguard Worker		if test none != "$non_pic_object"; then
7016*6236dae4SAndroid Build Coastguard Worker		  # Prepend the subdirectory the object is found in.
7017*6236dae4SAndroid Build Coastguard Worker		  non_pic_object=$xdir$non_pic_object
7018*6236dae4SAndroid Build Coastguard Worker
7019*6236dae4SAndroid Build Coastguard Worker		  # A standard non-PIC object
7020*6236dae4SAndroid Build Coastguard Worker		  func_append non_pic_objects " $non_pic_object"
7021*6236dae4SAndroid Build Coastguard Worker		  if test -z "$pic_object" || test none = "$pic_object"; then
7022*6236dae4SAndroid Build Coastguard Worker		    arg=$non_pic_object
7023*6236dae4SAndroid Build Coastguard Worker		  fi
7024*6236dae4SAndroid Build Coastguard Worker		else
7025*6236dae4SAndroid Build Coastguard Worker		  # If the PIC object exists, use it instead.
7026*6236dae4SAndroid Build Coastguard Worker		  # $xdir was prepended to $pic_object above.
7027*6236dae4SAndroid Build Coastguard Worker		  non_pic_object=$pic_object
7028*6236dae4SAndroid Build Coastguard Worker		  func_append non_pic_objects " $non_pic_object"
7029*6236dae4SAndroid Build Coastguard Worker		fi
7030*6236dae4SAndroid Build Coastguard Worker	      else
7031*6236dae4SAndroid Build Coastguard Worker		# Only an error if not doing a dry-run.
7032*6236dae4SAndroid Build Coastguard Worker		if $opt_dry_run; then
7033*6236dae4SAndroid Build Coastguard Worker		  # Extract subdirectory from the argument.
7034*6236dae4SAndroid Build Coastguard Worker		  func_dirname "$arg" "/" ""
7035*6236dae4SAndroid Build Coastguard Worker		  xdir=$func_dirname_result
7036*6236dae4SAndroid Build Coastguard Worker
7037*6236dae4SAndroid Build Coastguard Worker		  func_lo2o "$arg"
7038*6236dae4SAndroid Build Coastguard Worker		  pic_object=$xdir$objdir/$func_lo2o_result
7039*6236dae4SAndroid Build Coastguard Worker		  non_pic_object=$xdir$func_lo2o_result
7040*6236dae4SAndroid Build Coastguard Worker		  func_append libobjs " $pic_object"
7041*6236dae4SAndroid Build Coastguard Worker		  func_append non_pic_objects " $non_pic_object"
7042*6236dae4SAndroid Build Coastguard Worker	        else
7043*6236dae4SAndroid Build Coastguard Worker		  func_fatal_error "'$arg' is not a valid libtool object"
7044*6236dae4SAndroid Build Coastguard Worker		fi
7045*6236dae4SAndroid Build Coastguard Worker	      fi
7046*6236dae4SAndroid Build Coastguard Worker	    done
7047*6236dae4SAndroid Build Coastguard Worker	  else
7048*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "link input file '$arg' does not exist"
7049*6236dae4SAndroid Build Coastguard Worker	  fi
7050*6236dae4SAndroid Build Coastguard Worker	  arg=$save_arg
7051*6236dae4SAndroid Build Coastguard Worker	  prev=
7052*6236dae4SAndroid Build Coastguard Worker	  continue
7053*6236dae4SAndroid Build Coastguard Worker	  ;;
7054*6236dae4SAndroid Build Coastguard Worker	os2dllname)
7055*6236dae4SAndroid Build Coastguard Worker	  os2dllname=$arg
7056*6236dae4SAndroid Build Coastguard Worker	  prev=
7057*6236dae4SAndroid Build Coastguard Worker	  continue
7058*6236dae4SAndroid Build Coastguard Worker	  ;;
7059*6236dae4SAndroid Build Coastguard Worker	precious_regex)
7060*6236dae4SAndroid Build Coastguard Worker	  precious_files_regex=$arg
7061*6236dae4SAndroid Build Coastguard Worker	  prev=
7062*6236dae4SAndroid Build Coastguard Worker	  continue
7063*6236dae4SAndroid Build Coastguard Worker	  ;;
7064*6236dae4SAndroid Build Coastguard Worker	release)
7065*6236dae4SAndroid Build Coastguard Worker	  release=-$arg
7066*6236dae4SAndroid Build Coastguard Worker	  prev=
7067*6236dae4SAndroid Build Coastguard Worker	  continue
7068*6236dae4SAndroid Build Coastguard Worker	  ;;
7069*6236dae4SAndroid Build Coastguard Worker	rpath | xrpath)
7070*6236dae4SAndroid Build Coastguard Worker	  # We need an absolute path.
7071*6236dae4SAndroid Build Coastguard Worker	  case $arg in
7072*6236dae4SAndroid Build Coastguard Worker	  [\\/]* | [A-Za-z]:[\\/]*) ;;
7073*6236dae4SAndroid Build Coastguard Worker	  *)
7074*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "only absolute run-paths are allowed"
7075*6236dae4SAndroid Build Coastguard Worker	    ;;
7076*6236dae4SAndroid Build Coastguard Worker	  esac
7077*6236dae4SAndroid Build Coastguard Worker	  if test rpath = "$prev"; then
7078*6236dae4SAndroid Build Coastguard Worker	    case "$rpath " in
7079*6236dae4SAndroid Build Coastguard Worker	    *" $arg "*) ;;
7080*6236dae4SAndroid Build Coastguard Worker	    *) func_append rpath " $arg" ;;
7081*6236dae4SAndroid Build Coastguard Worker	    esac
7082*6236dae4SAndroid Build Coastguard Worker	  else
7083*6236dae4SAndroid Build Coastguard Worker	    case "$xrpath " in
7084*6236dae4SAndroid Build Coastguard Worker	    *" $arg "*) ;;
7085*6236dae4SAndroid Build Coastguard Worker	    *) func_append xrpath " $arg" ;;
7086*6236dae4SAndroid Build Coastguard Worker	    esac
7087*6236dae4SAndroid Build Coastguard Worker	  fi
7088*6236dae4SAndroid Build Coastguard Worker	  prev=
7089*6236dae4SAndroid Build Coastguard Worker	  continue
7090*6236dae4SAndroid Build Coastguard Worker	  ;;
7091*6236dae4SAndroid Build Coastguard Worker	shrext)
7092*6236dae4SAndroid Build Coastguard Worker	  shrext_cmds=$arg
7093*6236dae4SAndroid Build Coastguard Worker	  prev=
7094*6236dae4SAndroid Build Coastguard Worker	  continue
7095*6236dae4SAndroid Build Coastguard Worker	  ;;
7096*6236dae4SAndroid Build Coastguard Worker	weak)
7097*6236dae4SAndroid Build Coastguard Worker	  func_append weak_libs " $arg"
7098*6236dae4SAndroid Build Coastguard Worker	  prev=
7099*6236dae4SAndroid Build Coastguard Worker	  continue
7100*6236dae4SAndroid Build Coastguard Worker	  ;;
7101*6236dae4SAndroid Build Coastguard Worker	xassembler)
7102*6236dae4SAndroid Build Coastguard Worker	  func_append compiler_flags " -Xassembler $qarg"
7103*6236dae4SAndroid Build Coastguard Worker	  prev=
7104*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " -Xassembler $qarg"
7105*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " -Xassembler $qarg"
7106*6236dae4SAndroid Build Coastguard Worker	  continue
7107*6236dae4SAndroid Build Coastguard Worker	  ;;
7108*6236dae4SAndroid Build Coastguard Worker	xcclinker)
7109*6236dae4SAndroid Build Coastguard Worker	  func_append linker_flags " $qarg"
7110*6236dae4SAndroid Build Coastguard Worker	  func_append compiler_flags " $qarg"
7111*6236dae4SAndroid Build Coastguard Worker	  prev=
7112*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " $qarg"
7113*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " $qarg"
7114*6236dae4SAndroid Build Coastguard Worker	  continue
7115*6236dae4SAndroid Build Coastguard Worker	  ;;
7116*6236dae4SAndroid Build Coastguard Worker	xcompiler)
7117*6236dae4SAndroid Build Coastguard Worker	  func_append compiler_flags " $qarg"
7118*6236dae4SAndroid Build Coastguard Worker	  prev=
7119*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " $qarg"
7120*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " $qarg"
7121*6236dae4SAndroid Build Coastguard Worker	  continue
7122*6236dae4SAndroid Build Coastguard Worker	  ;;
7123*6236dae4SAndroid Build Coastguard Worker	xlinker)
7124*6236dae4SAndroid Build Coastguard Worker	  func_append linker_flags " $qarg"
7125*6236dae4SAndroid Build Coastguard Worker	  func_append compiler_flags " $wl$qarg"
7126*6236dae4SAndroid Build Coastguard Worker	  prev=
7127*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " $wl$qarg"
7128*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " $wl$qarg"
7129*6236dae4SAndroid Build Coastguard Worker	  continue
7130*6236dae4SAndroid Build Coastguard Worker	  ;;
7131*6236dae4SAndroid Build Coastguard Worker	*)
7132*6236dae4SAndroid Build Coastguard Worker	  eval "$prev=\"\$arg\""
7133*6236dae4SAndroid Build Coastguard Worker	  prev=
7134*6236dae4SAndroid Build Coastguard Worker	  continue
7135*6236dae4SAndroid Build Coastguard Worker	  ;;
7136*6236dae4SAndroid Build Coastguard Worker	esac
7137*6236dae4SAndroid Build Coastguard Worker      fi # test -n "$prev"
7138*6236dae4SAndroid Build Coastguard Worker
7139*6236dae4SAndroid Build Coastguard Worker      prevarg=$arg
7140*6236dae4SAndroid Build Coastguard Worker
7141*6236dae4SAndroid Build Coastguard Worker      case $arg in
7142*6236dae4SAndroid Build Coastguard Worker      -all-static)
7143*6236dae4SAndroid Build Coastguard Worker	if test -n "$link_static_flag"; then
7144*6236dae4SAndroid Build Coastguard Worker	  # See comment for -static flag below, for more details.
7145*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " $link_static_flag"
7146*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " $link_static_flag"
7147*6236dae4SAndroid Build Coastguard Worker	fi
7148*6236dae4SAndroid Build Coastguard Worker	continue
7149*6236dae4SAndroid Build Coastguard Worker	;;
7150*6236dae4SAndroid Build Coastguard Worker
7151*6236dae4SAndroid Build Coastguard Worker      -allow-undefined)
7152*6236dae4SAndroid Build Coastguard Worker	# FIXME: remove this flag sometime in the future.
7153*6236dae4SAndroid Build Coastguard Worker	func_fatal_error "'-allow-undefined' must not be used because it is the default"
7154*6236dae4SAndroid Build Coastguard Worker	;;
7155*6236dae4SAndroid Build Coastguard Worker
7156*6236dae4SAndroid Build Coastguard Worker      -avoid-version)
7157*6236dae4SAndroid Build Coastguard Worker	avoid_version=yes
7158*6236dae4SAndroid Build Coastguard Worker	continue
7159*6236dae4SAndroid Build Coastguard Worker	;;
7160*6236dae4SAndroid Build Coastguard Worker
7161*6236dae4SAndroid Build Coastguard Worker      -bindir)
7162*6236dae4SAndroid Build Coastguard Worker	prev=bindir
7163*6236dae4SAndroid Build Coastguard Worker	continue
7164*6236dae4SAndroid Build Coastguard Worker	;;
7165*6236dae4SAndroid Build Coastguard Worker
7166*6236dae4SAndroid Build Coastguard Worker      -dlopen)
7167*6236dae4SAndroid Build Coastguard Worker	prev=dlfiles
7168*6236dae4SAndroid Build Coastguard Worker	continue
7169*6236dae4SAndroid Build Coastguard Worker	;;
7170*6236dae4SAndroid Build Coastguard Worker
7171*6236dae4SAndroid Build Coastguard Worker      -dlpreopen)
7172*6236dae4SAndroid Build Coastguard Worker	prev=dlprefiles
7173*6236dae4SAndroid Build Coastguard Worker	continue
7174*6236dae4SAndroid Build Coastguard Worker	;;
7175*6236dae4SAndroid Build Coastguard Worker
7176*6236dae4SAndroid Build Coastguard Worker      -export-dynamic)
7177*6236dae4SAndroid Build Coastguard Worker	export_dynamic=yes
7178*6236dae4SAndroid Build Coastguard Worker	continue
7179*6236dae4SAndroid Build Coastguard Worker	;;
7180*6236dae4SAndroid Build Coastguard Worker
7181*6236dae4SAndroid Build Coastguard Worker      -export-symbols | -export-symbols-regex)
7182*6236dae4SAndroid Build Coastguard Worker	if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
7183*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "more than one -exported-symbols argument is not allowed"
7184*6236dae4SAndroid Build Coastguard Worker	fi
7185*6236dae4SAndroid Build Coastguard Worker	if test X-export-symbols = "X$arg"; then
7186*6236dae4SAndroid Build Coastguard Worker	  prev=expsyms
7187*6236dae4SAndroid Build Coastguard Worker	else
7188*6236dae4SAndroid Build Coastguard Worker	  prev=expsyms_regex
7189*6236dae4SAndroid Build Coastguard Worker	fi
7190*6236dae4SAndroid Build Coastguard Worker	continue
7191*6236dae4SAndroid Build Coastguard Worker	;;
7192*6236dae4SAndroid Build Coastguard Worker
7193*6236dae4SAndroid Build Coastguard Worker      -framework)
7194*6236dae4SAndroid Build Coastguard Worker	prev=framework
7195*6236dae4SAndroid Build Coastguard Worker	continue
7196*6236dae4SAndroid Build Coastguard Worker	;;
7197*6236dae4SAndroid Build Coastguard Worker
7198*6236dae4SAndroid Build Coastguard Worker      -inst-prefix-dir)
7199*6236dae4SAndroid Build Coastguard Worker	prev=inst_prefix
7200*6236dae4SAndroid Build Coastguard Worker	continue
7201*6236dae4SAndroid Build Coastguard Worker	;;
7202*6236dae4SAndroid Build Coastguard Worker
7203*6236dae4SAndroid Build Coastguard Worker      # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:*
7204*6236dae4SAndroid Build Coastguard Worker      # so, if we see these flags be careful not to treat them like -L
7205*6236dae4SAndroid Build Coastguard Worker      -L[A-Z][A-Z]*:*)
7206*6236dae4SAndroid Build Coastguard Worker	case $with_gcc/$host in
7207*6236dae4SAndroid Build Coastguard Worker	no/*-*-irix* | /*-*-irix*)
7208*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " $arg"
7209*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " $arg"
7210*6236dae4SAndroid Build Coastguard Worker	  ;;
7211*6236dae4SAndroid Build Coastguard Worker	esac
7212*6236dae4SAndroid Build Coastguard Worker	continue
7213*6236dae4SAndroid Build Coastguard Worker	;;
7214*6236dae4SAndroid Build Coastguard Worker
7215*6236dae4SAndroid Build Coastguard Worker      -L*)
7216*6236dae4SAndroid Build Coastguard Worker	func_stripname "-L" '' "$arg"
7217*6236dae4SAndroid Build Coastguard Worker	if test -z "$func_stripname_result"; then
7218*6236dae4SAndroid Build Coastguard Worker	  if test "$#" -gt 0; then
7219*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "require no space between '-L' and '$1'"
7220*6236dae4SAndroid Build Coastguard Worker	  else
7221*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "need path for '-L' option"
7222*6236dae4SAndroid Build Coastguard Worker	  fi
7223*6236dae4SAndroid Build Coastguard Worker	fi
7224*6236dae4SAndroid Build Coastguard Worker	func_resolve_sysroot "$func_stripname_result"
7225*6236dae4SAndroid Build Coastguard Worker	dir=$func_resolve_sysroot_result
7226*6236dae4SAndroid Build Coastguard Worker	# We need an absolute path.
7227*6236dae4SAndroid Build Coastguard Worker	case $dir in
7228*6236dae4SAndroid Build Coastguard Worker	[\\/]* | [A-Za-z]:[\\/]*) ;;
7229*6236dae4SAndroid Build Coastguard Worker	*)
7230*6236dae4SAndroid Build Coastguard Worker	  absdir=`cd "$dir" && pwd`
7231*6236dae4SAndroid Build Coastguard Worker	  test -z "$absdir" && \
7232*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "cannot determine absolute directory name of '$dir'"
7233*6236dae4SAndroid Build Coastguard Worker	  dir=$absdir
7234*6236dae4SAndroid Build Coastguard Worker	  ;;
7235*6236dae4SAndroid Build Coastguard Worker	esac
7236*6236dae4SAndroid Build Coastguard Worker	case "$deplibs " in
7237*6236dae4SAndroid Build Coastguard Worker	*" -L$dir "* | *" $arg "*)
7238*6236dae4SAndroid Build Coastguard Worker	  # Will only happen for absolute or sysroot arguments
7239*6236dae4SAndroid Build Coastguard Worker	  ;;
7240*6236dae4SAndroid Build Coastguard Worker	*)
7241*6236dae4SAndroid Build Coastguard Worker	  # Preserve sysroot, but never include relative directories
7242*6236dae4SAndroid Build Coastguard Worker	  case $dir in
7243*6236dae4SAndroid Build Coastguard Worker	    [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;;
7244*6236dae4SAndroid Build Coastguard Worker	    *) func_append deplibs " -L$dir" ;;
7245*6236dae4SAndroid Build Coastguard Worker	  esac
7246*6236dae4SAndroid Build Coastguard Worker	  func_append lib_search_path " $dir"
7247*6236dae4SAndroid Build Coastguard Worker	  ;;
7248*6236dae4SAndroid Build Coastguard Worker	esac
7249*6236dae4SAndroid Build Coastguard Worker	case $host in
7250*6236dae4SAndroid Build Coastguard Worker	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
7251*6236dae4SAndroid Build Coastguard Worker	  testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'`
7252*6236dae4SAndroid Build Coastguard Worker	  case :$dllsearchpath: in
7253*6236dae4SAndroid Build Coastguard Worker	  *":$dir:"*) ;;
7254*6236dae4SAndroid Build Coastguard Worker	  ::) dllsearchpath=$dir;;
7255*6236dae4SAndroid Build Coastguard Worker	  *) func_append dllsearchpath ":$dir";;
7256*6236dae4SAndroid Build Coastguard Worker	  esac
7257*6236dae4SAndroid Build Coastguard Worker	  case :$dllsearchpath: in
7258*6236dae4SAndroid Build Coastguard Worker	  *":$testbindir:"*) ;;
7259*6236dae4SAndroid Build Coastguard Worker	  ::) dllsearchpath=$testbindir;;
7260*6236dae4SAndroid Build Coastguard Worker	  *) func_append dllsearchpath ":$testbindir";;
7261*6236dae4SAndroid Build Coastguard Worker	  esac
7262*6236dae4SAndroid Build Coastguard Worker	  ;;
7263*6236dae4SAndroid Build Coastguard Worker	esac
7264*6236dae4SAndroid Build Coastguard Worker	continue
7265*6236dae4SAndroid Build Coastguard Worker	;;
7266*6236dae4SAndroid Build Coastguard Worker
7267*6236dae4SAndroid Build Coastguard Worker      -l*)
7268*6236dae4SAndroid Build Coastguard Worker	if test X-lc = "X$arg" || test X-lm = "X$arg"; then
7269*6236dae4SAndroid Build Coastguard Worker	  case $host in
7270*6236dae4SAndroid Build Coastguard Worker	  *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*)
7271*6236dae4SAndroid Build Coastguard Worker	    # These systems don't actually have a C or math library (as such)
7272*6236dae4SAndroid Build Coastguard Worker	    continue
7273*6236dae4SAndroid Build Coastguard Worker	    ;;
7274*6236dae4SAndroid Build Coastguard Worker	  *-*-os2*)
7275*6236dae4SAndroid Build Coastguard Worker	    # These systems don't actually have a C library (as such)
7276*6236dae4SAndroid Build Coastguard Worker	    test X-lc = "X$arg" && continue
7277*6236dae4SAndroid Build Coastguard Worker	    ;;
7278*6236dae4SAndroid Build Coastguard Worker	  *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig* | *-*-midnightbsd*)
7279*6236dae4SAndroid Build Coastguard Worker	    # Do not include libc due to us having libc/libc_r.
7280*6236dae4SAndroid Build Coastguard Worker	    test X-lc = "X$arg" && continue
7281*6236dae4SAndroid Build Coastguard Worker	    ;;
7282*6236dae4SAndroid Build Coastguard Worker	  *-*-rhapsody* | *-*-darwin1.[012])
7283*6236dae4SAndroid Build Coastguard Worker	    # Rhapsody C and math libraries are in the System framework
7284*6236dae4SAndroid Build Coastguard Worker	    func_append deplibs " System.ltframework"
7285*6236dae4SAndroid Build Coastguard Worker	    continue
7286*6236dae4SAndroid Build Coastguard Worker	    ;;
7287*6236dae4SAndroid Build Coastguard Worker	  *-*-sco3.2v5* | *-*-sco5v6*)
7288*6236dae4SAndroid Build Coastguard Worker	    # Causes problems with __ctype
7289*6236dae4SAndroid Build Coastguard Worker	    test X-lc = "X$arg" && continue
7290*6236dae4SAndroid Build Coastguard Worker	    ;;
7291*6236dae4SAndroid Build Coastguard Worker	  *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*)
7292*6236dae4SAndroid Build Coastguard Worker	    # Compiler inserts libc in the correct place for threads to work
7293*6236dae4SAndroid Build Coastguard Worker	    test X-lc = "X$arg" && continue
7294*6236dae4SAndroid Build Coastguard Worker	    ;;
7295*6236dae4SAndroid Build Coastguard Worker	  esac
7296*6236dae4SAndroid Build Coastguard Worker	elif test X-lc_r = "X$arg"; then
7297*6236dae4SAndroid Build Coastguard Worker	 case $host in
7298*6236dae4SAndroid Build Coastguard Worker	 *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig* | *-*-midnightbsd*)
7299*6236dae4SAndroid Build Coastguard Worker	   # Do not include libc_r directly, use -pthread flag.
7300*6236dae4SAndroid Build Coastguard Worker	   continue
7301*6236dae4SAndroid Build Coastguard Worker	   ;;
7302*6236dae4SAndroid Build Coastguard Worker	 esac
7303*6236dae4SAndroid Build Coastguard Worker	fi
7304*6236dae4SAndroid Build Coastguard Worker	func_append deplibs " $arg"
7305*6236dae4SAndroid Build Coastguard Worker	continue
7306*6236dae4SAndroid Build Coastguard Worker	;;
7307*6236dae4SAndroid Build Coastguard Worker
7308*6236dae4SAndroid Build Coastguard Worker      -mllvm)
7309*6236dae4SAndroid Build Coastguard Worker	prev=mllvm
7310*6236dae4SAndroid Build Coastguard Worker	continue
7311*6236dae4SAndroid Build Coastguard Worker	;;
7312*6236dae4SAndroid Build Coastguard Worker
7313*6236dae4SAndroid Build Coastguard Worker      -module)
7314*6236dae4SAndroid Build Coastguard Worker	module=yes
7315*6236dae4SAndroid Build Coastguard Worker	continue
7316*6236dae4SAndroid Build Coastguard Worker	;;
7317*6236dae4SAndroid Build Coastguard Worker
7318*6236dae4SAndroid Build Coastguard Worker      # Tru64 UNIX uses -model [arg] to determine the layout of C++
7319*6236dae4SAndroid Build Coastguard Worker      # classes, name mangling, and exception handling.
7320*6236dae4SAndroid Build Coastguard Worker      # Darwin uses the -arch flag to determine output architecture.
7321*6236dae4SAndroid Build Coastguard Worker      -model|-arch|-isysroot|--sysroot)
7322*6236dae4SAndroid Build Coastguard Worker	func_append compiler_flags " $arg"
7323*6236dae4SAndroid Build Coastguard Worker	func_append compile_command " $arg"
7324*6236dae4SAndroid Build Coastguard Worker	func_append finalize_command " $arg"
7325*6236dae4SAndroid Build Coastguard Worker	prev=xcompiler
7326*6236dae4SAndroid Build Coastguard Worker	continue
7327*6236dae4SAndroid Build Coastguard Worker	;;
7328*6236dae4SAndroid Build Coastguard Worker     # Solaris ld rejects as of 11.4. Refer to Oracle bug 22985199.
7329*6236dae4SAndroid Build Coastguard Worker     -pthread)
7330*6236dae4SAndroid Build Coastguard Worker	case $host in
7331*6236dae4SAndroid Build Coastguard Worker	  *solaris2*) ;;
7332*6236dae4SAndroid Build Coastguard Worker	  *)
7333*6236dae4SAndroid Build Coastguard Worker	    case "$new_inherited_linker_flags " in
7334*6236dae4SAndroid Build Coastguard Worker	        *" $arg "*) ;;
7335*6236dae4SAndroid Build Coastguard Worker	        * ) func_append new_inherited_linker_flags " $arg" ;;
7336*6236dae4SAndroid Build Coastguard Worker	    esac
7337*6236dae4SAndroid Build Coastguard Worker	  ;;
7338*6236dae4SAndroid Build Coastguard Worker	esac
7339*6236dae4SAndroid Build Coastguard Worker	continue
7340*6236dae4SAndroid Build Coastguard Worker	;;
7341*6236dae4SAndroid Build Coastguard Worker      -mt|-mthreads|-kthread|-Kthread|-pthreads|--thread-safe \
7342*6236dae4SAndroid Build Coastguard Worker      |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*)
7343*6236dae4SAndroid Build Coastguard Worker	func_append compiler_flags " $arg"
7344*6236dae4SAndroid Build Coastguard Worker	func_append compile_command " $arg"
7345*6236dae4SAndroid Build Coastguard Worker	func_append finalize_command " $arg"
7346*6236dae4SAndroid Build Coastguard Worker	case "$new_inherited_linker_flags " in
7347*6236dae4SAndroid Build Coastguard Worker	    *" $arg "*) ;;
7348*6236dae4SAndroid Build Coastguard Worker	    * ) func_append new_inherited_linker_flags " $arg" ;;
7349*6236dae4SAndroid Build Coastguard Worker	esac
7350*6236dae4SAndroid Build Coastguard Worker	continue
7351*6236dae4SAndroid Build Coastguard Worker	;;
7352*6236dae4SAndroid Build Coastguard Worker
7353*6236dae4SAndroid Build Coastguard Worker      -multi_module)
7354*6236dae4SAndroid Build Coastguard Worker	single_module=$wl-multi_module
7355*6236dae4SAndroid Build Coastguard Worker	continue
7356*6236dae4SAndroid Build Coastguard Worker	;;
7357*6236dae4SAndroid Build Coastguard Worker
7358*6236dae4SAndroid Build Coastguard Worker      -no-fast-install)
7359*6236dae4SAndroid Build Coastguard Worker	fast_install=no
7360*6236dae4SAndroid Build Coastguard Worker	continue
7361*6236dae4SAndroid Build Coastguard Worker	;;
7362*6236dae4SAndroid Build Coastguard Worker
7363*6236dae4SAndroid Build Coastguard Worker      -no-install)
7364*6236dae4SAndroid Build Coastguard Worker	case $host in
7365*6236dae4SAndroid Build Coastguard Worker	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*)
7366*6236dae4SAndroid Build Coastguard Worker	  # The PATH hackery in wrapper scripts is required on Windows
7367*6236dae4SAndroid Build Coastguard Worker	  # and Darwin in order for the loader to find any dlls it needs.
7368*6236dae4SAndroid Build Coastguard Worker	  func_warning "'-no-install' is ignored for $host"
7369*6236dae4SAndroid Build Coastguard Worker	  func_warning "assuming '-no-fast-install' instead"
7370*6236dae4SAndroid Build Coastguard Worker	  fast_install=no
7371*6236dae4SAndroid Build Coastguard Worker	  ;;
7372*6236dae4SAndroid Build Coastguard Worker	*) no_install=yes ;;
7373*6236dae4SAndroid Build Coastguard Worker	esac
7374*6236dae4SAndroid Build Coastguard Worker	continue
7375*6236dae4SAndroid Build Coastguard Worker	;;
7376*6236dae4SAndroid Build Coastguard Worker
7377*6236dae4SAndroid Build Coastguard Worker      -no-undefined)
7378*6236dae4SAndroid Build Coastguard Worker	allow_undefined=no
7379*6236dae4SAndroid Build Coastguard Worker	continue
7380*6236dae4SAndroid Build Coastguard Worker	;;
7381*6236dae4SAndroid Build Coastguard Worker
7382*6236dae4SAndroid Build Coastguard Worker      -objectlist)
7383*6236dae4SAndroid Build Coastguard Worker	prev=objectlist
7384*6236dae4SAndroid Build Coastguard Worker	continue
7385*6236dae4SAndroid Build Coastguard Worker	;;
7386*6236dae4SAndroid Build Coastguard Worker
7387*6236dae4SAndroid Build Coastguard Worker      -os2dllname)
7388*6236dae4SAndroid Build Coastguard Worker	prev=os2dllname
7389*6236dae4SAndroid Build Coastguard Worker	continue
7390*6236dae4SAndroid Build Coastguard Worker	;;
7391*6236dae4SAndroid Build Coastguard Worker
7392*6236dae4SAndroid Build Coastguard Worker      -o) prev=output ;;
7393*6236dae4SAndroid Build Coastguard Worker
7394*6236dae4SAndroid Build Coastguard Worker      -precious-files-regex)
7395*6236dae4SAndroid Build Coastguard Worker	prev=precious_regex
7396*6236dae4SAndroid Build Coastguard Worker	continue
7397*6236dae4SAndroid Build Coastguard Worker	;;
7398*6236dae4SAndroid Build Coastguard Worker
7399*6236dae4SAndroid Build Coastguard Worker      -release)
7400*6236dae4SAndroid Build Coastguard Worker	prev=release
7401*6236dae4SAndroid Build Coastguard Worker	continue
7402*6236dae4SAndroid Build Coastguard Worker	;;
7403*6236dae4SAndroid Build Coastguard Worker
7404*6236dae4SAndroid Build Coastguard Worker      -rpath)
7405*6236dae4SAndroid Build Coastguard Worker	prev=rpath
7406*6236dae4SAndroid Build Coastguard Worker	continue
7407*6236dae4SAndroid Build Coastguard Worker	;;
7408*6236dae4SAndroid Build Coastguard Worker
7409*6236dae4SAndroid Build Coastguard Worker      -R)
7410*6236dae4SAndroid Build Coastguard Worker	prev=xrpath
7411*6236dae4SAndroid Build Coastguard Worker	continue
7412*6236dae4SAndroid Build Coastguard Worker	;;
7413*6236dae4SAndroid Build Coastguard Worker
7414*6236dae4SAndroid Build Coastguard Worker      -R*)
7415*6236dae4SAndroid Build Coastguard Worker	func_stripname '-R' '' "$arg"
7416*6236dae4SAndroid Build Coastguard Worker	dir=$func_stripname_result
7417*6236dae4SAndroid Build Coastguard Worker	# We need an absolute path.
7418*6236dae4SAndroid Build Coastguard Worker	case $dir in
7419*6236dae4SAndroid Build Coastguard Worker	[\\/]* | [A-Za-z]:[\\/]*) ;;
7420*6236dae4SAndroid Build Coastguard Worker	=*)
7421*6236dae4SAndroid Build Coastguard Worker	  func_stripname '=' '' "$dir"
7422*6236dae4SAndroid Build Coastguard Worker	  dir=$lt_sysroot$func_stripname_result
7423*6236dae4SAndroid Build Coastguard Worker	  ;;
7424*6236dae4SAndroid Build Coastguard Worker	*)
7425*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "only absolute run-paths are allowed"
7426*6236dae4SAndroid Build Coastguard Worker	  ;;
7427*6236dae4SAndroid Build Coastguard Worker	esac
7428*6236dae4SAndroid Build Coastguard Worker	case "$xrpath " in
7429*6236dae4SAndroid Build Coastguard Worker	*" $dir "*) ;;
7430*6236dae4SAndroid Build Coastguard Worker	*) func_append xrpath " $dir" ;;
7431*6236dae4SAndroid Build Coastguard Worker	esac
7432*6236dae4SAndroid Build Coastguard Worker	continue
7433*6236dae4SAndroid Build Coastguard Worker	;;
7434*6236dae4SAndroid Build Coastguard Worker
7435*6236dae4SAndroid Build Coastguard Worker      -shared)
7436*6236dae4SAndroid Build Coastguard Worker	# The effects of -shared are defined in a previous loop.
7437*6236dae4SAndroid Build Coastguard Worker	continue
7438*6236dae4SAndroid Build Coastguard Worker	;;
7439*6236dae4SAndroid Build Coastguard Worker
7440*6236dae4SAndroid Build Coastguard Worker      -shrext)
7441*6236dae4SAndroid Build Coastguard Worker	prev=shrext
7442*6236dae4SAndroid Build Coastguard Worker	continue
7443*6236dae4SAndroid Build Coastguard Worker	;;
7444*6236dae4SAndroid Build Coastguard Worker
7445*6236dae4SAndroid Build Coastguard Worker      -static | -static-libtool-libs)
7446*6236dae4SAndroid Build Coastguard Worker	# The effects of -static are defined in a previous loop.
7447*6236dae4SAndroid Build Coastguard Worker	# We used to do the same as -all-static on platforms that
7448*6236dae4SAndroid Build Coastguard Worker	# didn't have a PIC flag, but the assumption that the effects
7449*6236dae4SAndroid Build Coastguard Worker	# would be equivalent was wrong.  It would break on at least
7450*6236dae4SAndroid Build Coastguard Worker	# Digital Unix and AIX.
7451*6236dae4SAndroid Build Coastguard Worker	continue
7452*6236dae4SAndroid Build Coastguard Worker	;;
7453*6236dae4SAndroid Build Coastguard Worker
7454*6236dae4SAndroid Build Coastguard Worker      -thread-safe)
7455*6236dae4SAndroid Build Coastguard Worker	thread_safe=yes
7456*6236dae4SAndroid Build Coastguard Worker	continue
7457*6236dae4SAndroid Build Coastguard Worker	;;
7458*6236dae4SAndroid Build Coastguard Worker
7459*6236dae4SAndroid Build Coastguard Worker      -version-info)
7460*6236dae4SAndroid Build Coastguard Worker	prev=vinfo
7461*6236dae4SAndroid Build Coastguard Worker	continue
7462*6236dae4SAndroid Build Coastguard Worker	;;
7463*6236dae4SAndroid Build Coastguard Worker
7464*6236dae4SAndroid Build Coastguard Worker      -version-number)
7465*6236dae4SAndroid Build Coastguard Worker	prev=vinfo
7466*6236dae4SAndroid Build Coastguard Worker	vinfo_number=yes
7467*6236dae4SAndroid Build Coastguard Worker	continue
7468*6236dae4SAndroid Build Coastguard Worker	;;
7469*6236dae4SAndroid Build Coastguard Worker
7470*6236dae4SAndroid Build Coastguard Worker      -weak)
7471*6236dae4SAndroid Build Coastguard Worker        prev=weak
7472*6236dae4SAndroid Build Coastguard Worker	continue
7473*6236dae4SAndroid Build Coastguard Worker	;;
7474*6236dae4SAndroid Build Coastguard Worker
7475*6236dae4SAndroid Build Coastguard Worker      -Wc,*)
7476*6236dae4SAndroid Build Coastguard Worker	func_stripname '-Wc,' '' "$arg"
7477*6236dae4SAndroid Build Coastguard Worker	args=$func_stripname_result
7478*6236dae4SAndroid Build Coastguard Worker	arg=
7479*6236dae4SAndroid Build Coastguard Worker	save_ifs=$IFS; IFS=,
7480*6236dae4SAndroid Build Coastguard Worker	for flag in $args; do
7481*6236dae4SAndroid Build Coastguard Worker	  IFS=$save_ifs
7482*6236dae4SAndroid Build Coastguard Worker          func_quote_arg pretty "$flag"
7483*6236dae4SAndroid Build Coastguard Worker	  func_append arg " $func_quote_arg_result"
7484*6236dae4SAndroid Build Coastguard Worker	  func_append compiler_flags " $func_quote_arg_result"
7485*6236dae4SAndroid Build Coastguard Worker	done
7486*6236dae4SAndroid Build Coastguard Worker	IFS=$save_ifs
7487*6236dae4SAndroid Build Coastguard Worker	func_stripname ' ' '' "$arg"
7488*6236dae4SAndroid Build Coastguard Worker	arg=$func_stripname_result
7489*6236dae4SAndroid Build Coastguard Worker	;;
7490*6236dae4SAndroid Build Coastguard Worker
7491*6236dae4SAndroid Build Coastguard Worker      -Wl,*)
7492*6236dae4SAndroid Build Coastguard Worker	func_stripname '-Wl,' '' "$arg"
7493*6236dae4SAndroid Build Coastguard Worker	args=$func_stripname_result
7494*6236dae4SAndroid Build Coastguard Worker	arg=
7495*6236dae4SAndroid Build Coastguard Worker	save_ifs=$IFS; IFS=,
7496*6236dae4SAndroid Build Coastguard Worker	for flag in $args; do
7497*6236dae4SAndroid Build Coastguard Worker	  IFS=$save_ifs
7498*6236dae4SAndroid Build Coastguard Worker          func_quote_arg pretty "$flag"
7499*6236dae4SAndroid Build Coastguard Worker	  func_append arg " $wl$func_quote_arg_result"
7500*6236dae4SAndroid Build Coastguard Worker	  func_append compiler_flags " $wl$func_quote_arg_result"
7501*6236dae4SAndroid Build Coastguard Worker	  func_append linker_flags " $func_quote_arg_result"
7502*6236dae4SAndroid Build Coastguard Worker	done
7503*6236dae4SAndroid Build Coastguard Worker	IFS=$save_ifs
7504*6236dae4SAndroid Build Coastguard Worker	func_stripname ' ' '' "$arg"
7505*6236dae4SAndroid Build Coastguard Worker	arg=$func_stripname_result
7506*6236dae4SAndroid Build Coastguard Worker	;;
7507*6236dae4SAndroid Build Coastguard Worker
7508*6236dae4SAndroid Build Coastguard Worker      -Xassembler)
7509*6236dae4SAndroid Build Coastguard Worker        prev=xassembler
7510*6236dae4SAndroid Build Coastguard Worker        continue
7511*6236dae4SAndroid Build Coastguard Worker        ;;
7512*6236dae4SAndroid Build Coastguard Worker
7513*6236dae4SAndroid Build Coastguard Worker      -Xcompiler)
7514*6236dae4SAndroid Build Coastguard Worker	prev=xcompiler
7515*6236dae4SAndroid Build Coastguard Worker	continue
7516*6236dae4SAndroid Build Coastguard Worker	;;
7517*6236dae4SAndroid Build Coastguard Worker
7518*6236dae4SAndroid Build Coastguard Worker      -Xlinker)
7519*6236dae4SAndroid Build Coastguard Worker	prev=xlinker
7520*6236dae4SAndroid Build Coastguard Worker	continue
7521*6236dae4SAndroid Build Coastguard Worker	;;
7522*6236dae4SAndroid Build Coastguard Worker
7523*6236dae4SAndroid Build Coastguard Worker      -XCClinker)
7524*6236dae4SAndroid Build Coastguard Worker	prev=xcclinker
7525*6236dae4SAndroid Build Coastguard Worker	continue
7526*6236dae4SAndroid Build Coastguard Worker	;;
7527*6236dae4SAndroid Build Coastguard Worker
7528*6236dae4SAndroid Build Coastguard Worker      # -msg_* for osf cc
7529*6236dae4SAndroid Build Coastguard Worker      -msg_*)
7530*6236dae4SAndroid Build Coastguard Worker	func_quote_arg pretty "$arg"
7531*6236dae4SAndroid Build Coastguard Worker	arg=$func_quote_arg_result
7532*6236dae4SAndroid Build Coastguard Worker	;;
7533*6236dae4SAndroid Build Coastguard Worker
7534*6236dae4SAndroid Build Coastguard Worker      # Flags to be passed through unchanged, with rationale:
7535*6236dae4SAndroid Build Coastguard Worker      # -64, -mips[0-9]      enable 64-bit mode for the SGI compiler
7536*6236dae4SAndroid Build Coastguard Worker      # -r[0-9][0-9]*        specify processor for the SGI compiler
7537*6236dae4SAndroid Build Coastguard Worker      # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler
7538*6236dae4SAndroid Build Coastguard Worker      # +DA*, +DD*           enable 64-bit mode for the HP compiler
7539*6236dae4SAndroid Build Coastguard Worker      # -q*                  compiler args for the IBM compiler
7540*6236dae4SAndroid Build Coastguard Worker      # -m*, -t[45]*, -txscale* architecture-specific flags for GCC
7541*6236dae4SAndroid Build Coastguard Worker      # -F/path              path to uninstalled frameworks, gcc on darwin
7542*6236dae4SAndroid Build Coastguard Worker      # -p, -pg, --coverage, -fprofile-*  profiling flags for GCC
7543*6236dae4SAndroid Build Coastguard Worker      # -fstack-protector*   stack protector flags for GCC
7544*6236dae4SAndroid Build Coastguard Worker      # @file                GCC response files
7545*6236dae4SAndroid Build Coastguard Worker      # -tp=*                Portland pgcc target processor selection
7546*6236dae4SAndroid Build Coastguard Worker      # --sysroot=*          for sysroot support
7547*6236dae4SAndroid Build Coastguard Worker      # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization
7548*6236dae4SAndroid Build Coastguard Worker      # -specs=*             GCC specs files
7549*6236dae4SAndroid Build Coastguard Worker      # -stdlib=*            select c++ std lib with clang
7550*6236dae4SAndroid Build Coastguard Worker      # -fsanitize=*         Clang/GCC memory and address sanitizer
7551*6236dae4SAndroid Build Coastguard Worker      # -fuse-ld=*           Linker select flags for GCC
7552*6236dae4SAndroid Build Coastguard Worker      # -static-*            direct GCC to link specific libraries statically
7553*6236dae4SAndroid Build Coastguard Worker      # -fcilkplus           Cilk Plus language extension features for C/C++
7554*6236dae4SAndroid Build Coastguard Worker      # -Wa,*                Pass flags directly to the assembler
7555*6236dae4SAndroid Build Coastguard Worker      -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
7556*6236dae4SAndroid Build Coastguard Worker      -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
7557*6236dae4SAndroid Build Coastguard Worker      -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \
7558*6236dae4SAndroid Build Coastguard Worker      -specs=*|-fsanitize=*|-fuse-ld=*|-static-*|-fcilkplus|-Wa,*)
7559*6236dae4SAndroid Build Coastguard Worker        func_quote_arg pretty "$arg"
7560*6236dae4SAndroid Build Coastguard Worker	arg=$func_quote_arg_result
7561*6236dae4SAndroid Build Coastguard Worker        func_append compile_command " $arg"
7562*6236dae4SAndroid Build Coastguard Worker        func_append finalize_command " $arg"
7563*6236dae4SAndroid Build Coastguard Worker        func_append compiler_flags " $arg"
7564*6236dae4SAndroid Build Coastguard Worker        continue
7565*6236dae4SAndroid Build Coastguard Worker        ;;
7566*6236dae4SAndroid Build Coastguard Worker
7567*6236dae4SAndroid Build Coastguard Worker      -Z*)
7568*6236dae4SAndroid Build Coastguard Worker        if test os2 = "`expr $host : '.*\(os2\)'`"; then
7569*6236dae4SAndroid Build Coastguard Worker          # OS/2 uses -Zxxx to specify OS/2-specific options
7570*6236dae4SAndroid Build Coastguard Worker	  compiler_flags="$compiler_flags $arg"
7571*6236dae4SAndroid Build Coastguard Worker	  func_append compile_command " $arg"
7572*6236dae4SAndroid Build Coastguard Worker	  func_append finalize_command " $arg"
7573*6236dae4SAndroid Build Coastguard Worker	  case $arg in
7574*6236dae4SAndroid Build Coastguard Worker	  -Zlinker | -Zstack)
7575*6236dae4SAndroid Build Coastguard Worker	    prev=xcompiler
7576*6236dae4SAndroid Build Coastguard Worker	    ;;
7577*6236dae4SAndroid Build Coastguard Worker	  esac
7578*6236dae4SAndroid Build Coastguard Worker	  continue
7579*6236dae4SAndroid Build Coastguard Worker        else
7580*6236dae4SAndroid Build Coastguard Worker	  # Otherwise treat like 'Some other compiler flag' below
7581*6236dae4SAndroid Build Coastguard Worker	  func_quote_arg pretty "$arg"
7582*6236dae4SAndroid Build Coastguard Worker	  arg=$func_quote_arg_result
7583*6236dae4SAndroid Build Coastguard Worker        fi
7584*6236dae4SAndroid Build Coastguard Worker	;;
7585*6236dae4SAndroid Build Coastguard Worker
7586*6236dae4SAndroid Build Coastguard Worker      # Some other compiler flag.
7587*6236dae4SAndroid Build Coastguard Worker      -* | +*)
7588*6236dae4SAndroid Build Coastguard Worker        func_quote_arg pretty "$arg"
7589*6236dae4SAndroid Build Coastguard Worker	arg=$func_quote_arg_result
7590*6236dae4SAndroid Build Coastguard Worker	;;
7591*6236dae4SAndroid Build Coastguard Worker
7592*6236dae4SAndroid Build Coastguard Worker      *.$objext)
7593*6236dae4SAndroid Build Coastguard Worker	# A standard object.
7594*6236dae4SAndroid Build Coastguard Worker	func_append objs " $arg"
7595*6236dae4SAndroid Build Coastguard Worker	;;
7596*6236dae4SAndroid Build Coastguard Worker
7597*6236dae4SAndroid Build Coastguard Worker      *.lo)
7598*6236dae4SAndroid Build Coastguard Worker	# A libtool-controlled object.
7599*6236dae4SAndroid Build Coastguard Worker
7600*6236dae4SAndroid Build Coastguard Worker	# Check to see that this really is a libtool object.
7601*6236dae4SAndroid Build Coastguard Worker	if func_lalib_unsafe_p "$arg"; then
7602*6236dae4SAndroid Build Coastguard Worker	  pic_object=
7603*6236dae4SAndroid Build Coastguard Worker	  non_pic_object=
7604*6236dae4SAndroid Build Coastguard Worker
7605*6236dae4SAndroid Build Coastguard Worker	  # Read the .lo file
7606*6236dae4SAndroid Build Coastguard Worker	  func_source "$arg"
7607*6236dae4SAndroid Build Coastguard Worker
7608*6236dae4SAndroid Build Coastguard Worker	  if test -z "$pic_object" ||
7609*6236dae4SAndroid Build Coastguard Worker	     test -z "$non_pic_object" ||
7610*6236dae4SAndroid Build Coastguard Worker	     test none = "$pic_object" &&
7611*6236dae4SAndroid Build Coastguard Worker	     test none = "$non_pic_object"; then
7612*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "cannot find name of object for '$arg'"
7613*6236dae4SAndroid Build Coastguard Worker	  fi
7614*6236dae4SAndroid Build Coastguard Worker
7615*6236dae4SAndroid Build Coastguard Worker	  # Extract subdirectory from the argument.
7616*6236dae4SAndroid Build Coastguard Worker	  func_dirname "$arg" "/" ""
7617*6236dae4SAndroid Build Coastguard Worker	  xdir=$func_dirname_result
7618*6236dae4SAndroid Build Coastguard Worker
7619*6236dae4SAndroid Build Coastguard Worker	  test none = "$pic_object" || {
7620*6236dae4SAndroid Build Coastguard Worker	    # Prepend the subdirectory the object is found in.
7621*6236dae4SAndroid Build Coastguard Worker	    pic_object=$xdir$pic_object
7622*6236dae4SAndroid Build Coastguard Worker
7623*6236dae4SAndroid Build Coastguard Worker	    if test dlfiles = "$prev"; then
7624*6236dae4SAndroid Build Coastguard Worker	      if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then
7625*6236dae4SAndroid Build Coastguard Worker		func_append dlfiles " $pic_object"
7626*6236dae4SAndroid Build Coastguard Worker		prev=
7627*6236dae4SAndroid Build Coastguard Worker		continue
7628*6236dae4SAndroid Build Coastguard Worker	      else
7629*6236dae4SAndroid Build Coastguard Worker		# If libtool objects are unsupported, then we need to preload.
7630*6236dae4SAndroid Build Coastguard Worker		prev=dlprefiles
7631*6236dae4SAndroid Build Coastguard Worker	      fi
7632*6236dae4SAndroid Build Coastguard Worker	    fi
7633*6236dae4SAndroid Build Coastguard Worker
7634*6236dae4SAndroid Build Coastguard Worker	    # CHECK ME:  I think I busted this.  -Ossama
7635*6236dae4SAndroid Build Coastguard Worker	    if test dlprefiles = "$prev"; then
7636*6236dae4SAndroid Build Coastguard Worker	      # Preload the old-style object.
7637*6236dae4SAndroid Build Coastguard Worker	      func_append dlprefiles " $pic_object"
7638*6236dae4SAndroid Build Coastguard Worker	      prev=
7639*6236dae4SAndroid Build Coastguard Worker	    fi
7640*6236dae4SAndroid Build Coastguard Worker
7641*6236dae4SAndroid Build Coastguard Worker	    # A PIC object.
7642*6236dae4SAndroid Build Coastguard Worker	    func_append libobjs " $pic_object"
7643*6236dae4SAndroid Build Coastguard Worker	    arg=$pic_object
7644*6236dae4SAndroid Build Coastguard Worker	  }
7645*6236dae4SAndroid Build Coastguard Worker
7646*6236dae4SAndroid Build Coastguard Worker	  # Non-PIC object.
7647*6236dae4SAndroid Build Coastguard Worker	  if test none != "$non_pic_object"; then
7648*6236dae4SAndroid Build Coastguard Worker	    # Prepend the subdirectory the object is found in.
7649*6236dae4SAndroid Build Coastguard Worker	    non_pic_object=$xdir$non_pic_object
7650*6236dae4SAndroid Build Coastguard Worker
7651*6236dae4SAndroid Build Coastguard Worker	    # A standard non-PIC object
7652*6236dae4SAndroid Build Coastguard Worker	    func_append non_pic_objects " $non_pic_object"
7653*6236dae4SAndroid Build Coastguard Worker	    if test -z "$pic_object" || test none = "$pic_object"; then
7654*6236dae4SAndroid Build Coastguard Worker	      arg=$non_pic_object
7655*6236dae4SAndroid Build Coastguard Worker	    fi
7656*6236dae4SAndroid Build Coastguard Worker	  else
7657*6236dae4SAndroid Build Coastguard Worker	    # If the PIC object exists, use it instead.
7658*6236dae4SAndroid Build Coastguard Worker	    # $xdir was prepended to $pic_object above.
7659*6236dae4SAndroid Build Coastguard Worker	    non_pic_object=$pic_object
7660*6236dae4SAndroid Build Coastguard Worker	    func_append non_pic_objects " $non_pic_object"
7661*6236dae4SAndroid Build Coastguard Worker	  fi
7662*6236dae4SAndroid Build Coastguard Worker	else
7663*6236dae4SAndroid Build Coastguard Worker	  # Only an error if not doing a dry-run.
7664*6236dae4SAndroid Build Coastguard Worker	  if $opt_dry_run; then
7665*6236dae4SAndroid Build Coastguard Worker	    # Extract subdirectory from the argument.
7666*6236dae4SAndroid Build Coastguard Worker	    func_dirname "$arg" "/" ""
7667*6236dae4SAndroid Build Coastguard Worker	    xdir=$func_dirname_result
7668*6236dae4SAndroid Build Coastguard Worker
7669*6236dae4SAndroid Build Coastguard Worker	    func_lo2o "$arg"
7670*6236dae4SAndroid Build Coastguard Worker	    pic_object=$xdir$objdir/$func_lo2o_result
7671*6236dae4SAndroid Build Coastguard Worker	    non_pic_object=$xdir$func_lo2o_result
7672*6236dae4SAndroid Build Coastguard Worker	    func_append libobjs " $pic_object"
7673*6236dae4SAndroid Build Coastguard Worker	    func_append non_pic_objects " $non_pic_object"
7674*6236dae4SAndroid Build Coastguard Worker	  else
7675*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "'$arg' is not a valid libtool object"
7676*6236dae4SAndroid Build Coastguard Worker	  fi
7677*6236dae4SAndroid Build Coastguard Worker	fi
7678*6236dae4SAndroid Build Coastguard Worker	;;
7679*6236dae4SAndroid Build Coastguard Worker
7680*6236dae4SAndroid Build Coastguard Worker      *.$libext)
7681*6236dae4SAndroid Build Coastguard Worker	# An archive.
7682*6236dae4SAndroid Build Coastguard Worker	func_append deplibs " $arg"
7683*6236dae4SAndroid Build Coastguard Worker	func_append old_deplibs " $arg"
7684*6236dae4SAndroid Build Coastguard Worker	continue
7685*6236dae4SAndroid Build Coastguard Worker	;;
7686*6236dae4SAndroid Build Coastguard Worker
7687*6236dae4SAndroid Build Coastguard Worker      *.la)
7688*6236dae4SAndroid Build Coastguard Worker	# A libtool-controlled library.
7689*6236dae4SAndroid Build Coastguard Worker
7690*6236dae4SAndroid Build Coastguard Worker	func_resolve_sysroot "$arg"
7691*6236dae4SAndroid Build Coastguard Worker	if test dlfiles = "$prev"; then
7692*6236dae4SAndroid Build Coastguard Worker	  # This library was specified with -dlopen.
7693*6236dae4SAndroid Build Coastguard Worker	  func_append dlfiles " $func_resolve_sysroot_result"
7694*6236dae4SAndroid Build Coastguard Worker	  prev=
7695*6236dae4SAndroid Build Coastguard Worker	elif test dlprefiles = "$prev"; then
7696*6236dae4SAndroid Build Coastguard Worker	  # The library was specified with -dlpreopen.
7697*6236dae4SAndroid Build Coastguard Worker	  func_append dlprefiles " $func_resolve_sysroot_result"
7698*6236dae4SAndroid Build Coastguard Worker	  prev=
7699*6236dae4SAndroid Build Coastguard Worker	else
7700*6236dae4SAndroid Build Coastguard Worker	  func_append deplibs " $func_resolve_sysroot_result"
7701*6236dae4SAndroid Build Coastguard Worker	fi
7702*6236dae4SAndroid Build Coastguard Worker	continue
7703*6236dae4SAndroid Build Coastguard Worker	;;
7704*6236dae4SAndroid Build Coastguard Worker
7705*6236dae4SAndroid Build Coastguard Worker      # Some other compiler argument.
7706*6236dae4SAndroid Build Coastguard Worker      *)
7707*6236dae4SAndroid Build Coastguard Worker	# Unknown arguments in both finalize_command and compile_command need
7708*6236dae4SAndroid Build Coastguard Worker	# to be aesthetically quoted because they are evaled later.
7709*6236dae4SAndroid Build Coastguard Worker	func_quote_arg pretty "$arg"
7710*6236dae4SAndroid Build Coastguard Worker	arg=$func_quote_arg_result
7711*6236dae4SAndroid Build Coastguard Worker	;;
7712*6236dae4SAndroid Build Coastguard Worker      esac # arg
7713*6236dae4SAndroid Build Coastguard Worker
7714*6236dae4SAndroid Build Coastguard Worker      # Now actually substitute the argument into the commands.
7715*6236dae4SAndroid Build Coastguard Worker      if test -n "$arg"; then
7716*6236dae4SAndroid Build Coastguard Worker	func_append compile_command " $arg"
7717*6236dae4SAndroid Build Coastguard Worker	func_append finalize_command " $arg"
7718*6236dae4SAndroid Build Coastguard Worker      fi
7719*6236dae4SAndroid Build Coastguard Worker    done # argument parsing loop
7720*6236dae4SAndroid Build Coastguard Worker
7721*6236dae4SAndroid Build Coastguard Worker    test -n "$prev" && \
7722*6236dae4SAndroid Build Coastguard Worker      func_fatal_help "the '$prevarg' option requires an argument"
7723*6236dae4SAndroid Build Coastguard Worker
7724*6236dae4SAndroid Build Coastguard Worker    if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then
7725*6236dae4SAndroid Build Coastguard Worker      eval arg=\"$export_dynamic_flag_spec\"
7726*6236dae4SAndroid Build Coastguard Worker      func_append compile_command " $arg"
7727*6236dae4SAndroid Build Coastguard Worker      func_append finalize_command " $arg"
7728*6236dae4SAndroid Build Coastguard Worker    fi
7729*6236dae4SAndroid Build Coastguard Worker
7730*6236dae4SAndroid Build Coastguard Worker    oldlibs=
7731*6236dae4SAndroid Build Coastguard Worker    # calculate the name of the file, without its directory
7732*6236dae4SAndroid Build Coastguard Worker    func_basename "$output"
7733*6236dae4SAndroid Build Coastguard Worker    outputname=$func_basename_result
7734*6236dae4SAndroid Build Coastguard Worker    libobjs_save=$libobjs
7735*6236dae4SAndroid Build Coastguard Worker
7736*6236dae4SAndroid Build Coastguard Worker    if test -n "$shlibpath_var"; then
7737*6236dae4SAndroid Build Coastguard Worker      # get the directories listed in $shlibpath_var
7738*6236dae4SAndroid Build Coastguard Worker      eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\`
7739*6236dae4SAndroid Build Coastguard Worker    else
7740*6236dae4SAndroid Build Coastguard Worker      shlib_search_path=
7741*6236dae4SAndroid Build Coastguard Worker    fi
7742*6236dae4SAndroid Build Coastguard Worker    eval sys_lib_search_path=\"$sys_lib_search_path_spec\"
7743*6236dae4SAndroid Build Coastguard Worker    eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\"
7744*6236dae4SAndroid Build Coastguard Worker
7745*6236dae4SAndroid Build Coastguard Worker    # Definition is injected by LT_CONFIG during libtool generation.
7746*6236dae4SAndroid Build Coastguard Worker    func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH"
7747*6236dae4SAndroid Build Coastguard Worker
7748*6236dae4SAndroid Build Coastguard Worker    func_dirname "$output" "/" ""
7749*6236dae4SAndroid Build Coastguard Worker    output_objdir=$func_dirname_result$objdir
7750*6236dae4SAndroid Build Coastguard Worker    func_to_tool_file "$output_objdir/"
7751*6236dae4SAndroid Build Coastguard Worker    tool_output_objdir=$func_to_tool_file_result
7752*6236dae4SAndroid Build Coastguard Worker    # Create the object directory.
7753*6236dae4SAndroid Build Coastguard Worker    func_mkdir_p "$output_objdir"
7754*6236dae4SAndroid Build Coastguard Worker
7755*6236dae4SAndroid Build Coastguard Worker    # Determine the type of output
7756*6236dae4SAndroid Build Coastguard Worker    case $output in
7757*6236dae4SAndroid Build Coastguard Worker    "")
7758*6236dae4SAndroid Build Coastguard Worker      func_fatal_help "you must specify an output file"
7759*6236dae4SAndroid Build Coastguard Worker      ;;
7760*6236dae4SAndroid Build Coastguard Worker    *.$libext) linkmode=oldlib ;;
7761*6236dae4SAndroid Build Coastguard Worker    *.lo | *.$objext) linkmode=obj ;;
7762*6236dae4SAndroid Build Coastguard Worker    *.la) linkmode=lib ;;
7763*6236dae4SAndroid Build Coastguard Worker    *) linkmode=prog ;; # Anything else should be a program.
7764*6236dae4SAndroid Build Coastguard Worker    esac
7765*6236dae4SAndroid Build Coastguard Worker
7766*6236dae4SAndroid Build Coastguard Worker    specialdeplibs=
7767*6236dae4SAndroid Build Coastguard Worker
7768*6236dae4SAndroid Build Coastguard Worker    libs=
7769*6236dae4SAndroid Build Coastguard Worker    # Find all interdependent deplibs by searching for libraries
7770*6236dae4SAndroid Build Coastguard Worker    # that are linked more than once (e.g. -la -lb -la)
7771*6236dae4SAndroid Build Coastguard Worker    for deplib in $deplibs; do
7772*6236dae4SAndroid Build Coastguard Worker      if $opt_preserve_dup_deps; then
7773*6236dae4SAndroid Build Coastguard Worker	case "$libs " in
7774*6236dae4SAndroid Build Coastguard Worker	*" $deplib "*) func_append specialdeplibs " $deplib" ;;
7775*6236dae4SAndroid Build Coastguard Worker	esac
7776*6236dae4SAndroid Build Coastguard Worker      fi
7777*6236dae4SAndroid Build Coastguard Worker      func_append libs " $deplib"
7778*6236dae4SAndroid Build Coastguard Worker    done
7779*6236dae4SAndroid Build Coastguard Worker
7780*6236dae4SAndroid Build Coastguard Worker    if test lib = "$linkmode"; then
7781*6236dae4SAndroid Build Coastguard Worker      libs="$predeps $libs $compiler_lib_search_path $postdeps"
7782*6236dae4SAndroid Build Coastguard Worker
7783*6236dae4SAndroid Build Coastguard Worker      # Compute libraries that are listed more than once in $predeps
7784*6236dae4SAndroid Build Coastguard Worker      # $postdeps and mark them as special (i.e., whose duplicates are
7785*6236dae4SAndroid Build Coastguard Worker      # not to be eliminated).
7786*6236dae4SAndroid Build Coastguard Worker      pre_post_deps=
7787*6236dae4SAndroid Build Coastguard Worker      if $opt_duplicate_compiler_generated_deps; then
7788*6236dae4SAndroid Build Coastguard Worker	for pre_post_dep in $predeps $postdeps; do
7789*6236dae4SAndroid Build Coastguard Worker	  case "$pre_post_deps " in
7790*6236dae4SAndroid Build Coastguard Worker	  *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;;
7791*6236dae4SAndroid Build Coastguard Worker	  esac
7792*6236dae4SAndroid Build Coastguard Worker	  func_append pre_post_deps " $pre_post_dep"
7793*6236dae4SAndroid Build Coastguard Worker	done
7794*6236dae4SAndroid Build Coastguard Worker      fi
7795*6236dae4SAndroid Build Coastguard Worker      pre_post_deps=
7796*6236dae4SAndroid Build Coastguard Worker    fi
7797*6236dae4SAndroid Build Coastguard Worker
7798*6236dae4SAndroid Build Coastguard Worker    deplibs=
7799*6236dae4SAndroid Build Coastguard Worker    newdependency_libs=
7800*6236dae4SAndroid Build Coastguard Worker    newlib_search_path=
7801*6236dae4SAndroid Build Coastguard Worker    need_relink=no # whether we're linking any uninstalled libtool libraries
7802*6236dae4SAndroid Build Coastguard Worker    notinst_deplibs= # not-installed libtool libraries
7803*6236dae4SAndroid Build Coastguard Worker    notinst_path= # paths that contain not-installed libtool libraries
7804*6236dae4SAndroid Build Coastguard Worker
7805*6236dae4SAndroid Build Coastguard Worker    case $linkmode in
7806*6236dae4SAndroid Build Coastguard Worker    lib)
7807*6236dae4SAndroid Build Coastguard Worker	passes="conv dlpreopen link"
7808*6236dae4SAndroid Build Coastguard Worker	for file in $dlfiles $dlprefiles; do
7809*6236dae4SAndroid Build Coastguard Worker	  case $file in
7810*6236dae4SAndroid Build Coastguard Worker	  *.la) ;;
7811*6236dae4SAndroid Build Coastguard Worker	  *)
7812*6236dae4SAndroid Build Coastguard Worker	    func_fatal_help "libraries can '-dlopen' only libtool libraries: $file"
7813*6236dae4SAndroid Build Coastguard Worker	    ;;
7814*6236dae4SAndroid Build Coastguard Worker	  esac
7815*6236dae4SAndroid Build Coastguard Worker	done
7816*6236dae4SAndroid Build Coastguard Worker	;;
7817*6236dae4SAndroid Build Coastguard Worker    prog)
7818*6236dae4SAndroid Build Coastguard Worker	compile_deplibs=
7819*6236dae4SAndroid Build Coastguard Worker	finalize_deplibs=
7820*6236dae4SAndroid Build Coastguard Worker	alldeplibs=false
7821*6236dae4SAndroid Build Coastguard Worker	newdlfiles=
7822*6236dae4SAndroid Build Coastguard Worker	newdlprefiles=
7823*6236dae4SAndroid Build Coastguard Worker	passes="conv scan dlopen dlpreopen link"
7824*6236dae4SAndroid Build Coastguard Worker	;;
7825*6236dae4SAndroid Build Coastguard Worker    *)  passes="conv"
7826*6236dae4SAndroid Build Coastguard Worker	;;
7827*6236dae4SAndroid Build Coastguard Worker    esac
7828*6236dae4SAndroid Build Coastguard Worker
7829*6236dae4SAndroid Build Coastguard Worker    for pass in $passes; do
7830*6236dae4SAndroid Build Coastguard Worker      # The preopen pass in lib mode reverses $deplibs; put it back here
7831*6236dae4SAndroid Build Coastguard Worker      # so that -L comes before libs that need it for instance...
7832*6236dae4SAndroid Build Coastguard Worker      if test lib,link = "$linkmode,$pass"; then
7833*6236dae4SAndroid Build Coastguard Worker	## FIXME: Find the place where the list is rebuilt in the wrong
7834*6236dae4SAndroid Build Coastguard Worker	##        order, and fix it there properly
7835*6236dae4SAndroid Build Coastguard Worker        tmp_deplibs=
7836*6236dae4SAndroid Build Coastguard Worker	for deplib in $deplibs; do
7837*6236dae4SAndroid Build Coastguard Worker	  tmp_deplibs="$deplib $tmp_deplibs"
7838*6236dae4SAndroid Build Coastguard Worker	done
7839*6236dae4SAndroid Build Coastguard Worker	deplibs=$tmp_deplibs
7840*6236dae4SAndroid Build Coastguard Worker      fi
7841*6236dae4SAndroid Build Coastguard Worker
7842*6236dae4SAndroid Build Coastguard Worker      if test lib,link = "$linkmode,$pass" ||
7843*6236dae4SAndroid Build Coastguard Worker	 test prog,scan = "$linkmode,$pass"; then
7844*6236dae4SAndroid Build Coastguard Worker	libs=$deplibs
7845*6236dae4SAndroid Build Coastguard Worker	deplibs=
7846*6236dae4SAndroid Build Coastguard Worker      fi
7847*6236dae4SAndroid Build Coastguard Worker      if test prog = "$linkmode"; then
7848*6236dae4SAndroid Build Coastguard Worker	case $pass in
7849*6236dae4SAndroid Build Coastguard Worker	dlopen) libs=$dlfiles ;;
7850*6236dae4SAndroid Build Coastguard Worker	dlpreopen) libs=$dlprefiles ;;
7851*6236dae4SAndroid Build Coastguard Worker	link)
7852*6236dae4SAndroid Build Coastguard Worker	  libs="$deplibs %DEPLIBS%"
7853*6236dae4SAndroid Build Coastguard Worker	  test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs"
7854*6236dae4SAndroid Build Coastguard Worker	  ;;
7855*6236dae4SAndroid Build Coastguard Worker	esac
7856*6236dae4SAndroid Build Coastguard Worker      fi
7857*6236dae4SAndroid Build Coastguard Worker      if test lib,dlpreopen = "$linkmode,$pass"; then
7858*6236dae4SAndroid Build Coastguard Worker	# Collect and forward deplibs of preopened libtool libs
7859*6236dae4SAndroid Build Coastguard Worker	for lib in $dlprefiles; do
7860*6236dae4SAndroid Build Coastguard Worker	  # Ignore non-libtool-libs
7861*6236dae4SAndroid Build Coastguard Worker	  dependency_libs=
7862*6236dae4SAndroid Build Coastguard Worker	  func_resolve_sysroot "$lib"
7863*6236dae4SAndroid Build Coastguard Worker	  case $lib in
7864*6236dae4SAndroid Build Coastguard Worker	  *.la)	func_source "$func_resolve_sysroot_result" ;;
7865*6236dae4SAndroid Build Coastguard Worker	  esac
7866*6236dae4SAndroid Build Coastguard Worker
7867*6236dae4SAndroid Build Coastguard Worker	  # Collect preopened libtool deplibs, except any this library
7868*6236dae4SAndroid Build Coastguard Worker	  # has declared as weak libs
7869*6236dae4SAndroid Build Coastguard Worker	  for deplib in $dependency_libs; do
7870*6236dae4SAndroid Build Coastguard Worker	    func_basename "$deplib"
7871*6236dae4SAndroid Build Coastguard Worker            deplib_base=$func_basename_result
7872*6236dae4SAndroid Build Coastguard Worker	    case " $weak_libs " in
7873*6236dae4SAndroid Build Coastguard Worker	    *" $deplib_base "*) ;;
7874*6236dae4SAndroid Build Coastguard Worker	    *) func_append deplibs " $deplib" ;;
7875*6236dae4SAndroid Build Coastguard Worker	    esac
7876*6236dae4SAndroid Build Coastguard Worker	  done
7877*6236dae4SAndroid Build Coastguard Worker	done
7878*6236dae4SAndroid Build Coastguard Worker	libs=$dlprefiles
7879*6236dae4SAndroid Build Coastguard Worker      fi
7880*6236dae4SAndroid Build Coastguard Worker      if test dlopen = "$pass"; then
7881*6236dae4SAndroid Build Coastguard Worker	# Collect dlpreopened libraries
7882*6236dae4SAndroid Build Coastguard Worker	save_deplibs=$deplibs
7883*6236dae4SAndroid Build Coastguard Worker	deplibs=
7884*6236dae4SAndroid Build Coastguard Worker      fi
7885*6236dae4SAndroid Build Coastguard Worker
7886*6236dae4SAndroid Build Coastguard Worker      for deplib in $libs; do
7887*6236dae4SAndroid Build Coastguard Worker	lib=
7888*6236dae4SAndroid Build Coastguard Worker	found=false
7889*6236dae4SAndroid Build Coastguard Worker	case $deplib in
7890*6236dae4SAndroid Build Coastguard Worker	-mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \
7891*6236dae4SAndroid Build Coastguard Worker        |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*)
7892*6236dae4SAndroid Build Coastguard Worker	  if test prog,link = "$linkmode,$pass"; then
7893*6236dae4SAndroid Build Coastguard Worker	    compile_deplibs="$deplib $compile_deplibs"
7894*6236dae4SAndroid Build Coastguard Worker	    finalize_deplibs="$deplib $finalize_deplibs"
7895*6236dae4SAndroid Build Coastguard Worker	  else
7896*6236dae4SAndroid Build Coastguard Worker	    func_append compiler_flags " $deplib"
7897*6236dae4SAndroid Build Coastguard Worker	    if test lib = "$linkmode"; then
7898*6236dae4SAndroid Build Coastguard Worker		case "$new_inherited_linker_flags " in
7899*6236dae4SAndroid Build Coastguard Worker		    *" $deplib "*) ;;
7900*6236dae4SAndroid Build Coastguard Worker		    * ) func_append new_inherited_linker_flags " $deplib" ;;
7901*6236dae4SAndroid Build Coastguard Worker		esac
7902*6236dae4SAndroid Build Coastguard Worker	    fi
7903*6236dae4SAndroid Build Coastguard Worker	  fi
7904*6236dae4SAndroid Build Coastguard Worker	  continue
7905*6236dae4SAndroid Build Coastguard Worker	  ;;
7906*6236dae4SAndroid Build Coastguard Worker	-l*)
7907*6236dae4SAndroid Build Coastguard Worker	  if test lib != "$linkmode" && test prog != "$linkmode"; then
7908*6236dae4SAndroid Build Coastguard Worker	    func_warning "'-l' is ignored for archives/objects"
7909*6236dae4SAndroid Build Coastguard Worker	    continue
7910*6236dae4SAndroid Build Coastguard Worker	  fi
7911*6236dae4SAndroid Build Coastguard Worker	  func_stripname '-l' '' "$deplib"
7912*6236dae4SAndroid Build Coastguard Worker	  name=$func_stripname_result
7913*6236dae4SAndroid Build Coastguard Worker	  if test lib = "$linkmode"; then
7914*6236dae4SAndroid Build Coastguard Worker	    searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path"
7915*6236dae4SAndroid Build Coastguard Worker	  else
7916*6236dae4SAndroid Build Coastguard Worker	    searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path"
7917*6236dae4SAndroid Build Coastguard Worker	  fi
7918*6236dae4SAndroid Build Coastguard Worker	  for searchdir in $searchdirs; do
7919*6236dae4SAndroid Build Coastguard Worker	    for search_ext in .la $std_shrext .so .a; do
7920*6236dae4SAndroid Build Coastguard Worker	      # Search the libtool library
7921*6236dae4SAndroid Build Coastguard Worker	      lib=$searchdir/lib$name$search_ext
7922*6236dae4SAndroid Build Coastguard Worker	      if test -f "$lib"; then
7923*6236dae4SAndroid Build Coastguard Worker		if test .la = "$search_ext"; then
7924*6236dae4SAndroid Build Coastguard Worker		  found=:
7925*6236dae4SAndroid Build Coastguard Worker		else
7926*6236dae4SAndroid Build Coastguard Worker		  found=false
7927*6236dae4SAndroid Build Coastguard Worker		fi
7928*6236dae4SAndroid Build Coastguard Worker		break 2
7929*6236dae4SAndroid Build Coastguard Worker	      fi
7930*6236dae4SAndroid Build Coastguard Worker	    done
7931*6236dae4SAndroid Build Coastguard Worker	  done
7932*6236dae4SAndroid Build Coastguard Worker	  if $found; then
7933*6236dae4SAndroid Build Coastguard Worker	    # deplib is a libtool library
7934*6236dae4SAndroid Build Coastguard Worker	    # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib,
7935*6236dae4SAndroid Build Coastguard Worker	    # We need to do some special things here, and not later.
7936*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$allow_libtool_libs_with_static_runtimes"; then
7937*6236dae4SAndroid Build Coastguard Worker	      case " $predeps $postdeps " in
7938*6236dae4SAndroid Build Coastguard Worker	      *" $deplib "*)
7939*6236dae4SAndroid Build Coastguard Worker		if func_lalib_p "$lib"; then
7940*6236dae4SAndroid Build Coastguard Worker		  library_names=
7941*6236dae4SAndroid Build Coastguard Worker		  old_library=
7942*6236dae4SAndroid Build Coastguard Worker		  func_source "$lib"
7943*6236dae4SAndroid Build Coastguard Worker		  for l in $old_library $library_names; do
7944*6236dae4SAndroid Build Coastguard Worker		    ll=$l
7945*6236dae4SAndroid Build Coastguard Worker		  done
7946*6236dae4SAndroid Build Coastguard Worker		  if test "X$ll" = "X$old_library"; then # only static version available
7947*6236dae4SAndroid Build Coastguard Worker		    found=false
7948*6236dae4SAndroid Build Coastguard Worker		    func_dirname "$lib" "" "."
7949*6236dae4SAndroid Build Coastguard Worker		    ladir=$func_dirname_result
7950*6236dae4SAndroid Build Coastguard Worker		    lib=$ladir/$old_library
7951*6236dae4SAndroid Build Coastguard Worker		    if test prog,link = "$linkmode,$pass"; then
7952*6236dae4SAndroid Build Coastguard Worker		      compile_deplibs="$deplib $compile_deplibs"
7953*6236dae4SAndroid Build Coastguard Worker		      finalize_deplibs="$deplib $finalize_deplibs"
7954*6236dae4SAndroid Build Coastguard Worker		    else
7955*6236dae4SAndroid Build Coastguard Worker		      deplibs="$deplib $deplibs"
7956*6236dae4SAndroid Build Coastguard Worker		      test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs"
7957*6236dae4SAndroid Build Coastguard Worker		    fi
7958*6236dae4SAndroid Build Coastguard Worker		    continue
7959*6236dae4SAndroid Build Coastguard Worker		  fi
7960*6236dae4SAndroid Build Coastguard Worker		fi
7961*6236dae4SAndroid Build Coastguard Worker		;;
7962*6236dae4SAndroid Build Coastguard Worker	      *) ;;
7963*6236dae4SAndroid Build Coastguard Worker	      esac
7964*6236dae4SAndroid Build Coastguard Worker	    fi
7965*6236dae4SAndroid Build Coastguard Worker	  else
7966*6236dae4SAndroid Build Coastguard Worker	    # deplib doesn't seem to be a libtool library
7967*6236dae4SAndroid Build Coastguard Worker	    if test prog,link = "$linkmode,$pass"; then
7968*6236dae4SAndroid Build Coastguard Worker	      compile_deplibs="$deplib $compile_deplibs"
7969*6236dae4SAndroid Build Coastguard Worker	      finalize_deplibs="$deplib $finalize_deplibs"
7970*6236dae4SAndroid Build Coastguard Worker	    else
7971*6236dae4SAndroid Build Coastguard Worker	      deplibs="$deplib $deplibs"
7972*6236dae4SAndroid Build Coastguard Worker	      test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs"
7973*6236dae4SAndroid Build Coastguard Worker	    fi
7974*6236dae4SAndroid Build Coastguard Worker	    continue
7975*6236dae4SAndroid Build Coastguard Worker	  fi
7976*6236dae4SAndroid Build Coastguard Worker	  ;; # -l
7977*6236dae4SAndroid Build Coastguard Worker	*.ltframework)
7978*6236dae4SAndroid Build Coastguard Worker	  if test prog,link = "$linkmode,$pass"; then
7979*6236dae4SAndroid Build Coastguard Worker	    compile_deplibs="$deplib $compile_deplibs"
7980*6236dae4SAndroid Build Coastguard Worker	    finalize_deplibs="$deplib $finalize_deplibs"
7981*6236dae4SAndroid Build Coastguard Worker	  else
7982*6236dae4SAndroid Build Coastguard Worker	    deplibs="$deplib $deplibs"
7983*6236dae4SAndroid Build Coastguard Worker	    if test lib = "$linkmode"; then
7984*6236dae4SAndroid Build Coastguard Worker		case "$new_inherited_linker_flags " in
7985*6236dae4SAndroid Build Coastguard Worker		    *" $deplib "*) ;;
7986*6236dae4SAndroid Build Coastguard Worker		    * ) func_append new_inherited_linker_flags " $deplib" ;;
7987*6236dae4SAndroid Build Coastguard Worker		esac
7988*6236dae4SAndroid Build Coastguard Worker	    fi
7989*6236dae4SAndroid Build Coastguard Worker	  fi
7990*6236dae4SAndroid Build Coastguard Worker	  continue
7991*6236dae4SAndroid Build Coastguard Worker	  ;;
7992*6236dae4SAndroid Build Coastguard Worker	-L*)
7993*6236dae4SAndroid Build Coastguard Worker	  case $linkmode in
7994*6236dae4SAndroid Build Coastguard Worker	  lib)
7995*6236dae4SAndroid Build Coastguard Worker	    deplibs="$deplib $deplibs"
7996*6236dae4SAndroid Build Coastguard Worker	    test conv = "$pass" && continue
7997*6236dae4SAndroid Build Coastguard Worker	    newdependency_libs="$deplib $newdependency_libs"
7998*6236dae4SAndroid Build Coastguard Worker	    func_stripname '-L' '' "$deplib"
7999*6236dae4SAndroid Build Coastguard Worker	    func_resolve_sysroot "$func_stripname_result"
8000*6236dae4SAndroid Build Coastguard Worker	    func_append newlib_search_path " $func_resolve_sysroot_result"
8001*6236dae4SAndroid Build Coastguard Worker	    ;;
8002*6236dae4SAndroid Build Coastguard Worker	  prog)
8003*6236dae4SAndroid Build Coastguard Worker	    if test conv = "$pass"; then
8004*6236dae4SAndroid Build Coastguard Worker	      deplibs="$deplib $deplibs"
8005*6236dae4SAndroid Build Coastguard Worker	      continue
8006*6236dae4SAndroid Build Coastguard Worker	    fi
8007*6236dae4SAndroid Build Coastguard Worker	    if test scan = "$pass"; then
8008*6236dae4SAndroid Build Coastguard Worker	      deplibs="$deplib $deplibs"
8009*6236dae4SAndroid Build Coastguard Worker	    else
8010*6236dae4SAndroid Build Coastguard Worker	      compile_deplibs="$deplib $compile_deplibs"
8011*6236dae4SAndroid Build Coastguard Worker	      finalize_deplibs="$deplib $finalize_deplibs"
8012*6236dae4SAndroid Build Coastguard Worker	    fi
8013*6236dae4SAndroid Build Coastguard Worker	    func_stripname '-L' '' "$deplib"
8014*6236dae4SAndroid Build Coastguard Worker	    func_resolve_sysroot "$func_stripname_result"
8015*6236dae4SAndroid Build Coastguard Worker	    func_append newlib_search_path " $func_resolve_sysroot_result"
8016*6236dae4SAndroid Build Coastguard Worker	    ;;
8017*6236dae4SAndroid Build Coastguard Worker	  *)
8018*6236dae4SAndroid Build Coastguard Worker	    func_warning "'-L' is ignored for archives/objects"
8019*6236dae4SAndroid Build Coastguard Worker	    ;;
8020*6236dae4SAndroid Build Coastguard Worker	  esac # linkmode
8021*6236dae4SAndroid Build Coastguard Worker	  continue
8022*6236dae4SAndroid Build Coastguard Worker	  ;; # -L
8023*6236dae4SAndroid Build Coastguard Worker	-R*)
8024*6236dae4SAndroid Build Coastguard Worker	  if test link = "$pass"; then
8025*6236dae4SAndroid Build Coastguard Worker	    func_stripname '-R' '' "$deplib"
8026*6236dae4SAndroid Build Coastguard Worker	    func_resolve_sysroot "$func_stripname_result"
8027*6236dae4SAndroid Build Coastguard Worker	    dir=$func_resolve_sysroot_result
8028*6236dae4SAndroid Build Coastguard Worker	    # Make sure the xrpath contains only unique directories.
8029*6236dae4SAndroid Build Coastguard Worker	    case "$xrpath " in
8030*6236dae4SAndroid Build Coastguard Worker	    *" $dir "*) ;;
8031*6236dae4SAndroid Build Coastguard Worker	    *) func_append xrpath " $dir" ;;
8032*6236dae4SAndroid Build Coastguard Worker	    esac
8033*6236dae4SAndroid Build Coastguard Worker	  fi
8034*6236dae4SAndroid Build Coastguard Worker	  deplibs="$deplib $deplibs"
8035*6236dae4SAndroid Build Coastguard Worker	  continue
8036*6236dae4SAndroid Build Coastguard Worker	  ;;
8037*6236dae4SAndroid Build Coastguard Worker	*.la)
8038*6236dae4SAndroid Build Coastguard Worker	  func_resolve_sysroot "$deplib"
8039*6236dae4SAndroid Build Coastguard Worker	  lib=$func_resolve_sysroot_result
8040*6236dae4SAndroid Build Coastguard Worker	  ;;
8041*6236dae4SAndroid Build Coastguard Worker	*.$libext)
8042*6236dae4SAndroid Build Coastguard Worker	  if test conv = "$pass"; then
8043*6236dae4SAndroid Build Coastguard Worker	    deplibs="$deplib $deplibs"
8044*6236dae4SAndroid Build Coastguard Worker	    continue
8045*6236dae4SAndroid Build Coastguard Worker	  fi
8046*6236dae4SAndroid Build Coastguard Worker	  case $linkmode in
8047*6236dae4SAndroid Build Coastguard Worker	  lib)
8048*6236dae4SAndroid Build Coastguard Worker	    # Linking convenience modules into shared libraries is allowed,
8049*6236dae4SAndroid Build Coastguard Worker	    # but linking other static libraries is non-portable.
8050*6236dae4SAndroid Build Coastguard Worker	    case " $dlpreconveniencelibs " in
8051*6236dae4SAndroid Build Coastguard Worker	    *" $deplib "*) ;;
8052*6236dae4SAndroid Build Coastguard Worker	    *)
8053*6236dae4SAndroid Build Coastguard Worker	      valid_a_lib=false
8054*6236dae4SAndroid Build Coastguard Worker	      case $deplibs_check_method in
8055*6236dae4SAndroid Build Coastguard Worker		match_pattern*)
8056*6236dae4SAndroid Build Coastguard Worker		  set dummy $deplibs_check_method; shift
8057*6236dae4SAndroid Build Coastguard Worker		  match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
8058*6236dae4SAndroid Build Coastguard Worker		  if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \
8059*6236dae4SAndroid Build Coastguard Worker		    | $EGREP "$match_pattern_regex" > /dev/null; then
8060*6236dae4SAndroid Build Coastguard Worker		    valid_a_lib=:
8061*6236dae4SAndroid Build Coastguard Worker		  fi
8062*6236dae4SAndroid Build Coastguard Worker		;;
8063*6236dae4SAndroid Build Coastguard Worker		pass_all)
8064*6236dae4SAndroid Build Coastguard Worker		  valid_a_lib=:
8065*6236dae4SAndroid Build Coastguard Worker		;;
8066*6236dae4SAndroid Build Coastguard Worker	      esac
8067*6236dae4SAndroid Build Coastguard Worker	      if $valid_a_lib; then
8068*6236dae4SAndroid Build Coastguard Worker		echo
8069*6236dae4SAndroid Build Coastguard Worker		$ECHO "*** Warning: Linking the shared library $output against the"
8070*6236dae4SAndroid Build Coastguard Worker		$ECHO "*** static library $deplib is not portable!"
8071*6236dae4SAndroid Build Coastguard Worker		deplibs="$deplib $deplibs"
8072*6236dae4SAndroid Build Coastguard Worker	      else
8073*6236dae4SAndroid Build Coastguard Worker		echo
8074*6236dae4SAndroid Build Coastguard Worker		$ECHO "*** Warning: Trying to link with static lib archive $deplib."
8075*6236dae4SAndroid Build Coastguard Worker		echo "*** I have the capability to make that library automatically link in when"
8076*6236dae4SAndroid Build Coastguard Worker		echo "*** you link to this library.  But I can only do this if you have a"
8077*6236dae4SAndroid Build Coastguard Worker		echo "*** shared version of the library, which you do not appear to have"
8078*6236dae4SAndroid Build Coastguard Worker		echo "*** because the file extensions .$libext of this argument makes me believe"
8079*6236dae4SAndroid Build Coastguard Worker		echo "*** that it is just a static archive that I should not use here."
8080*6236dae4SAndroid Build Coastguard Worker	      fi
8081*6236dae4SAndroid Build Coastguard Worker	      ;;
8082*6236dae4SAndroid Build Coastguard Worker	    esac
8083*6236dae4SAndroid Build Coastguard Worker	    continue
8084*6236dae4SAndroid Build Coastguard Worker	    ;;
8085*6236dae4SAndroid Build Coastguard Worker	  prog)
8086*6236dae4SAndroid Build Coastguard Worker	    if test link != "$pass"; then
8087*6236dae4SAndroid Build Coastguard Worker	      deplibs="$deplib $deplibs"
8088*6236dae4SAndroid Build Coastguard Worker	    else
8089*6236dae4SAndroid Build Coastguard Worker	      compile_deplibs="$deplib $compile_deplibs"
8090*6236dae4SAndroid Build Coastguard Worker	      finalize_deplibs="$deplib $finalize_deplibs"
8091*6236dae4SAndroid Build Coastguard Worker	    fi
8092*6236dae4SAndroid Build Coastguard Worker	    continue
8093*6236dae4SAndroid Build Coastguard Worker	    ;;
8094*6236dae4SAndroid Build Coastguard Worker	  esac # linkmode
8095*6236dae4SAndroid Build Coastguard Worker	  ;; # *.$libext
8096*6236dae4SAndroid Build Coastguard Worker	*.lo | *.$objext)
8097*6236dae4SAndroid Build Coastguard Worker	  if test conv = "$pass"; then
8098*6236dae4SAndroid Build Coastguard Worker	    deplibs="$deplib $deplibs"
8099*6236dae4SAndroid Build Coastguard Worker	  elif test prog = "$linkmode"; then
8100*6236dae4SAndroid Build Coastguard Worker	    if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then
8101*6236dae4SAndroid Build Coastguard Worker	      # If there is no dlopen support or we're linking statically,
8102*6236dae4SAndroid Build Coastguard Worker	      # we need to preload.
8103*6236dae4SAndroid Build Coastguard Worker	      func_append newdlprefiles " $deplib"
8104*6236dae4SAndroid Build Coastguard Worker	      compile_deplibs="$deplib $compile_deplibs"
8105*6236dae4SAndroid Build Coastguard Worker	      finalize_deplibs="$deplib $finalize_deplibs"
8106*6236dae4SAndroid Build Coastguard Worker	    else
8107*6236dae4SAndroid Build Coastguard Worker	      func_append newdlfiles " $deplib"
8108*6236dae4SAndroid Build Coastguard Worker	    fi
8109*6236dae4SAndroid Build Coastguard Worker	  fi
8110*6236dae4SAndroid Build Coastguard Worker	  continue
8111*6236dae4SAndroid Build Coastguard Worker	  ;;
8112*6236dae4SAndroid Build Coastguard Worker	%DEPLIBS%)
8113*6236dae4SAndroid Build Coastguard Worker	  alldeplibs=:
8114*6236dae4SAndroid Build Coastguard Worker	  continue
8115*6236dae4SAndroid Build Coastguard Worker	  ;;
8116*6236dae4SAndroid Build Coastguard Worker	esac # case $deplib
8117*6236dae4SAndroid Build Coastguard Worker
8118*6236dae4SAndroid Build Coastguard Worker	$found || test -f "$lib" \
8119*6236dae4SAndroid Build Coastguard Worker	  || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'"
8120*6236dae4SAndroid Build Coastguard Worker
8121*6236dae4SAndroid Build Coastguard Worker	# Check to see that this really is a libtool archive.
8122*6236dae4SAndroid Build Coastguard Worker	func_lalib_unsafe_p "$lib" \
8123*6236dae4SAndroid Build Coastguard Worker	  || func_fatal_error "'$lib' is not a valid libtool archive"
8124*6236dae4SAndroid Build Coastguard Worker
8125*6236dae4SAndroid Build Coastguard Worker	func_dirname "$lib" "" "."
8126*6236dae4SAndroid Build Coastguard Worker	ladir=$func_dirname_result
8127*6236dae4SAndroid Build Coastguard Worker
8128*6236dae4SAndroid Build Coastguard Worker	dlname=
8129*6236dae4SAndroid Build Coastguard Worker	dlopen=
8130*6236dae4SAndroid Build Coastguard Worker	dlpreopen=
8131*6236dae4SAndroid Build Coastguard Worker	libdir=
8132*6236dae4SAndroid Build Coastguard Worker	library_names=
8133*6236dae4SAndroid Build Coastguard Worker	old_library=
8134*6236dae4SAndroid Build Coastguard Worker	inherited_linker_flags=
8135*6236dae4SAndroid Build Coastguard Worker	# If the library was installed with an old release of libtool,
8136*6236dae4SAndroid Build Coastguard Worker	# it will not redefine variables installed, or shouldnotlink
8137*6236dae4SAndroid Build Coastguard Worker	installed=yes
8138*6236dae4SAndroid Build Coastguard Worker	shouldnotlink=no
8139*6236dae4SAndroid Build Coastguard Worker	avoidtemprpath=
8140*6236dae4SAndroid Build Coastguard Worker
8141*6236dae4SAndroid Build Coastguard Worker
8142*6236dae4SAndroid Build Coastguard Worker	# Read the .la file
8143*6236dae4SAndroid Build Coastguard Worker	func_source "$lib"
8144*6236dae4SAndroid Build Coastguard Worker
8145*6236dae4SAndroid Build Coastguard Worker	# Convert "-framework foo" to "foo.ltframework"
8146*6236dae4SAndroid Build Coastguard Worker	if test -n "$inherited_linker_flags"; then
8147*6236dae4SAndroid Build Coastguard Worker	  tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'`
8148*6236dae4SAndroid Build Coastguard Worker	  for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do
8149*6236dae4SAndroid Build Coastguard Worker	    case " $new_inherited_linker_flags " in
8150*6236dae4SAndroid Build Coastguard Worker	      *" $tmp_inherited_linker_flag "*) ;;
8151*6236dae4SAndroid Build Coastguard Worker	      *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";;
8152*6236dae4SAndroid Build Coastguard Worker	    esac
8153*6236dae4SAndroid Build Coastguard Worker	  done
8154*6236dae4SAndroid Build Coastguard Worker	fi
8155*6236dae4SAndroid Build Coastguard Worker	dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
8156*6236dae4SAndroid Build Coastguard Worker	if test lib,link = "$linkmode,$pass" ||
8157*6236dae4SAndroid Build Coastguard Worker	   test prog,scan = "$linkmode,$pass" ||
8158*6236dae4SAndroid Build Coastguard Worker	   { test prog != "$linkmode" && test lib != "$linkmode"; }; then
8159*6236dae4SAndroid Build Coastguard Worker	  test -n "$dlopen" && func_append dlfiles " $dlopen"
8160*6236dae4SAndroid Build Coastguard Worker	  test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen"
8161*6236dae4SAndroid Build Coastguard Worker	fi
8162*6236dae4SAndroid Build Coastguard Worker
8163*6236dae4SAndroid Build Coastguard Worker	if test conv = "$pass"; then
8164*6236dae4SAndroid Build Coastguard Worker	  # Only check for convenience libraries
8165*6236dae4SAndroid Build Coastguard Worker	  deplibs="$lib $deplibs"
8166*6236dae4SAndroid Build Coastguard Worker	  if test -z "$libdir"; then
8167*6236dae4SAndroid Build Coastguard Worker	    if test -z "$old_library"; then
8168*6236dae4SAndroid Build Coastguard Worker	      func_fatal_error "cannot find name of link library for '$lib'"
8169*6236dae4SAndroid Build Coastguard Worker	    fi
8170*6236dae4SAndroid Build Coastguard Worker	    # It is a libtool convenience library, so add in its objects.
8171*6236dae4SAndroid Build Coastguard Worker	    func_append convenience " $ladir/$objdir/$old_library"
8172*6236dae4SAndroid Build Coastguard Worker	    func_append old_convenience " $ladir/$objdir/$old_library"
8173*6236dae4SAndroid Build Coastguard Worker	    tmp_libs=
8174*6236dae4SAndroid Build Coastguard Worker	    for deplib in $dependency_libs; do
8175*6236dae4SAndroid Build Coastguard Worker	      deplibs="$deplib $deplibs"
8176*6236dae4SAndroid Build Coastguard Worker	      if $opt_preserve_dup_deps; then
8177*6236dae4SAndroid Build Coastguard Worker		case "$tmp_libs " in
8178*6236dae4SAndroid Build Coastguard Worker		*" $deplib "*) func_append specialdeplibs " $deplib" ;;
8179*6236dae4SAndroid Build Coastguard Worker		esac
8180*6236dae4SAndroid Build Coastguard Worker	      fi
8181*6236dae4SAndroid Build Coastguard Worker	      func_append tmp_libs " $deplib"
8182*6236dae4SAndroid Build Coastguard Worker	    done
8183*6236dae4SAndroid Build Coastguard Worker	  elif test prog != "$linkmode" && test lib != "$linkmode"; then
8184*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "'$lib' is not a convenience library"
8185*6236dae4SAndroid Build Coastguard Worker	  fi
8186*6236dae4SAndroid Build Coastguard Worker	  continue
8187*6236dae4SAndroid Build Coastguard Worker	fi # $pass = conv
8188*6236dae4SAndroid Build Coastguard Worker
8189*6236dae4SAndroid Build Coastguard Worker
8190*6236dae4SAndroid Build Coastguard Worker	# Get the name of the library we link against.
8191*6236dae4SAndroid Build Coastguard Worker	linklib=
8192*6236dae4SAndroid Build Coastguard Worker	if test -n "$old_library" &&
8193*6236dae4SAndroid Build Coastguard Worker	   { test yes = "$prefer_static_libs" ||
8194*6236dae4SAndroid Build Coastguard Worker	     test built,no = "$prefer_static_libs,$installed"; }; then
8195*6236dae4SAndroid Build Coastguard Worker	  linklib=$old_library
8196*6236dae4SAndroid Build Coastguard Worker	else
8197*6236dae4SAndroid Build Coastguard Worker	  for l in $old_library $library_names; do
8198*6236dae4SAndroid Build Coastguard Worker	    linklib=$l
8199*6236dae4SAndroid Build Coastguard Worker	  done
8200*6236dae4SAndroid Build Coastguard Worker	fi
8201*6236dae4SAndroid Build Coastguard Worker	if test -z "$linklib"; then
8202*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "cannot find name of link library for '$lib'"
8203*6236dae4SAndroid Build Coastguard Worker	fi
8204*6236dae4SAndroid Build Coastguard Worker
8205*6236dae4SAndroid Build Coastguard Worker	# This library was specified with -dlopen.
8206*6236dae4SAndroid Build Coastguard Worker	if test dlopen = "$pass"; then
8207*6236dae4SAndroid Build Coastguard Worker	  test -z "$libdir" \
8208*6236dae4SAndroid Build Coastguard Worker	    && func_fatal_error "cannot -dlopen a convenience library: '$lib'"
8209*6236dae4SAndroid Build Coastguard Worker	  if test -z "$dlname" ||
8210*6236dae4SAndroid Build Coastguard Worker	     test yes != "$dlopen_support" ||
8211*6236dae4SAndroid Build Coastguard Worker	     test no = "$build_libtool_libs"
8212*6236dae4SAndroid Build Coastguard Worker	  then
8213*6236dae4SAndroid Build Coastguard Worker	    # If there is no dlname, no dlopen support or we're linking
8214*6236dae4SAndroid Build Coastguard Worker	    # statically, we need to preload.  We also need to preload any
8215*6236dae4SAndroid Build Coastguard Worker	    # dependent libraries so libltdl's deplib preloader doesn't
8216*6236dae4SAndroid Build Coastguard Worker	    # bomb out in the load deplibs phase.
8217*6236dae4SAndroid Build Coastguard Worker	    func_append dlprefiles " $lib $dependency_libs"
8218*6236dae4SAndroid Build Coastguard Worker	  else
8219*6236dae4SAndroid Build Coastguard Worker	    func_append newdlfiles " $lib"
8220*6236dae4SAndroid Build Coastguard Worker	  fi
8221*6236dae4SAndroid Build Coastguard Worker	  continue
8222*6236dae4SAndroid Build Coastguard Worker	fi # $pass = dlopen
8223*6236dae4SAndroid Build Coastguard Worker
8224*6236dae4SAndroid Build Coastguard Worker	# We need an absolute path.
8225*6236dae4SAndroid Build Coastguard Worker	case $ladir in
8226*6236dae4SAndroid Build Coastguard Worker	[\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;;
8227*6236dae4SAndroid Build Coastguard Worker	*)
8228*6236dae4SAndroid Build Coastguard Worker	  abs_ladir=`cd "$ladir" && pwd`
8229*6236dae4SAndroid Build Coastguard Worker	  if test -z "$abs_ladir"; then
8230*6236dae4SAndroid Build Coastguard Worker	    func_warning "cannot determine absolute directory name of '$ladir'"
8231*6236dae4SAndroid Build Coastguard Worker	    func_warning "passing it literally to the linker, although it might fail"
8232*6236dae4SAndroid Build Coastguard Worker	    abs_ladir=$ladir
8233*6236dae4SAndroid Build Coastguard Worker	  fi
8234*6236dae4SAndroid Build Coastguard Worker	  ;;
8235*6236dae4SAndroid Build Coastguard Worker	esac
8236*6236dae4SAndroid Build Coastguard Worker	func_basename "$lib"
8237*6236dae4SAndroid Build Coastguard Worker	laname=$func_basename_result
8238*6236dae4SAndroid Build Coastguard Worker
8239*6236dae4SAndroid Build Coastguard Worker	# Find the relevant object directory and library name.
8240*6236dae4SAndroid Build Coastguard Worker	if test yes = "$installed"; then
8241*6236dae4SAndroid Build Coastguard Worker	  if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
8242*6236dae4SAndroid Build Coastguard Worker	    func_warning "library '$lib' was moved."
8243*6236dae4SAndroid Build Coastguard Worker	    dir=$ladir
8244*6236dae4SAndroid Build Coastguard Worker	    absdir=$abs_ladir
8245*6236dae4SAndroid Build Coastguard Worker	    libdir=$abs_ladir
8246*6236dae4SAndroid Build Coastguard Worker	  else
8247*6236dae4SAndroid Build Coastguard Worker	    dir=$lt_sysroot$libdir
8248*6236dae4SAndroid Build Coastguard Worker	    absdir=$lt_sysroot$libdir
8249*6236dae4SAndroid Build Coastguard Worker	  fi
8250*6236dae4SAndroid Build Coastguard Worker	  test yes = "$hardcode_automatic" && avoidtemprpath=yes
8251*6236dae4SAndroid Build Coastguard Worker	else
8252*6236dae4SAndroid Build Coastguard Worker	  if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then
8253*6236dae4SAndroid Build Coastguard Worker	    dir=$ladir
8254*6236dae4SAndroid Build Coastguard Worker	    absdir=$abs_ladir
8255*6236dae4SAndroid Build Coastguard Worker	    # Remove this search path later
8256*6236dae4SAndroid Build Coastguard Worker	    func_append notinst_path " $abs_ladir"
8257*6236dae4SAndroid Build Coastguard Worker	  else
8258*6236dae4SAndroid Build Coastguard Worker	    dir=$ladir/$objdir
8259*6236dae4SAndroid Build Coastguard Worker	    absdir=$abs_ladir/$objdir
8260*6236dae4SAndroid Build Coastguard Worker	    # Remove this search path later
8261*6236dae4SAndroid Build Coastguard Worker	    func_append notinst_path " $abs_ladir"
8262*6236dae4SAndroid Build Coastguard Worker	  fi
8263*6236dae4SAndroid Build Coastguard Worker	fi # $installed = yes
8264*6236dae4SAndroid Build Coastguard Worker	func_stripname 'lib' '.la' "$laname"
8265*6236dae4SAndroid Build Coastguard Worker	name=$func_stripname_result
8266*6236dae4SAndroid Build Coastguard Worker
8267*6236dae4SAndroid Build Coastguard Worker	# This library was specified with -dlpreopen.
8268*6236dae4SAndroid Build Coastguard Worker	if test dlpreopen = "$pass"; then
8269*6236dae4SAndroid Build Coastguard Worker	  if test -z "$libdir" && test prog = "$linkmode"; then
8270*6236dae4SAndroid Build Coastguard Worker	    func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'"
8271*6236dae4SAndroid Build Coastguard Worker	  fi
8272*6236dae4SAndroid Build Coastguard Worker	  case $host in
8273*6236dae4SAndroid Build Coastguard Worker	    # special handling for platforms with PE-DLLs.
8274*6236dae4SAndroid Build Coastguard Worker	    *cygwin* | *mingw* | *cegcc* )
8275*6236dae4SAndroid Build Coastguard Worker	      # Linker will automatically link against shared library if both
8276*6236dae4SAndroid Build Coastguard Worker	      # static and shared are present.  Therefore, ensure we extract
8277*6236dae4SAndroid Build Coastguard Worker	      # symbols from the import library if a shared library is present
8278*6236dae4SAndroid Build Coastguard Worker	      # (otherwise, the dlopen module name will be incorrect).  We do
8279*6236dae4SAndroid Build Coastguard Worker	      # this by putting the import library name into $newdlprefiles.
8280*6236dae4SAndroid Build Coastguard Worker	      # We recover the dlopen module name by 'saving' the la file
8281*6236dae4SAndroid Build Coastguard Worker	      # name in a special purpose variable, and (later) extracting the
8282*6236dae4SAndroid Build Coastguard Worker	      # dlname from the la file.
8283*6236dae4SAndroid Build Coastguard Worker	      if test -n "$dlname"; then
8284*6236dae4SAndroid Build Coastguard Worker	        func_tr_sh "$dir/$linklib"
8285*6236dae4SAndroid Build Coastguard Worker	        eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname"
8286*6236dae4SAndroid Build Coastguard Worker	        func_append newdlprefiles " $dir/$linklib"
8287*6236dae4SAndroid Build Coastguard Worker	      else
8288*6236dae4SAndroid Build Coastguard Worker	        func_append newdlprefiles " $dir/$old_library"
8289*6236dae4SAndroid Build Coastguard Worker	        # Keep a list of preopened convenience libraries to check
8290*6236dae4SAndroid Build Coastguard Worker	        # that they are being used correctly in the link pass.
8291*6236dae4SAndroid Build Coastguard Worker	        test -z "$libdir" && \
8292*6236dae4SAndroid Build Coastguard Worker	          func_append dlpreconveniencelibs " $dir/$old_library"
8293*6236dae4SAndroid Build Coastguard Worker	      fi
8294*6236dae4SAndroid Build Coastguard Worker	    ;;
8295*6236dae4SAndroid Build Coastguard Worker	    * )
8296*6236dae4SAndroid Build Coastguard Worker	      # Prefer using a static library (so that no silly _DYNAMIC symbols
8297*6236dae4SAndroid Build Coastguard Worker	      # are required to link).
8298*6236dae4SAndroid Build Coastguard Worker	      if test -n "$old_library"; then
8299*6236dae4SAndroid Build Coastguard Worker	        func_append newdlprefiles " $dir/$old_library"
8300*6236dae4SAndroid Build Coastguard Worker	        # Keep a list of preopened convenience libraries to check
8301*6236dae4SAndroid Build Coastguard Worker	        # that they are being used correctly in the link pass.
8302*6236dae4SAndroid Build Coastguard Worker	        test -z "$libdir" && \
8303*6236dae4SAndroid Build Coastguard Worker	          func_append dlpreconveniencelibs " $dir/$old_library"
8304*6236dae4SAndroid Build Coastguard Worker	      # Otherwise, use the dlname, so that lt_dlopen finds it.
8305*6236dae4SAndroid Build Coastguard Worker	      elif test -n "$dlname"; then
8306*6236dae4SAndroid Build Coastguard Worker	        func_append newdlprefiles " $dir/$dlname"
8307*6236dae4SAndroid Build Coastguard Worker	      else
8308*6236dae4SAndroid Build Coastguard Worker	        func_append newdlprefiles " $dir/$linklib"
8309*6236dae4SAndroid Build Coastguard Worker	      fi
8310*6236dae4SAndroid Build Coastguard Worker	    ;;
8311*6236dae4SAndroid Build Coastguard Worker	  esac
8312*6236dae4SAndroid Build Coastguard Worker	fi # $pass = dlpreopen
8313*6236dae4SAndroid Build Coastguard Worker
8314*6236dae4SAndroid Build Coastguard Worker	if test -z "$libdir"; then
8315*6236dae4SAndroid Build Coastguard Worker	  # Link the convenience library
8316*6236dae4SAndroid Build Coastguard Worker	  if test lib = "$linkmode"; then
8317*6236dae4SAndroid Build Coastguard Worker	    deplibs="$dir/$old_library $deplibs"
8318*6236dae4SAndroid Build Coastguard Worker	  elif test prog,link = "$linkmode,$pass"; then
8319*6236dae4SAndroid Build Coastguard Worker	    compile_deplibs="$dir/$old_library $compile_deplibs"
8320*6236dae4SAndroid Build Coastguard Worker	    finalize_deplibs="$dir/$old_library $finalize_deplibs"
8321*6236dae4SAndroid Build Coastguard Worker	  else
8322*6236dae4SAndroid Build Coastguard Worker	    deplibs="$lib $deplibs" # used for prog,scan pass
8323*6236dae4SAndroid Build Coastguard Worker	  fi
8324*6236dae4SAndroid Build Coastguard Worker	  continue
8325*6236dae4SAndroid Build Coastguard Worker	fi
8326*6236dae4SAndroid Build Coastguard Worker
8327*6236dae4SAndroid Build Coastguard Worker
8328*6236dae4SAndroid Build Coastguard Worker	if test prog = "$linkmode" && test link != "$pass"; then
8329*6236dae4SAndroid Build Coastguard Worker	  func_append newlib_search_path " $ladir"
8330*6236dae4SAndroid Build Coastguard Worker	  deplibs="$lib $deplibs"
8331*6236dae4SAndroid Build Coastguard Worker
8332*6236dae4SAndroid Build Coastguard Worker	  linkalldeplibs=false
8333*6236dae4SAndroid Build Coastguard Worker	  if test no != "$link_all_deplibs" || test -z "$library_names" ||
8334*6236dae4SAndroid Build Coastguard Worker	     test no = "$build_libtool_libs"; then
8335*6236dae4SAndroid Build Coastguard Worker	    linkalldeplibs=:
8336*6236dae4SAndroid Build Coastguard Worker	  fi
8337*6236dae4SAndroid Build Coastguard Worker
8338*6236dae4SAndroid Build Coastguard Worker	  tmp_libs=
8339*6236dae4SAndroid Build Coastguard Worker	  for deplib in $dependency_libs; do
8340*6236dae4SAndroid Build Coastguard Worker	    case $deplib in
8341*6236dae4SAndroid Build Coastguard Worker	    -L*) func_stripname '-L' '' "$deplib"
8342*6236dae4SAndroid Build Coastguard Worker	         func_resolve_sysroot "$func_stripname_result"
8343*6236dae4SAndroid Build Coastguard Worker	         func_append newlib_search_path " $func_resolve_sysroot_result"
8344*6236dae4SAndroid Build Coastguard Worker		 ;;
8345*6236dae4SAndroid Build Coastguard Worker	    esac
8346*6236dae4SAndroid Build Coastguard Worker	    # Need to link against all dependency_libs?
8347*6236dae4SAndroid Build Coastguard Worker	    if $linkalldeplibs; then
8348*6236dae4SAndroid Build Coastguard Worker	      deplibs="$deplib $deplibs"
8349*6236dae4SAndroid Build Coastguard Worker	    else
8350*6236dae4SAndroid Build Coastguard Worker	      # Need to hardcode shared library paths
8351*6236dae4SAndroid Build Coastguard Worker	      # or/and link against static libraries
8352*6236dae4SAndroid Build Coastguard Worker	      newdependency_libs="$deplib $newdependency_libs"
8353*6236dae4SAndroid Build Coastguard Worker	    fi
8354*6236dae4SAndroid Build Coastguard Worker	    if $opt_preserve_dup_deps; then
8355*6236dae4SAndroid Build Coastguard Worker	      case "$tmp_libs " in
8356*6236dae4SAndroid Build Coastguard Worker	      *" $deplib "*) func_append specialdeplibs " $deplib" ;;
8357*6236dae4SAndroid Build Coastguard Worker	      esac
8358*6236dae4SAndroid Build Coastguard Worker	    fi
8359*6236dae4SAndroid Build Coastguard Worker	    func_append tmp_libs " $deplib"
8360*6236dae4SAndroid Build Coastguard Worker	  done # for deplib
8361*6236dae4SAndroid Build Coastguard Worker	  continue
8362*6236dae4SAndroid Build Coastguard Worker	fi # $linkmode = prog...
8363*6236dae4SAndroid Build Coastguard Worker
8364*6236dae4SAndroid Build Coastguard Worker	if test prog,link = "$linkmode,$pass"; then
8365*6236dae4SAndroid Build Coastguard Worker	  if test -n "$library_names" &&
8366*6236dae4SAndroid Build Coastguard Worker	     { { test no = "$prefer_static_libs" ||
8367*6236dae4SAndroid Build Coastguard Worker	         test built,yes = "$prefer_static_libs,$installed"; } ||
8368*6236dae4SAndroid Build Coastguard Worker	       test -z "$old_library"; }; then
8369*6236dae4SAndroid Build Coastguard Worker	    # We need to hardcode the library path
8370*6236dae4SAndroid Build Coastguard Worker	    if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then
8371*6236dae4SAndroid Build Coastguard Worker	      # Make sure the rpath contains only unique directories.
8372*6236dae4SAndroid Build Coastguard Worker	      case $temp_rpath: in
8373*6236dae4SAndroid Build Coastguard Worker	      *"$absdir:"*) ;;
8374*6236dae4SAndroid Build Coastguard Worker	      *) func_append temp_rpath "$absdir:" ;;
8375*6236dae4SAndroid Build Coastguard Worker	      esac
8376*6236dae4SAndroid Build Coastguard Worker	    fi
8377*6236dae4SAndroid Build Coastguard Worker
8378*6236dae4SAndroid Build Coastguard Worker	    # Hardcode the library path.
8379*6236dae4SAndroid Build Coastguard Worker	    # Skip directories that are in the system default run-time
8380*6236dae4SAndroid Build Coastguard Worker	    # search path.
8381*6236dae4SAndroid Build Coastguard Worker	    case " $sys_lib_dlsearch_path " in
8382*6236dae4SAndroid Build Coastguard Worker	    *" $absdir "*) ;;
8383*6236dae4SAndroid Build Coastguard Worker	    *)
8384*6236dae4SAndroid Build Coastguard Worker	      case "$compile_rpath " in
8385*6236dae4SAndroid Build Coastguard Worker	      *" $absdir "*) ;;
8386*6236dae4SAndroid Build Coastguard Worker	      *) func_append compile_rpath " $absdir" ;;
8387*6236dae4SAndroid Build Coastguard Worker	      esac
8388*6236dae4SAndroid Build Coastguard Worker	      ;;
8389*6236dae4SAndroid Build Coastguard Worker	    esac
8390*6236dae4SAndroid Build Coastguard Worker	    case " $sys_lib_dlsearch_path " in
8391*6236dae4SAndroid Build Coastguard Worker	    *" $libdir "*) ;;
8392*6236dae4SAndroid Build Coastguard Worker	    *)
8393*6236dae4SAndroid Build Coastguard Worker	      case "$finalize_rpath " in
8394*6236dae4SAndroid Build Coastguard Worker	      *" $libdir "*) ;;
8395*6236dae4SAndroid Build Coastguard Worker	      *) func_append finalize_rpath " $libdir" ;;
8396*6236dae4SAndroid Build Coastguard Worker	      esac
8397*6236dae4SAndroid Build Coastguard Worker	      ;;
8398*6236dae4SAndroid Build Coastguard Worker	    esac
8399*6236dae4SAndroid Build Coastguard Worker	  fi # $linkmode,$pass = prog,link...
8400*6236dae4SAndroid Build Coastguard Worker
8401*6236dae4SAndroid Build Coastguard Worker	  if $alldeplibs &&
8402*6236dae4SAndroid Build Coastguard Worker	     { test pass_all = "$deplibs_check_method" ||
8403*6236dae4SAndroid Build Coastguard Worker	       { test yes = "$build_libtool_libs" &&
8404*6236dae4SAndroid Build Coastguard Worker		 test -n "$library_names"; }; }; then
8405*6236dae4SAndroid Build Coastguard Worker	    # We only need to search for static libraries
8406*6236dae4SAndroid Build Coastguard Worker	    continue
8407*6236dae4SAndroid Build Coastguard Worker	  fi
8408*6236dae4SAndroid Build Coastguard Worker	fi
8409*6236dae4SAndroid Build Coastguard Worker
8410*6236dae4SAndroid Build Coastguard Worker	link_static=no # Whether the deplib will be linked statically
8411*6236dae4SAndroid Build Coastguard Worker	use_static_libs=$prefer_static_libs
8412*6236dae4SAndroid Build Coastguard Worker	if test built = "$use_static_libs" && test yes = "$installed"; then
8413*6236dae4SAndroid Build Coastguard Worker	  use_static_libs=no
8414*6236dae4SAndroid Build Coastguard Worker	fi
8415*6236dae4SAndroid Build Coastguard Worker	if test -n "$library_names" &&
8416*6236dae4SAndroid Build Coastguard Worker	   { test no = "$use_static_libs" || test -z "$old_library"; }; then
8417*6236dae4SAndroid Build Coastguard Worker	  case $host in
8418*6236dae4SAndroid Build Coastguard Worker	  *cygwin* | *mingw* | *cegcc* | *os2*)
8419*6236dae4SAndroid Build Coastguard Worker	      # No point in relinking DLLs because paths are not encoded
8420*6236dae4SAndroid Build Coastguard Worker	      func_append notinst_deplibs " $lib"
8421*6236dae4SAndroid Build Coastguard Worker	      need_relink=no
8422*6236dae4SAndroid Build Coastguard Worker	    ;;
8423*6236dae4SAndroid Build Coastguard Worker	  *)
8424*6236dae4SAndroid Build Coastguard Worker	    if test no = "$installed"; then
8425*6236dae4SAndroid Build Coastguard Worker	      func_append notinst_deplibs " $lib"
8426*6236dae4SAndroid Build Coastguard Worker	      need_relink=yes
8427*6236dae4SAndroid Build Coastguard Worker	    fi
8428*6236dae4SAndroid Build Coastguard Worker	    ;;
8429*6236dae4SAndroid Build Coastguard Worker	  esac
8430*6236dae4SAndroid Build Coastguard Worker	  # This is a shared library
8431*6236dae4SAndroid Build Coastguard Worker
8432*6236dae4SAndroid Build Coastguard Worker	  # Warn about portability, can't link against -module's on some
8433*6236dae4SAndroid Build Coastguard Worker	  # systems (darwin).  Don't bleat about dlopened modules though!
8434*6236dae4SAndroid Build Coastguard Worker	  dlopenmodule=
8435*6236dae4SAndroid Build Coastguard Worker	  for dlpremoduletest in $dlprefiles; do
8436*6236dae4SAndroid Build Coastguard Worker	    if test "X$dlpremoduletest" = "X$lib"; then
8437*6236dae4SAndroid Build Coastguard Worker	      dlopenmodule=$dlpremoduletest
8438*6236dae4SAndroid Build Coastguard Worker	      break
8439*6236dae4SAndroid Build Coastguard Worker	    fi
8440*6236dae4SAndroid Build Coastguard Worker	  done
8441*6236dae4SAndroid Build Coastguard Worker	  if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then
8442*6236dae4SAndroid Build Coastguard Worker	    echo
8443*6236dae4SAndroid Build Coastguard Worker	    if test prog = "$linkmode"; then
8444*6236dae4SAndroid Build Coastguard Worker	      $ECHO "*** Warning: Linking the executable $output against the loadable module"
8445*6236dae4SAndroid Build Coastguard Worker	    else
8446*6236dae4SAndroid Build Coastguard Worker	      $ECHO "*** Warning: Linking the shared library $output against the loadable module"
8447*6236dae4SAndroid Build Coastguard Worker	    fi
8448*6236dae4SAndroid Build Coastguard Worker	    $ECHO "*** $linklib is not portable!"
8449*6236dae4SAndroid Build Coastguard Worker	  fi
8450*6236dae4SAndroid Build Coastguard Worker	  if test lib = "$linkmode" &&
8451*6236dae4SAndroid Build Coastguard Worker	     test yes = "$hardcode_into_libs"; then
8452*6236dae4SAndroid Build Coastguard Worker	    # Hardcode the library path.
8453*6236dae4SAndroid Build Coastguard Worker	    # Skip directories that are in the system default run-time
8454*6236dae4SAndroid Build Coastguard Worker	    # search path.
8455*6236dae4SAndroid Build Coastguard Worker	    case " $sys_lib_dlsearch_path " in
8456*6236dae4SAndroid Build Coastguard Worker	    *" $absdir "*) ;;
8457*6236dae4SAndroid Build Coastguard Worker	    *)
8458*6236dae4SAndroid Build Coastguard Worker	      case "$compile_rpath " in
8459*6236dae4SAndroid Build Coastguard Worker	      *" $absdir "*) ;;
8460*6236dae4SAndroid Build Coastguard Worker	      *) func_append compile_rpath " $absdir" ;;
8461*6236dae4SAndroid Build Coastguard Worker	      esac
8462*6236dae4SAndroid Build Coastguard Worker	      ;;
8463*6236dae4SAndroid Build Coastguard Worker	    esac
8464*6236dae4SAndroid Build Coastguard Worker	    case " $sys_lib_dlsearch_path " in
8465*6236dae4SAndroid Build Coastguard Worker	    *" $libdir "*) ;;
8466*6236dae4SAndroid Build Coastguard Worker	    *)
8467*6236dae4SAndroid Build Coastguard Worker	      case "$finalize_rpath " in
8468*6236dae4SAndroid Build Coastguard Worker	      *" $libdir "*) ;;
8469*6236dae4SAndroid Build Coastguard Worker	      *) func_append finalize_rpath " $libdir" ;;
8470*6236dae4SAndroid Build Coastguard Worker	      esac
8471*6236dae4SAndroid Build Coastguard Worker	      ;;
8472*6236dae4SAndroid Build Coastguard Worker	    esac
8473*6236dae4SAndroid Build Coastguard Worker	  fi
8474*6236dae4SAndroid Build Coastguard Worker
8475*6236dae4SAndroid Build Coastguard Worker	  if test -n "$old_archive_from_expsyms_cmds"; then
8476*6236dae4SAndroid Build Coastguard Worker	    # figure out the soname
8477*6236dae4SAndroid Build Coastguard Worker	    set dummy $library_names
8478*6236dae4SAndroid Build Coastguard Worker	    shift
8479*6236dae4SAndroid Build Coastguard Worker	    realname=$1
8480*6236dae4SAndroid Build Coastguard Worker	    shift
8481*6236dae4SAndroid Build Coastguard Worker	    libname=`eval "\\$ECHO \"$libname_spec\""`
8482*6236dae4SAndroid Build Coastguard Worker	    # use dlname if we got it. it's perfectly good, no?
8483*6236dae4SAndroid Build Coastguard Worker	    if test -n "$dlname"; then
8484*6236dae4SAndroid Build Coastguard Worker	      soname=$dlname
8485*6236dae4SAndroid Build Coastguard Worker	    elif test -n "$soname_spec"; then
8486*6236dae4SAndroid Build Coastguard Worker	      # bleh windows
8487*6236dae4SAndroid Build Coastguard Worker	      case $host in
8488*6236dae4SAndroid Build Coastguard Worker	      *cygwin* | mingw* | *cegcc* | *os2*)
8489*6236dae4SAndroid Build Coastguard Worker	        func_arith $current - $age
8490*6236dae4SAndroid Build Coastguard Worker		major=$func_arith_result
8491*6236dae4SAndroid Build Coastguard Worker		versuffix=-$major
8492*6236dae4SAndroid Build Coastguard Worker		;;
8493*6236dae4SAndroid Build Coastguard Worker	      esac
8494*6236dae4SAndroid Build Coastguard Worker	      eval soname=\"$soname_spec\"
8495*6236dae4SAndroid Build Coastguard Worker	    else
8496*6236dae4SAndroid Build Coastguard Worker	      soname=$realname
8497*6236dae4SAndroid Build Coastguard Worker	    fi
8498*6236dae4SAndroid Build Coastguard Worker
8499*6236dae4SAndroid Build Coastguard Worker	    # Make a new name for the extract_expsyms_cmds to use
8500*6236dae4SAndroid Build Coastguard Worker	    soroot=$soname
8501*6236dae4SAndroid Build Coastguard Worker	    func_basename "$soroot"
8502*6236dae4SAndroid Build Coastguard Worker	    soname=$func_basename_result
8503*6236dae4SAndroid Build Coastguard Worker	    func_stripname 'lib' '.dll' "$soname"
8504*6236dae4SAndroid Build Coastguard Worker	    newlib=libimp-$func_stripname_result.a
8505*6236dae4SAndroid Build Coastguard Worker
8506*6236dae4SAndroid Build Coastguard Worker	    # If the library has no export list, then create one now
8507*6236dae4SAndroid Build Coastguard Worker	    if test -f "$output_objdir/$soname-def"; then :
8508*6236dae4SAndroid Build Coastguard Worker	    else
8509*6236dae4SAndroid Build Coastguard Worker	      func_verbose "extracting exported symbol list from '$soname'"
8510*6236dae4SAndroid Build Coastguard Worker	      func_execute_cmds "$extract_expsyms_cmds" 'exit $?'
8511*6236dae4SAndroid Build Coastguard Worker	    fi
8512*6236dae4SAndroid Build Coastguard Worker
8513*6236dae4SAndroid Build Coastguard Worker	    # Create $newlib
8514*6236dae4SAndroid Build Coastguard Worker	    if test -f "$output_objdir/$newlib"; then :; else
8515*6236dae4SAndroid Build Coastguard Worker	      func_verbose "generating import library for '$soname'"
8516*6236dae4SAndroid Build Coastguard Worker	      func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?'
8517*6236dae4SAndroid Build Coastguard Worker	    fi
8518*6236dae4SAndroid Build Coastguard Worker	    # make sure the library variables are pointing to the new library
8519*6236dae4SAndroid Build Coastguard Worker	    dir=$output_objdir
8520*6236dae4SAndroid Build Coastguard Worker	    linklib=$newlib
8521*6236dae4SAndroid Build Coastguard Worker	  fi # test -n "$old_archive_from_expsyms_cmds"
8522*6236dae4SAndroid Build Coastguard Worker
8523*6236dae4SAndroid Build Coastguard Worker	  if test prog = "$linkmode" || test relink != "$opt_mode"; then
8524*6236dae4SAndroid Build Coastguard Worker	    add_shlibpath=
8525*6236dae4SAndroid Build Coastguard Worker	    add_dir=
8526*6236dae4SAndroid Build Coastguard Worker	    add=
8527*6236dae4SAndroid Build Coastguard Worker	    lib_linked=yes
8528*6236dae4SAndroid Build Coastguard Worker	    case $hardcode_action in
8529*6236dae4SAndroid Build Coastguard Worker	    immediate | unsupported)
8530*6236dae4SAndroid Build Coastguard Worker	      if test no = "$hardcode_direct"; then
8531*6236dae4SAndroid Build Coastguard Worker		add=$dir/$linklib
8532*6236dae4SAndroid Build Coastguard Worker		case $host in
8533*6236dae4SAndroid Build Coastguard Worker		  *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;;
8534*6236dae4SAndroid Build Coastguard Worker		  *-*-sysv4*uw2*) add_dir=-L$dir ;;
8535*6236dae4SAndroid Build Coastguard Worker		  *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \
8536*6236dae4SAndroid Build Coastguard Worker		    *-*-unixware7*) add_dir=-L$dir ;;
8537*6236dae4SAndroid Build Coastguard Worker		  *-*-darwin* )
8538*6236dae4SAndroid Build Coastguard Worker		    # if the lib is a (non-dlopened) module then we cannot
8539*6236dae4SAndroid Build Coastguard Worker		    # link against it, someone is ignoring the earlier warnings
8540*6236dae4SAndroid Build Coastguard Worker		    if /usr/bin/file -L $add 2> /dev/null |
8541*6236dae4SAndroid Build Coastguard Worker			 $GREP ": [^:]* bundle" >/dev/null; then
8542*6236dae4SAndroid Build Coastguard Worker		      if test "X$dlopenmodule" != "X$lib"; then
8543*6236dae4SAndroid Build Coastguard Worker			$ECHO "*** Warning: lib $linklib is a module, not a shared library"
8544*6236dae4SAndroid Build Coastguard Worker			if test -z "$old_library"; then
8545*6236dae4SAndroid Build Coastguard Worker			  echo
8546*6236dae4SAndroid Build Coastguard Worker			  echo "*** And there doesn't seem to be a static archive available"
8547*6236dae4SAndroid Build Coastguard Worker			  echo "*** The link will probably fail, sorry"
8548*6236dae4SAndroid Build Coastguard Worker			else
8549*6236dae4SAndroid Build Coastguard Worker			  add=$dir/$old_library
8550*6236dae4SAndroid Build Coastguard Worker			fi
8551*6236dae4SAndroid Build Coastguard Worker		      elif test -n "$old_library"; then
8552*6236dae4SAndroid Build Coastguard Worker			add=$dir/$old_library
8553*6236dae4SAndroid Build Coastguard Worker		      fi
8554*6236dae4SAndroid Build Coastguard Worker		    fi
8555*6236dae4SAndroid Build Coastguard Worker		esac
8556*6236dae4SAndroid Build Coastguard Worker	      elif test no = "$hardcode_minus_L"; then
8557*6236dae4SAndroid Build Coastguard Worker		case $host in
8558*6236dae4SAndroid Build Coastguard Worker		*-*-sunos*) add_shlibpath=$dir ;;
8559*6236dae4SAndroid Build Coastguard Worker		esac
8560*6236dae4SAndroid Build Coastguard Worker		add_dir=-L$dir
8561*6236dae4SAndroid Build Coastguard Worker		add=-l$name
8562*6236dae4SAndroid Build Coastguard Worker	      elif test no = "$hardcode_shlibpath_var"; then
8563*6236dae4SAndroid Build Coastguard Worker		add_shlibpath=$dir
8564*6236dae4SAndroid Build Coastguard Worker		add=-l$name
8565*6236dae4SAndroid Build Coastguard Worker	      else
8566*6236dae4SAndroid Build Coastguard Worker		lib_linked=no
8567*6236dae4SAndroid Build Coastguard Worker	      fi
8568*6236dae4SAndroid Build Coastguard Worker	      ;;
8569*6236dae4SAndroid Build Coastguard Worker	    relink)
8570*6236dae4SAndroid Build Coastguard Worker	      if test yes = "$hardcode_direct" &&
8571*6236dae4SAndroid Build Coastguard Worker	         test no = "$hardcode_direct_absolute"; then
8572*6236dae4SAndroid Build Coastguard Worker		add=$dir/$linklib
8573*6236dae4SAndroid Build Coastguard Worker	      elif test yes = "$hardcode_minus_L"; then
8574*6236dae4SAndroid Build Coastguard Worker		add_dir=-L$absdir
8575*6236dae4SAndroid Build Coastguard Worker		# Try looking first in the location we're being installed to.
8576*6236dae4SAndroid Build Coastguard Worker		if test -n "$inst_prefix_dir"; then
8577*6236dae4SAndroid Build Coastguard Worker		  case $libdir in
8578*6236dae4SAndroid Build Coastguard Worker		    [\\/]*)
8579*6236dae4SAndroid Build Coastguard Worker		      func_append add_dir " -L$inst_prefix_dir$libdir"
8580*6236dae4SAndroid Build Coastguard Worker		      ;;
8581*6236dae4SAndroid Build Coastguard Worker		  esac
8582*6236dae4SAndroid Build Coastguard Worker		fi
8583*6236dae4SAndroid Build Coastguard Worker		add=-l$name
8584*6236dae4SAndroid Build Coastguard Worker	      elif test yes = "$hardcode_shlibpath_var"; then
8585*6236dae4SAndroid Build Coastguard Worker		add_shlibpath=$dir
8586*6236dae4SAndroid Build Coastguard Worker		add=-l$name
8587*6236dae4SAndroid Build Coastguard Worker	      else
8588*6236dae4SAndroid Build Coastguard Worker		lib_linked=no
8589*6236dae4SAndroid Build Coastguard Worker	      fi
8590*6236dae4SAndroid Build Coastguard Worker	      ;;
8591*6236dae4SAndroid Build Coastguard Worker	    *) lib_linked=no ;;
8592*6236dae4SAndroid Build Coastguard Worker	    esac
8593*6236dae4SAndroid Build Coastguard Worker
8594*6236dae4SAndroid Build Coastguard Worker	    if test yes != "$lib_linked"; then
8595*6236dae4SAndroid Build Coastguard Worker	      func_fatal_configuration "unsupported hardcode properties"
8596*6236dae4SAndroid Build Coastguard Worker	    fi
8597*6236dae4SAndroid Build Coastguard Worker
8598*6236dae4SAndroid Build Coastguard Worker	    if test -n "$add_shlibpath"; then
8599*6236dae4SAndroid Build Coastguard Worker	      case :$compile_shlibpath: in
8600*6236dae4SAndroid Build Coastguard Worker	      *":$add_shlibpath:"*) ;;
8601*6236dae4SAndroid Build Coastguard Worker	      *) func_append compile_shlibpath "$add_shlibpath:" ;;
8602*6236dae4SAndroid Build Coastguard Worker	      esac
8603*6236dae4SAndroid Build Coastguard Worker	    fi
8604*6236dae4SAndroid Build Coastguard Worker	    if test prog = "$linkmode"; then
8605*6236dae4SAndroid Build Coastguard Worker	      test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs"
8606*6236dae4SAndroid Build Coastguard Worker	      test -n "$add" && compile_deplibs="$add $compile_deplibs"
8607*6236dae4SAndroid Build Coastguard Worker	    else
8608*6236dae4SAndroid Build Coastguard Worker	      test -n "$add_dir" && deplibs="$add_dir $deplibs"
8609*6236dae4SAndroid Build Coastguard Worker	      test -n "$add" && deplibs="$add $deplibs"
8610*6236dae4SAndroid Build Coastguard Worker	      if test yes != "$hardcode_direct" &&
8611*6236dae4SAndroid Build Coastguard Worker		 test yes != "$hardcode_minus_L" &&
8612*6236dae4SAndroid Build Coastguard Worker		 test yes = "$hardcode_shlibpath_var"; then
8613*6236dae4SAndroid Build Coastguard Worker		case :$finalize_shlibpath: in
8614*6236dae4SAndroid Build Coastguard Worker		*":$libdir:"*) ;;
8615*6236dae4SAndroid Build Coastguard Worker		*) func_append finalize_shlibpath "$libdir:" ;;
8616*6236dae4SAndroid Build Coastguard Worker		esac
8617*6236dae4SAndroid Build Coastguard Worker	      fi
8618*6236dae4SAndroid Build Coastguard Worker	    fi
8619*6236dae4SAndroid Build Coastguard Worker	  fi
8620*6236dae4SAndroid Build Coastguard Worker
8621*6236dae4SAndroid Build Coastguard Worker	  if test prog = "$linkmode" || test relink = "$opt_mode"; then
8622*6236dae4SAndroid Build Coastguard Worker	    add_shlibpath=
8623*6236dae4SAndroid Build Coastguard Worker	    add_dir=
8624*6236dae4SAndroid Build Coastguard Worker	    add=
8625*6236dae4SAndroid Build Coastguard Worker	    # Finalize command for both is simple: just hardcode it.
8626*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$hardcode_direct" &&
8627*6236dae4SAndroid Build Coastguard Worker	       test no = "$hardcode_direct_absolute"; then
8628*6236dae4SAndroid Build Coastguard Worker	      add=$libdir/$linklib
8629*6236dae4SAndroid Build Coastguard Worker	    elif test yes = "$hardcode_minus_L"; then
8630*6236dae4SAndroid Build Coastguard Worker	      add_dir=-L$libdir
8631*6236dae4SAndroid Build Coastguard Worker	      add=-l$name
8632*6236dae4SAndroid Build Coastguard Worker	    elif test yes = "$hardcode_shlibpath_var"; then
8633*6236dae4SAndroid Build Coastguard Worker	      case :$finalize_shlibpath: in
8634*6236dae4SAndroid Build Coastguard Worker	      *":$libdir:"*) ;;
8635*6236dae4SAndroid Build Coastguard Worker	      *) func_append finalize_shlibpath "$libdir:" ;;
8636*6236dae4SAndroid Build Coastguard Worker	      esac
8637*6236dae4SAndroid Build Coastguard Worker	      add=-l$name
8638*6236dae4SAndroid Build Coastguard Worker	    elif test yes = "$hardcode_automatic"; then
8639*6236dae4SAndroid Build Coastguard Worker	      if test -n "$inst_prefix_dir" &&
8640*6236dae4SAndroid Build Coastguard Worker		 test -f "$inst_prefix_dir$libdir/$linklib"; then
8641*6236dae4SAndroid Build Coastguard Worker		add=$inst_prefix_dir$libdir/$linklib
8642*6236dae4SAndroid Build Coastguard Worker	      else
8643*6236dae4SAndroid Build Coastguard Worker		add=$libdir/$linklib
8644*6236dae4SAndroid Build Coastguard Worker	      fi
8645*6236dae4SAndroid Build Coastguard Worker	    else
8646*6236dae4SAndroid Build Coastguard Worker	      # We cannot seem to hardcode it, guess we'll fake it.
8647*6236dae4SAndroid Build Coastguard Worker	      add_dir=-L$libdir
8648*6236dae4SAndroid Build Coastguard Worker	      # Try looking first in the location we're being installed to.
8649*6236dae4SAndroid Build Coastguard Worker	      if test -n "$inst_prefix_dir"; then
8650*6236dae4SAndroid Build Coastguard Worker		case $libdir in
8651*6236dae4SAndroid Build Coastguard Worker		  [\\/]*)
8652*6236dae4SAndroid Build Coastguard Worker		    func_append add_dir " -L$inst_prefix_dir$libdir"
8653*6236dae4SAndroid Build Coastguard Worker		    ;;
8654*6236dae4SAndroid Build Coastguard Worker		esac
8655*6236dae4SAndroid Build Coastguard Worker	      fi
8656*6236dae4SAndroid Build Coastguard Worker	      add=-l$name
8657*6236dae4SAndroid Build Coastguard Worker	    fi
8658*6236dae4SAndroid Build Coastguard Worker
8659*6236dae4SAndroid Build Coastguard Worker	    if test prog = "$linkmode"; then
8660*6236dae4SAndroid Build Coastguard Worker	      test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs"
8661*6236dae4SAndroid Build Coastguard Worker	      test -n "$add" && finalize_deplibs="$add $finalize_deplibs"
8662*6236dae4SAndroid Build Coastguard Worker	    else
8663*6236dae4SAndroid Build Coastguard Worker	      test -n "$add_dir" && deplibs="$add_dir $deplibs"
8664*6236dae4SAndroid Build Coastguard Worker	      test -n "$add" && deplibs="$add $deplibs"
8665*6236dae4SAndroid Build Coastguard Worker	    fi
8666*6236dae4SAndroid Build Coastguard Worker	  fi
8667*6236dae4SAndroid Build Coastguard Worker	elif test prog = "$linkmode"; then
8668*6236dae4SAndroid Build Coastguard Worker	  # Here we assume that one of hardcode_direct or hardcode_minus_L
8669*6236dae4SAndroid Build Coastguard Worker	  # is not unsupported.  This is valid on all known static and
8670*6236dae4SAndroid Build Coastguard Worker	  # shared platforms.
8671*6236dae4SAndroid Build Coastguard Worker	  if test unsupported != "$hardcode_direct"; then
8672*6236dae4SAndroid Build Coastguard Worker	    test -n "$old_library" && linklib=$old_library
8673*6236dae4SAndroid Build Coastguard Worker	    compile_deplibs="$dir/$linklib $compile_deplibs"
8674*6236dae4SAndroid Build Coastguard Worker	    finalize_deplibs="$dir/$linklib $finalize_deplibs"
8675*6236dae4SAndroid Build Coastguard Worker	  else
8676*6236dae4SAndroid Build Coastguard Worker	    compile_deplibs="-l$name -L$dir $compile_deplibs"
8677*6236dae4SAndroid Build Coastguard Worker	    finalize_deplibs="-l$name -L$dir $finalize_deplibs"
8678*6236dae4SAndroid Build Coastguard Worker	  fi
8679*6236dae4SAndroid Build Coastguard Worker	elif test yes = "$build_libtool_libs"; then
8680*6236dae4SAndroid Build Coastguard Worker	  # Not a shared library
8681*6236dae4SAndroid Build Coastguard Worker	  if test pass_all != "$deplibs_check_method"; then
8682*6236dae4SAndroid Build Coastguard Worker	    # We're trying link a shared library against a static one
8683*6236dae4SAndroid Build Coastguard Worker	    # but the system doesn't support it.
8684*6236dae4SAndroid Build Coastguard Worker
8685*6236dae4SAndroid Build Coastguard Worker	    # Just print a warning and add the library to dependency_libs so
8686*6236dae4SAndroid Build Coastguard Worker	    # that the program can be linked against the static library.
8687*6236dae4SAndroid Build Coastguard Worker	    echo
8688*6236dae4SAndroid Build Coastguard Worker	    $ECHO "*** Warning: This system cannot link to static lib archive $lib."
8689*6236dae4SAndroid Build Coastguard Worker	    echo "*** I have the capability to make that library automatically link in when"
8690*6236dae4SAndroid Build Coastguard Worker	    echo "*** you link to this library.  But I can only do this if you have a"
8691*6236dae4SAndroid Build Coastguard Worker	    echo "*** shared version of the library, which you do not appear to have."
8692*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$module"; then
8693*6236dae4SAndroid Build Coastguard Worker	      echo "*** But as you try to build a module library, libtool will still create "
8694*6236dae4SAndroid Build Coastguard Worker	      echo "*** a static module, that should work as long as the dlopening application"
8695*6236dae4SAndroid Build Coastguard Worker	      echo "*** is linked with the -dlopen flag to resolve symbols at runtime."
8696*6236dae4SAndroid Build Coastguard Worker	      if test -z "$global_symbol_pipe"; then
8697*6236dae4SAndroid Build Coastguard Worker		echo
8698*6236dae4SAndroid Build Coastguard Worker		echo "*** However, this would only work if libtool was able to extract symbol"
8699*6236dae4SAndroid Build Coastguard Worker		echo "*** lists from a program, using 'nm' or equivalent, but libtool could"
8700*6236dae4SAndroid Build Coastguard Worker		echo "*** not find such a program.  So, this module is probably useless."
8701*6236dae4SAndroid Build Coastguard Worker		echo "*** 'nm' from GNU binutils and a full rebuild may help."
8702*6236dae4SAndroid Build Coastguard Worker	      fi
8703*6236dae4SAndroid Build Coastguard Worker	      if test no = "$build_old_libs"; then
8704*6236dae4SAndroid Build Coastguard Worker		build_libtool_libs=module
8705*6236dae4SAndroid Build Coastguard Worker		build_old_libs=yes
8706*6236dae4SAndroid Build Coastguard Worker	      else
8707*6236dae4SAndroid Build Coastguard Worker		build_libtool_libs=no
8708*6236dae4SAndroid Build Coastguard Worker	      fi
8709*6236dae4SAndroid Build Coastguard Worker	    fi
8710*6236dae4SAndroid Build Coastguard Worker	  else
8711*6236dae4SAndroid Build Coastguard Worker	    deplibs="$dir/$old_library $deplibs"
8712*6236dae4SAndroid Build Coastguard Worker	    link_static=yes
8713*6236dae4SAndroid Build Coastguard Worker	  fi
8714*6236dae4SAndroid Build Coastguard Worker	fi # link shared/static library?
8715*6236dae4SAndroid Build Coastguard Worker
8716*6236dae4SAndroid Build Coastguard Worker	if test lib = "$linkmode"; then
8717*6236dae4SAndroid Build Coastguard Worker	  if test -n "$dependency_libs" &&
8718*6236dae4SAndroid Build Coastguard Worker	     { test yes != "$hardcode_into_libs" ||
8719*6236dae4SAndroid Build Coastguard Worker	       test yes = "$build_old_libs" ||
8720*6236dae4SAndroid Build Coastguard Worker	       test yes = "$link_static"; }; then
8721*6236dae4SAndroid Build Coastguard Worker	    # Extract -R from dependency_libs
8722*6236dae4SAndroid Build Coastguard Worker	    temp_deplibs=
8723*6236dae4SAndroid Build Coastguard Worker	    for libdir in $dependency_libs; do
8724*6236dae4SAndroid Build Coastguard Worker	      case $libdir in
8725*6236dae4SAndroid Build Coastguard Worker	      -R*) func_stripname '-R' '' "$libdir"
8726*6236dae4SAndroid Build Coastguard Worker	           temp_xrpath=$func_stripname_result
8727*6236dae4SAndroid Build Coastguard Worker		   case " $xrpath " in
8728*6236dae4SAndroid Build Coastguard Worker		   *" $temp_xrpath "*) ;;
8729*6236dae4SAndroid Build Coastguard Worker		   *) func_append xrpath " $temp_xrpath";;
8730*6236dae4SAndroid Build Coastguard Worker		   esac;;
8731*6236dae4SAndroid Build Coastguard Worker	      *) func_append temp_deplibs " $libdir";;
8732*6236dae4SAndroid Build Coastguard Worker	      esac
8733*6236dae4SAndroid Build Coastguard Worker	    done
8734*6236dae4SAndroid Build Coastguard Worker	    dependency_libs=$temp_deplibs
8735*6236dae4SAndroid Build Coastguard Worker	  fi
8736*6236dae4SAndroid Build Coastguard Worker
8737*6236dae4SAndroid Build Coastguard Worker	  func_append newlib_search_path " $absdir"
8738*6236dae4SAndroid Build Coastguard Worker	  # Link against this library
8739*6236dae4SAndroid Build Coastguard Worker	  test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
8740*6236dae4SAndroid Build Coastguard Worker	  # ... and its dependency_libs
8741*6236dae4SAndroid Build Coastguard Worker	  tmp_libs=
8742*6236dae4SAndroid Build Coastguard Worker	  for deplib in $dependency_libs; do
8743*6236dae4SAndroid Build Coastguard Worker	    newdependency_libs="$deplib $newdependency_libs"
8744*6236dae4SAndroid Build Coastguard Worker	    case $deplib in
8745*6236dae4SAndroid Build Coastguard Worker              -L*) func_stripname '-L' '' "$deplib"
8746*6236dae4SAndroid Build Coastguard Worker                   func_resolve_sysroot "$func_stripname_result";;
8747*6236dae4SAndroid Build Coastguard Worker              *) func_resolve_sysroot "$deplib" ;;
8748*6236dae4SAndroid Build Coastguard Worker            esac
8749*6236dae4SAndroid Build Coastguard Worker	    if $opt_preserve_dup_deps; then
8750*6236dae4SAndroid Build Coastguard Worker	      case "$tmp_libs " in
8751*6236dae4SAndroid Build Coastguard Worker	      *" $func_resolve_sysroot_result "*)
8752*6236dae4SAndroid Build Coastguard Worker                func_append specialdeplibs " $func_resolve_sysroot_result" ;;
8753*6236dae4SAndroid Build Coastguard Worker	      esac
8754*6236dae4SAndroid Build Coastguard Worker	    fi
8755*6236dae4SAndroid Build Coastguard Worker	    func_append tmp_libs " $func_resolve_sysroot_result"
8756*6236dae4SAndroid Build Coastguard Worker	  done
8757*6236dae4SAndroid Build Coastguard Worker
8758*6236dae4SAndroid Build Coastguard Worker	  if test no != "$link_all_deplibs"; then
8759*6236dae4SAndroid Build Coastguard Worker	    # Add the search paths of all dependency libraries
8760*6236dae4SAndroid Build Coastguard Worker	    for deplib in $dependency_libs; do
8761*6236dae4SAndroid Build Coastguard Worker	      path=
8762*6236dae4SAndroid Build Coastguard Worker	      case $deplib in
8763*6236dae4SAndroid Build Coastguard Worker	      -L*) path=$deplib ;;
8764*6236dae4SAndroid Build Coastguard Worker	      *.la)
8765*6236dae4SAndroid Build Coastguard Worker	        func_resolve_sysroot "$deplib"
8766*6236dae4SAndroid Build Coastguard Worker	        deplib=$func_resolve_sysroot_result
8767*6236dae4SAndroid Build Coastguard Worker	        func_dirname "$deplib" "" "."
8768*6236dae4SAndroid Build Coastguard Worker		dir=$func_dirname_result
8769*6236dae4SAndroid Build Coastguard Worker		# We need an absolute path.
8770*6236dae4SAndroid Build Coastguard Worker		case $dir in
8771*6236dae4SAndroid Build Coastguard Worker		[\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;;
8772*6236dae4SAndroid Build Coastguard Worker		*)
8773*6236dae4SAndroid Build Coastguard Worker		  absdir=`cd "$dir" && pwd`
8774*6236dae4SAndroid Build Coastguard Worker		  if test -z "$absdir"; then
8775*6236dae4SAndroid Build Coastguard Worker		    func_warning "cannot determine absolute directory name of '$dir'"
8776*6236dae4SAndroid Build Coastguard Worker		    absdir=$dir
8777*6236dae4SAndroid Build Coastguard Worker		  fi
8778*6236dae4SAndroid Build Coastguard Worker		  ;;
8779*6236dae4SAndroid Build Coastguard Worker		esac
8780*6236dae4SAndroid Build Coastguard Worker		if $GREP "^installed=no" $deplib > /dev/null; then
8781*6236dae4SAndroid Build Coastguard Worker		case $host in
8782*6236dae4SAndroid Build Coastguard Worker		*-*-darwin*)
8783*6236dae4SAndroid Build Coastguard Worker		  depdepl=
8784*6236dae4SAndroid Build Coastguard Worker		  eval deplibrary_names=`$SED -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
8785*6236dae4SAndroid Build Coastguard Worker		  if test -n "$deplibrary_names"; then
8786*6236dae4SAndroid Build Coastguard Worker		    for tmp in $deplibrary_names; do
8787*6236dae4SAndroid Build Coastguard Worker		      depdepl=$tmp
8788*6236dae4SAndroid Build Coastguard Worker		    done
8789*6236dae4SAndroid Build Coastguard Worker		    if test -f "$absdir/$objdir/$depdepl"; then
8790*6236dae4SAndroid Build Coastguard Worker		      depdepl=$absdir/$objdir/$depdepl
8791*6236dae4SAndroid Build Coastguard Worker		      darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
8792*6236dae4SAndroid Build Coastguard Worker                      if test -z "$darwin_install_name"; then
8793*6236dae4SAndroid Build Coastguard Worker                          darwin_install_name=`$OTOOL64 -L $depdepl  | awk '{if (NR == 2) {print $1;exit}}'`
8794*6236dae4SAndroid Build Coastguard Worker                      fi
8795*6236dae4SAndroid Build Coastguard Worker		      func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl"
8796*6236dae4SAndroid Build Coastguard Worker		      func_append linker_flags " -dylib_file $darwin_install_name:$depdepl"
8797*6236dae4SAndroid Build Coastguard Worker		      path=
8798*6236dae4SAndroid Build Coastguard Worker		    fi
8799*6236dae4SAndroid Build Coastguard Worker		  fi
8800*6236dae4SAndroid Build Coastguard Worker		  ;;
8801*6236dae4SAndroid Build Coastguard Worker		*)
8802*6236dae4SAndroid Build Coastguard Worker		  path=-L$absdir/$objdir
8803*6236dae4SAndroid Build Coastguard Worker		  ;;
8804*6236dae4SAndroid Build Coastguard Worker		esac
8805*6236dae4SAndroid Build Coastguard Worker		else
8806*6236dae4SAndroid Build Coastguard Worker		  eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
8807*6236dae4SAndroid Build Coastguard Worker		  test -z "$libdir" && \
8808*6236dae4SAndroid Build Coastguard Worker		    func_fatal_error "'$deplib' is not a valid libtool archive"
8809*6236dae4SAndroid Build Coastguard Worker		  test "$absdir" != "$libdir" && \
8810*6236dae4SAndroid Build Coastguard Worker		    func_warning "'$deplib' seems to be moved"
8811*6236dae4SAndroid Build Coastguard Worker
8812*6236dae4SAndroid Build Coastguard Worker		  path=-L$absdir
8813*6236dae4SAndroid Build Coastguard Worker		fi
8814*6236dae4SAndroid Build Coastguard Worker		;;
8815*6236dae4SAndroid Build Coastguard Worker	      esac
8816*6236dae4SAndroid Build Coastguard Worker	      case " $deplibs " in
8817*6236dae4SAndroid Build Coastguard Worker	      *" $path "*) ;;
8818*6236dae4SAndroid Build Coastguard Worker	      *) deplibs="$path $deplibs" ;;
8819*6236dae4SAndroid Build Coastguard Worker	      esac
8820*6236dae4SAndroid Build Coastguard Worker	    done
8821*6236dae4SAndroid Build Coastguard Worker	  fi # link_all_deplibs != no
8822*6236dae4SAndroid Build Coastguard Worker	fi # linkmode = lib
8823*6236dae4SAndroid Build Coastguard Worker      done # for deplib in $libs
8824*6236dae4SAndroid Build Coastguard Worker      if test link = "$pass"; then
8825*6236dae4SAndroid Build Coastguard Worker	if test prog = "$linkmode"; then
8826*6236dae4SAndroid Build Coastguard Worker	  compile_deplibs="$new_inherited_linker_flags $compile_deplibs"
8827*6236dae4SAndroid Build Coastguard Worker	  finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs"
8828*6236dae4SAndroid Build Coastguard Worker	else
8829*6236dae4SAndroid Build Coastguard Worker	  compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
8830*6236dae4SAndroid Build Coastguard Worker	fi
8831*6236dae4SAndroid Build Coastguard Worker      fi
8832*6236dae4SAndroid Build Coastguard Worker      dependency_libs=$newdependency_libs
8833*6236dae4SAndroid Build Coastguard Worker      if test dlpreopen = "$pass"; then
8834*6236dae4SAndroid Build Coastguard Worker	# Link the dlpreopened libraries before other libraries
8835*6236dae4SAndroid Build Coastguard Worker	for deplib in $save_deplibs; do
8836*6236dae4SAndroid Build Coastguard Worker	  deplibs="$deplib $deplibs"
8837*6236dae4SAndroid Build Coastguard Worker	done
8838*6236dae4SAndroid Build Coastguard Worker      fi
8839*6236dae4SAndroid Build Coastguard Worker      if test dlopen != "$pass"; then
8840*6236dae4SAndroid Build Coastguard Worker	test conv = "$pass" || {
8841*6236dae4SAndroid Build Coastguard Worker	  # Make sure lib_search_path contains only unique directories.
8842*6236dae4SAndroid Build Coastguard Worker	  lib_search_path=
8843*6236dae4SAndroid Build Coastguard Worker	  for dir in $newlib_search_path; do
8844*6236dae4SAndroid Build Coastguard Worker	    case "$lib_search_path " in
8845*6236dae4SAndroid Build Coastguard Worker	    *" $dir "*) ;;
8846*6236dae4SAndroid Build Coastguard Worker	    *) func_append lib_search_path " $dir" ;;
8847*6236dae4SAndroid Build Coastguard Worker	    esac
8848*6236dae4SAndroid Build Coastguard Worker	  done
8849*6236dae4SAndroid Build Coastguard Worker	  newlib_search_path=
8850*6236dae4SAndroid Build Coastguard Worker	}
8851*6236dae4SAndroid Build Coastguard Worker
8852*6236dae4SAndroid Build Coastguard Worker	if test prog,link = "$linkmode,$pass"; then
8853*6236dae4SAndroid Build Coastguard Worker	  vars="compile_deplibs finalize_deplibs"
8854*6236dae4SAndroid Build Coastguard Worker	else
8855*6236dae4SAndroid Build Coastguard Worker	  vars=deplibs
8856*6236dae4SAndroid Build Coastguard Worker	fi
8857*6236dae4SAndroid Build Coastguard Worker	for var in $vars dependency_libs; do
8858*6236dae4SAndroid Build Coastguard Worker	  # Add libraries to $var in reverse order
8859*6236dae4SAndroid Build Coastguard Worker	  eval tmp_libs=\"\$$var\"
8860*6236dae4SAndroid Build Coastguard Worker	  new_libs=
8861*6236dae4SAndroid Build Coastguard Worker	  for deplib in $tmp_libs; do
8862*6236dae4SAndroid Build Coastguard Worker	    # FIXME: Pedantically, this is the right thing to do, so
8863*6236dae4SAndroid Build Coastguard Worker	    #        that some nasty dependency loop isn't accidentally
8864*6236dae4SAndroid Build Coastguard Worker	    #        broken:
8865*6236dae4SAndroid Build Coastguard Worker	    #new_libs="$deplib $new_libs"
8866*6236dae4SAndroid Build Coastguard Worker	    # Pragmatically, this seems to cause very few problems in
8867*6236dae4SAndroid Build Coastguard Worker	    # practice:
8868*6236dae4SAndroid Build Coastguard Worker	    case $deplib in
8869*6236dae4SAndroid Build Coastguard Worker	    -L*) new_libs="$deplib $new_libs" ;;
8870*6236dae4SAndroid Build Coastguard Worker	    -R*) ;;
8871*6236dae4SAndroid Build Coastguard Worker	    *)
8872*6236dae4SAndroid Build Coastguard Worker	      # And here is the reason: when a library appears more
8873*6236dae4SAndroid Build Coastguard Worker	      # than once as an explicit dependence of a library, or
8874*6236dae4SAndroid Build Coastguard Worker	      # is implicitly linked in more than once by the
8875*6236dae4SAndroid Build Coastguard Worker	      # compiler, it is considered special, and multiple
8876*6236dae4SAndroid Build Coastguard Worker	      # occurrences thereof are not removed.  Compare this
8877*6236dae4SAndroid Build Coastguard Worker	      # with having the same library being listed as a
8878*6236dae4SAndroid Build Coastguard Worker	      # dependency of multiple other libraries: in this case,
8879*6236dae4SAndroid Build Coastguard Worker	      # we know (pedantically, we assume) the library does not
8880*6236dae4SAndroid Build Coastguard Worker	      # need to be listed more than once, so we keep only the
8881*6236dae4SAndroid Build Coastguard Worker	      # last copy.  This is not always right, but it is rare
8882*6236dae4SAndroid Build Coastguard Worker	      # enough that we require users that really mean to play
8883*6236dae4SAndroid Build Coastguard Worker	      # such unportable linking tricks to link the library
8884*6236dae4SAndroid Build Coastguard Worker	      # using -Wl,-lname, so that libtool does not consider it
8885*6236dae4SAndroid Build Coastguard Worker	      # for duplicate removal.
8886*6236dae4SAndroid Build Coastguard Worker	      case " $specialdeplibs " in
8887*6236dae4SAndroid Build Coastguard Worker	      *" $deplib "*) new_libs="$deplib $new_libs" ;;
8888*6236dae4SAndroid Build Coastguard Worker	      *)
8889*6236dae4SAndroid Build Coastguard Worker		case " $new_libs " in
8890*6236dae4SAndroid Build Coastguard Worker		*" $deplib "*) ;;
8891*6236dae4SAndroid Build Coastguard Worker		*) new_libs="$deplib $new_libs" ;;
8892*6236dae4SAndroid Build Coastguard Worker		esac
8893*6236dae4SAndroid Build Coastguard Worker		;;
8894*6236dae4SAndroid Build Coastguard Worker	      esac
8895*6236dae4SAndroid Build Coastguard Worker	      ;;
8896*6236dae4SAndroid Build Coastguard Worker	    esac
8897*6236dae4SAndroid Build Coastguard Worker	  done
8898*6236dae4SAndroid Build Coastguard Worker	  tmp_libs=
8899*6236dae4SAndroid Build Coastguard Worker	  for deplib in $new_libs; do
8900*6236dae4SAndroid Build Coastguard Worker	    case $deplib in
8901*6236dae4SAndroid Build Coastguard Worker	    -L*)
8902*6236dae4SAndroid Build Coastguard Worker	      case " $tmp_libs " in
8903*6236dae4SAndroid Build Coastguard Worker	      *" $deplib "*) ;;
8904*6236dae4SAndroid Build Coastguard Worker	      *) func_append tmp_libs " $deplib" ;;
8905*6236dae4SAndroid Build Coastguard Worker	      esac
8906*6236dae4SAndroid Build Coastguard Worker	      ;;
8907*6236dae4SAndroid Build Coastguard Worker	    *) func_append tmp_libs " $deplib" ;;
8908*6236dae4SAndroid Build Coastguard Worker	    esac
8909*6236dae4SAndroid Build Coastguard Worker	  done
8910*6236dae4SAndroid Build Coastguard Worker	  eval $var=\"$tmp_libs\"
8911*6236dae4SAndroid Build Coastguard Worker	done # for var
8912*6236dae4SAndroid Build Coastguard Worker      fi
8913*6236dae4SAndroid Build Coastguard Worker
8914*6236dae4SAndroid Build Coastguard Worker      # Add Sun CC postdeps if required:
8915*6236dae4SAndroid Build Coastguard Worker      test CXX = "$tagname" && {
8916*6236dae4SAndroid Build Coastguard Worker        case $host_os in
8917*6236dae4SAndroid Build Coastguard Worker        linux*)
8918*6236dae4SAndroid Build Coastguard Worker          case `$CC -V 2>&1 | $SED 5q` in
8919*6236dae4SAndroid Build Coastguard Worker          *Sun\ C*) # Sun C++ 5.9
8920*6236dae4SAndroid Build Coastguard Worker            func_suncc_cstd_abi
8921*6236dae4SAndroid Build Coastguard Worker
8922*6236dae4SAndroid Build Coastguard Worker            if test no != "$suncc_use_cstd_abi"; then
8923*6236dae4SAndroid Build Coastguard Worker              func_append postdeps ' -library=Cstd -library=Crun'
8924*6236dae4SAndroid Build Coastguard Worker            fi
8925*6236dae4SAndroid Build Coastguard Worker            ;;
8926*6236dae4SAndroid Build Coastguard Worker          esac
8927*6236dae4SAndroid Build Coastguard Worker          ;;
8928*6236dae4SAndroid Build Coastguard Worker
8929*6236dae4SAndroid Build Coastguard Worker        solaris*)
8930*6236dae4SAndroid Build Coastguard Worker          func_cc_basename "$CC"
8931*6236dae4SAndroid Build Coastguard Worker          case $func_cc_basename_result in
8932*6236dae4SAndroid Build Coastguard Worker          CC* | sunCC*)
8933*6236dae4SAndroid Build Coastguard Worker            func_suncc_cstd_abi
8934*6236dae4SAndroid Build Coastguard Worker
8935*6236dae4SAndroid Build Coastguard Worker            if test no != "$suncc_use_cstd_abi"; then
8936*6236dae4SAndroid Build Coastguard Worker              func_append postdeps ' -library=Cstd -library=Crun'
8937*6236dae4SAndroid Build Coastguard Worker            fi
8938*6236dae4SAndroid Build Coastguard Worker            ;;
8939*6236dae4SAndroid Build Coastguard Worker          esac
8940*6236dae4SAndroid Build Coastguard Worker          ;;
8941*6236dae4SAndroid Build Coastguard Worker        esac
8942*6236dae4SAndroid Build Coastguard Worker      }
8943*6236dae4SAndroid Build Coastguard Worker
8944*6236dae4SAndroid Build Coastguard Worker      # Last step: remove runtime libs from dependency_libs
8945*6236dae4SAndroid Build Coastguard Worker      # (they stay in deplibs)
8946*6236dae4SAndroid Build Coastguard Worker      tmp_libs=
8947*6236dae4SAndroid Build Coastguard Worker      for i in $dependency_libs; do
8948*6236dae4SAndroid Build Coastguard Worker	case " $predeps $postdeps $compiler_lib_search_path " in
8949*6236dae4SAndroid Build Coastguard Worker	*" $i "*)
8950*6236dae4SAndroid Build Coastguard Worker	  i=
8951*6236dae4SAndroid Build Coastguard Worker	  ;;
8952*6236dae4SAndroid Build Coastguard Worker	esac
8953*6236dae4SAndroid Build Coastguard Worker	if test -n "$i"; then
8954*6236dae4SAndroid Build Coastguard Worker	  func_append tmp_libs " $i"
8955*6236dae4SAndroid Build Coastguard Worker	fi
8956*6236dae4SAndroid Build Coastguard Worker      done
8957*6236dae4SAndroid Build Coastguard Worker      dependency_libs=$tmp_libs
8958*6236dae4SAndroid Build Coastguard Worker    done # for pass
8959*6236dae4SAndroid Build Coastguard Worker    if test prog = "$linkmode"; then
8960*6236dae4SAndroid Build Coastguard Worker      dlfiles=$newdlfiles
8961*6236dae4SAndroid Build Coastguard Worker    fi
8962*6236dae4SAndroid Build Coastguard Worker    if test prog = "$linkmode" || test lib = "$linkmode"; then
8963*6236dae4SAndroid Build Coastguard Worker      dlprefiles=$newdlprefiles
8964*6236dae4SAndroid Build Coastguard Worker    fi
8965*6236dae4SAndroid Build Coastguard Worker
8966*6236dae4SAndroid Build Coastguard Worker    case $linkmode in
8967*6236dae4SAndroid Build Coastguard Worker    oldlib)
8968*6236dae4SAndroid Build Coastguard Worker      if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
8969*6236dae4SAndroid Build Coastguard Worker	func_warning "'-dlopen' is ignored for archives"
8970*6236dae4SAndroid Build Coastguard Worker      fi
8971*6236dae4SAndroid Build Coastguard Worker
8972*6236dae4SAndroid Build Coastguard Worker      case " $deplibs" in
8973*6236dae4SAndroid Build Coastguard Worker      *\ -l* | *\ -L*)
8974*6236dae4SAndroid Build Coastguard Worker	func_warning "'-l' and '-L' are ignored for archives" ;;
8975*6236dae4SAndroid Build Coastguard Worker      esac
8976*6236dae4SAndroid Build Coastguard Worker
8977*6236dae4SAndroid Build Coastguard Worker      test -n "$rpath" && \
8978*6236dae4SAndroid Build Coastguard Worker	func_warning "'-rpath' is ignored for archives"
8979*6236dae4SAndroid Build Coastguard Worker
8980*6236dae4SAndroid Build Coastguard Worker      test -n "$xrpath" && \
8981*6236dae4SAndroid Build Coastguard Worker	func_warning "'-R' is ignored for archives"
8982*6236dae4SAndroid Build Coastguard Worker
8983*6236dae4SAndroid Build Coastguard Worker      test -n "$vinfo" && \
8984*6236dae4SAndroid Build Coastguard Worker	func_warning "'-version-info/-version-number' is ignored for archives"
8985*6236dae4SAndroid Build Coastguard Worker
8986*6236dae4SAndroid Build Coastguard Worker      test -n "$release" && \
8987*6236dae4SAndroid Build Coastguard Worker	func_warning "'-release' is ignored for archives"
8988*6236dae4SAndroid Build Coastguard Worker
8989*6236dae4SAndroid Build Coastguard Worker      test -n "$export_symbols$export_symbols_regex" && \
8990*6236dae4SAndroid Build Coastguard Worker	func_warning "'-export-symbols' is ignored for archives"
8991*6236dae4SAndroid Build Coastguard Worker
8992*6236dae4SAndroid Build Coastguard Worker      # Now set the variables for building old libraries.
8993*6236dae4SAndroid Build Coastguard Worker      build_libtool_libs=no
8994*6236dae4SAndroid Build Coastguard Worker      oldlibs=$output
8995*6236dae4SAndroid Build Coastguard Worker      func_append objs "$old_deplibs"
8996*6236dae4SAndroid Build Coastguard Worker      ;;
8997*6236dae4SAndroid Build Coastguard Worker
8998*6236dae4SAndroid Build Coastguard Worker    lib)
8999*6236dae4SAndroid Build Coastguard Worker      # Make sure we only generate libraries of the form 'libNAME.la'.
9000*6236dae4SAndroid Build Coastguard Worker      case $outputname in
9001*6236dae4SAndroid Build Coastguard Worker      lib*)
9002*6236dae4SAndroid Build Coastguard Worker	func_stripname 'lib' '.la' "$outputname"
9003*6236dae4SAndroid Build Coastguard Worker	name=$func_stripname_result
9004*6236dae4SAndroid Build Coastguard Worker	eval shared_ext=\"$shrext_cmds\"
9005*6236dae4SAndroid Build Coastguard Worker	eval libname=\"$libname_spec\"
9006*6236dae4SAndroid Build Coastguard Worker	;;
9007*6236dae4SAndroid Build Coastguard Worker      *)
9008*6236dae4SAndroid Build Coastguard Worker	test no = "$module" \
9009*6236dae4SAndroid Build Coastguard Worker	  && func_fatal_help "libtool library '$output' must begin with 'lib'"
9010*6236dae4SAndroid Build Coastguard Worker
9011*6236dae4SAndroid Build Coastguard Worker	if test no != "$need_lib_prefix"; then
9012*6236dae4SAndroid Build Coastguard Worker	  # Add the "lib" prefix for modules if required
9013*6236dae4SAndroid Build Coastguard Worker	  func_stripname '' '.la' "$outputname"
9014*6236dae4SAndroid Build Coastguard Worker	  name=$func_stripname_result
9015*6236dae4SAndroid Build Coastguard Worker	  eval shared_ext=\"$shrext_cmds\"
9016*6236dae4SAndroid Build Coastguard Worker	  eval libname=\"$libname_spec\"
9017*6236dae4SAndroid Build Coastguard Worker	else
9018*6236dae4SAndroid Build Coastguard Worker	  func_stripname '' '.la' "$outputname"
9019*6236dae4SAndroid Build Coastguard Worker	  libname=$func_stripname_result
9020*6236dae4SAndroid Build Coastguard Worker	fi
9021*6236dae4SAndroid Build Coastguard Worker	;;
9022*6236dae4SAndroid Build Coastguard Worker      esac
9023*6236dae4SAndroid Build Coastguard Worker
9024*6236dae4SAndroid Build Coastguard Worker      if test -n "$objs"; then
9025*6236dae4SAndroid Build Coastguard Worker	if test pass_all != "$deplibs_check_method"; then
9026*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs"
9027*6236dae4SAndroid Build Coastguard Worker	else
9028*6236dae4SAndroid Build Coastguard Worker	  echo
9029*6236dae4SAndroid Build Coastguard Worker	  $ECHO "*** Warning: Linking the shared library $output against the non-libtool"
9030*6236dae4SAndroid Build Coastguard Worker	  $ECHO "*** objects $objs is not portable!"
9031*6236dae4SAndroid Build Coastguard Worker	  func_append libobjs " $objs"
9032*6236dae4SAndroid Build Coastguard Worker	fi
9033*6236dae4SAndroid Build Coastguard Worker      fi
9034*6236dae4SAndroid Build Coastguard Worker
9035*6236dae4SAndroid Build Coastguard Worker      test no = "$dlself" \
9036*6236dae4SAndroid Build Coastguard Worker	|| func_warning "'-dlopen self' is ignored for libtool libraries"
9037*6236dae4SAndroid Build Coastguard Worker
9038*6236dae4SAndroid Build Coastguard Worker      set dummy $rpath
9039*6236dae4SAndroid Build Coastguard Worker      shift
9040*6236dae4SAndroid Build Coastguard Worker      test 1 -lt "$#" \
9041*6236dae4SAndroid Build Coastguard Worker	&& func_warning "ignoring multiple '-rpath's for a libtool library"
9042*6236dae4SAndroid Build Coastguard Worker
9043*6236dae4SAndroid Build Coastguard Worker      install_libdir=$1
9044*6236dae4SAndroid Build Coastguard Worker
9045*6236dae4SAndroid Build Coastguard Worker      oldlibs=
9046*6236dae4SAndroid Build Coastguard Worker      if test -z "$rpath"; then
9047*6236dae4SAndroid Build Coastguard Worker	if test yes = "$build_libtool_libs"; then
9048*6236dae4SAndroid Build Coastguard Worker	  # Building a libtool convenience library.
9049*6236dae4SAndroid Build Coastguard Worker	  # Some compilers have problems with a '.al' extension so
9050*6236dae4SAndroid Build Coastguard Worker	  # convenience libraries should have the same extension an
9051*6236dae4SAndroid Build Coastguard Worker	  # archive normally would.
9052*6236dae4SAndroid Build Coastguard Worker	  oldlibs="$output_objdir/$libname.$libext $oldlibs"
9053*6236dae4SAndroid Build Coastguard Worker	  build_libtool_libs=convenience
9054*6236dae4SAndroid Build Coastguard Worker	  build_old_libs=yes
9055*6236dae4SAndroid Build Coastguard Worker	fi
9056*6236dae4SAndroid Build Coastguard Worker
9057*6236dae4SAndroid Build Coastguard Worker	test -n "$vinfo" && \
9058*6236dae4SAndroid Build Coastguard Worker	  func_warning "'-version-info/-version-number' is ignored for convenience libraries"
9059*6236dae4SAndroid Build Coastguard Worker
9060*6236dae4SAndroid Build Coastguard Worker	test -n "$release" && \
9061*6236dae4SAndroid Build Coastguard Worker	  func_warning "'-release' is ignored for convenience libraries"
9062*6236dae4SAndroid Build Coastguard Worker      else
9063*6236dae4SAndroid Build Coastguard Worker
9064*6236dae4SAndroid Build Coastguard Worker	# Parse the version information argument.
9065*6236dae4SAndroid Build Coastguard Worker	save_ifs=$IFS; IFS=:
9066*6236dae4SAndroid Build Coastguard Worker	set dummy $vinfo 0 0 0
9067*6236dae4SAndroid Build Coastguard Worker	shift
9068*6236dae4SAndroid Build Coastguard Worker	IFS=$save_ifs
9069*6236dae4SAndroid Build Coastguard Worker
9070*6236dae4SAndroid Build Coastguard Worker	test -n "$7" && \
9071*6236dae4SAndroid Build Coastguard Worker	  func_fatal_help "too many parameters to '-version-info'"
9072*6236dae4SAndroid Build Coastguard Worker
9073*6236dae4SAndroid Build Coastguard Worker	# convert absolute version numbers to libtool ages
9074*6236dae4SAndroid Build Coastguard Worker	# this retains compatibility with .la files and attempts
9075*6236dae4SAndroid Build Coastguard Worker	# to make the code below a bit more comprehensible
9076*6236dae4SAndroid Build Coastguard Worker
9077*6236dae4SAndroid Build Coastguard Worker	case $vinfo_number in
9078*6236dae4SAndroid Build Coastguard Worker	yes)
9079*6236dae4SAndroid Build Coastguard Worker	  number_major=$1
9080*6236dae4SAndroid Build Coastguard Worker	  number_minor=$2
9081*6236dae4SAndroid Build Coastguard Worker	  number_revision=$3
9082*6236dae4SAndroid Build Coastguard Worker	  #
9083*6236dae4SAndroid Build Coastguard Worker	  # There are really only two kinds -- those that
9084*6236dae4SAndroid Build Coastguard Worker	  # use the current revision as the major version
9085*6236dae4SAndroid Build Coastguard Worker	  # and those that subtract age and use age as
9086*6236dae4SAndroid Build Coastguard Worker	  # a minor version.  But, then there is irix
9087*6236dae4SAndroid Build Coastguard Worker	  # that has an extra 1 added just for fun
9088*6236dae4SAndroid Build Coastguard Worker	  #
9089*6236dae4SAndroid Build Coastguard Worker	  case $version_type in
9090*6236dae4SAndroid Build Coastguard Worker	  # correct linux to gnu/linux during the next big refactor
9091*6236dae4SAndroid Build Coastguard Worker	  darwin|freebsd-elf|linux|midnightbsd-elf|osf|windows|none)
9092*6236dae4SAndroid Build Coastguard Worker	    func_arith $number_major + $number_minor
9093*6236dae4SAndroid Build Coastguard Worker	    current=$func_arith_result
9094*6236dae4SAndroid Build Coastguard Worker	    age=$number_minor
9095*6236dae4SAndroid Build Coastguard Worker	    revision=$number_revision
9096*6236dae4SAndroid Build Coastguard Worker	    ;;
9097*6236dae4SAndroid Build Coastguard Worker	  freebsd-aout|qnx|sunos)
9098*6236dae4SAndroid Build Coastguard Worker	    current=$number_major
9099*6236dae4SAndroid Build Coastguard Worker	    revision=$number_minor
9100*6236dae4SAndroid Build Coastguard Worker	    age=0
9101*6236dae4SAndroid Build Coastguard Worker	    ;;
9102*6236dae4SAndroid Build Coastguard Worker	  irix|nonstopux)
9103*6236dae4SAndroid Build Coastguard Worker	    func_arith $number_major + $number_minor
9104*6236dae4SAndroid Build Coastguard Worker	    current=$func_arith_result
9105*6236dae4SAndroid Build Coastguard Worker	    age=$number_minor
9106*6236dae4SAndroid Build Coastguard Worker	    revision=$number_minor
9107*6236dae4SAndroid Build Coastguard Worker	    lt_irix_increment=no
9108*6236dae4SAndroid Build Coastguard Worker	    ;;
9109*6236dae4SAndroid Build Coastguard Worker	  *)
9110*6236dae4SAndroid Build Coastguard Worker	    func_fatal_configuration "$modename: unknown library version type '$version_type'"
9111*6236dae4SAndroid Build Coastguard Worker	    ;;
9112*6236dae4SAndroid Build Coastguard Worker	  esac
9113*6236dae4SAndroid Build Coastguard Worker	  ;;
9114*6236dae4SAndroid Build Coastguard Worker	no)
9115*6236dae4SAndroid Build Coastguard Worker	  current=$1
9116*6236dae4SAndroid Build Coastguard Worker	  revision=$2
9117*6236dae4SAndroid Build Coastguard Worker	  age=$3
9118*6236dae4SAndroid Build Coastguard Worker	  ;;
9119*6236dae4SAndroid Build Coastguard Worker	esac
9120*6236dae4SAndroid Build Coastguard Worker
9121*6236dae4SAndroid Build Coastguard Worker	# Check that each of the things are valid numbers.
9122*6236dae4SAndroid Build Coastguard Worker	case $current in
9123*6236dae4SAndroid Build Coastguard Worker	0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
9124*6236dae4SAndroid Build Coastguard Worker	*)
9125*6236dae4SAndroid Build Coastguard Worker	  func_error "CURRENT '$current' must be a nonnegative integer"
9126*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "'$vinfo' is not valid version information"
9127*6236dae4SAndroid Build Coastguard Worker	  ;;
9128*6236dae4SAndroid Build Coastguard Worker	esac
9129*6236dae4SAndroid Build Coastguard Worker
9130*6236dae4SAndroid Build Coastguard Worker	case $revision in
9131*6236dae4SAndroid Build Coastguard Worker	0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
9132*6236dae4SAndroid Build Coastguard Worker	*)
9133*6236dae4SAndroid Build Coastguard Worker	  func_error "REVISION '$revision' must be a nonnegative integer"
9134*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "'$vinfo' is not valid version information"
9135*6236dae4SAndroid Build Coastguard Worker	  ;;
9136*6236dae4SAndroid Build Coastguard Worker	esac
9137*6236dae4SAndroid Build Coastguard Worker
9138*6236dae4SAndroid Build Coastguard Worker	case $age in
9139*6236dae4SAndroid Build Coastguard Worker	0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
9140*6236dae4SAndroid Build Coastguard Worker	*)
9141*6236dae4SAndroid Build Coastguard Worker	  func_error "AGE '$age' must be a nonnegative integer"
9142*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "'$vinfo' is not valid version information"
9143*6236dae4SAndroid Build Coastguard Worker	  ;;
9144*6236dae4SAndroid Build Coastguard Worker	esac
9145*6236dae4SAndroid Build Coastguard Worker
9146*6236dae4SAndroid Build Coastguard Worker	if test "$age" -gt "$current"; then
9147*6236dae4SAndroid Build Coastguard Worker	  func_error "AGE '$age' is greater than the current interface number '$current'"
9148*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "'$vinfo' is not valid version information"
9149*6236dae4SAndroid Build Coastguard Worker	fi
9150*6236dae4SAndroid Build Coastguard Worker
9151*6236dae4SAndroid Build Coastguard Worker	# Calculate the version variables.
9152*6236dae4SAndroid Build Coastguard Worker	major=
9153*6236dae4SAndroid Build Coastguard Worker	versuffix=
9154*6236dae4SAndroid Build Coastguard Worker	verstring=
9155*6236dae4SAndroid Build Coastguard Worker	case $version_type in
9156*6236dae4SAndroid Build Coastguard Worker	none) ;;
9157*6236dae4SAndroid Build Coastguard Worker
9158*6236dae4SAndroid Build Coastguard Worker	darwin)
9159*6236dae4SAndroid Build Coastguard Worker	  # Like Linux, but with the current version available in
9160*6236dae4SAndroid Build Coastguard Worker	  # verstring for coding it into the library header
9161*6236dae4SAndroid Build Coastguard Worker	  func_arith $current - $age
9162*6236dae4SAndroid Build Coastguard Worker	  major=.$func_arith_result
9163*6236dae4SAndroid Build Coastguard Worker	  versuffix=$major.$age.$revision
9164*6236dae4SAndroid Build Coastguard Worker	  # Darwin ld doesn't like 0 for these options...
9165*6236dae4SAndroid Build Coastguard Worker	  func_arith $current + 1
9166*6236dae4SAndroid Build Coastguard Worker	  minor_current=$func_arith_result
9167*6236dae4SAndroid Build Coastguard Worker	  xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision"
9168*6236dae4SAndroid Build Coastguard Worker	  verstring="-compatibility_version $minor_current -current_version $minor_current.$revision"
9169*6236dae4SAndroid Build Coastguard Worker          # On Darwin other compilers
9170*6236dae4SAndroid Build Coastguard Worker          case $CC in
9171*6236dae4SAndroid Build Coastguard Worker              nagfor*)
9172*6236dae4SAndroid Build Coastguard Worker                  verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision"
9173*6236dae4SAndroid Build Coastguard Worker                  ;;
9174*6236dae4SAndroid Build Coastguard Worker              *)
9175*6236dae4SAndroid Build Coastguard Worker                  verstring="-compatibility_version $minor_current -current_version $minor_current.$revision"
9176*6236dae4SAndroid Build Coastguard Worker                  ;;
9177*6236dae4SAndroid Build Coastguard Worker          esac
9178*6236dae4SAndroid Build Coastguard Worker	  ;;
9179*6236dae4SAndroid Build Coastguard Worker
9180*6236dae4SAndroid Build Coastguard Worker	freebsd-aout)
9181*6236dae4SAndroid Build Coastguard Worker	  major=.$current
9182*6236dae4SAndroid Build Coastguard Worker	  versuffix=.$current.$revision
9183*6236dae4SAndroid Build Coastguard Worker	  ;;
9184*6236dae4SAndroid Build Coastguard Worker
9185*6236dae4SAndroid Build Coastguard Worker	freebsd-elf | midnightbsd-elf)
9186*6236dae4SAndroid Build Coastguard Worker	  func_arith $current - $age
9187*6236dae4SAndroid Build Coastguard Worker	  major=.$func_arith_result
9188*6236dae4SAndroid Build Coastguard Worker	  versuffix=$major.$age.$revision
9189*6236dae4SAndroid Build Coastguard Worker	  ;;
9190*6236dae4SAndroid Build Coastguard Worker
9191*6236dae4SAndroid Build Coastguard Worker	irix | nonstopux)
9192*6236dae4SAndroid Build Coastguard Worker	  if test no = "$lt_irix_increment"; then
9193*6236dae4SAndroid Build Coastguard Worker	    func_arith $current - $age
9194*6236dae4SAndroid Build Coastguard Worker	  else
9195*6236dae4SAndroid Build Coastguard Worker	    func_arith $current - $age + 1
9196*6236dae4SAndroid Build Coastguard Worker	  fi
9197*6236dae4SAndroid Build Coastguard Worker	  major=$func_arith_result
9198*6236dae4SAndroid Build Coastguard Worker
9199*6236dae4SAndroid Build Coastguard Worker	  case $version_type in
9200*6236dae4SAndroid Build Coastguard Worker	    nonstopux) verstring_prefix=nonstopux ;;
9201*6236dae4SAndroid Build Coastguard Worker	    *)         verstring_prefix=sgi ;;
9202*6236dae4SAndroid Build Coastguard Worker	  esac
9203*6236dae4SAndroid Build Coastguard Worker	  verstring=$verstring_prefix$major.$revision
9204*6236dae4SAndroid Build Coastguard Worker
9205*6236dae4SAndroid Build Coastguard Worker	  # Add in all the interfaces that we are compatible with.
9206*6236dae4SAndroid Build Coastguard Worker	  loop=$revision
9207*6236dae4SAndroid Build Coastguard Worker	  while test 0 -ne "$loop"; do
9208*6236dae4SAndroid Build Coastguard Worker	    func_arith $revision - $loop
9209*6236dae4SAndroid Build Coastguard Worker	    iface=$func_arith_result
9210*6236dae4SAndroid Build Coastguard Worker	    func_arith $loop - 1
9211*6236dae4SAndroid Build Coastguard Worker	    loop=$func_arith_result
9212*6236dae4SAndroid Build Coastguard Worker	    verstring=$verstring_prefix$major.$iface:$verstring
9213*6236dae4SAndroid Build Coastguard Worker	  done
9214*6236dae4SAndroid Build Coastguard Worker
9215*6236dae4SAndroid Build Coastguard Worker	  # Before this point, $major must not contain '.'.
9216*6236dae4SAndroid Build Coastguard Worker	  major=.$major
9217*6236dae4SAndroid Build Coastguard Worker	  versuffix=$major.$revision
9218*6236dae4SAndroid Build Coastguard Worker	  ;;
9219*6236dae4SAndroid Build Coastguard Worker
9220*6236dae4SAndroid Build Coastguard Worker	linux) # correct to gnu/linux during the next big refactor
9221*6236dae4SAndroid Build Coastguard Worker	  func_arith $current - $age
9222*6236dae4SAndroid Build Coastguard Worker	  major=.$func_arith_result
9223*6236dae4SAndroid Build Coastguard Worker	  versuffix=$major.$age.$revision
9224*6236dae4SAndroid Build Coastguard Worker	  ;;
9225*6236dae4SAndroid Build Coastguard Worker
9226*6236dae4SAndroid Build Coastguard Worker	osf)
9227*6236dae4SAndroid Build Coastguard Worker	  func_arith $current - $age
9228*6236dae4SAndroid Build Coastguard Worker	  major=.$func_arith_result
9229*6236dae4SAndroid Build Coastguard Worker	  versuffix=.$current.$age.$revision
9230*6236dae4SAndroid Build Coastguard Worker	  verstring=$current.$age.$revision
9231*6236dae4SAndroid Build Coastguard Worker
9232*6236dae4SAndroid Build Coastguard Worker	  # Add in all the interfaces that we are compatible with.
9233*6236dae4SAndroid Build Coastguard Worker	  loop=$age
9234*6236dae4SAndroid Build Coastguard Worker	  while test 0 -ne "$loop"; do
9235*6236dae4SAndroid Build Coastguard Worker	    func_arith $current - $loop
9236*6236dae4SAndroid Build Coastguard Worker	    iface=$func_arith_result
9237*6236dae4SAndroid Build Coastguard Worker	    func_arith $loop - 1
9238*6236dae4SAndroid Build Coastguard Worker	    loop=$func_arith_result
9239*6236dae4SAndroid Build Coastguard Worker	    verstring=$verstring:$iface.0
9240*6236dae4SAndroid Build Coastguard Worker	  done
9241*6236dae4SAndroid Build Coastguard Worker
9242*6236dae4SAndroid Build Coastguard Worker	  # Make executables depend on our current version.
9243*6236dae4SAndroid Build Coastguard Worker	  func_append verstring ":$current.0"
9244*6236dae4SAndroid Build Coastguard Worker	  ;;
9245*6236dae4SAndroid Build Coastguard Worker
9246*6236dae4SAndroid Build Coastguard Worker	qnx)
9247*6236dae4SAndroid Build Coastguard Worker	  major=.$current
9248*6236dae4SAndroid Build Coastguard Worker	  versuffix=.$current
9249*6236dae4SAndroid Build Coastguard Worker	  ;;
9250*6236dae4SAndroid Build Coastguard Worker
9251*6236dae4SAndroid Build Coastguard Worker	sco)
9252*6236dae4SAndroid Build Coastguard Worker	  major=.$current
9253*6236dae4SAndroid Build Coastguard Worker	  versuffix=.$current
9254*6236dae4SAndroid Build Coastguard Worker	  ;;
9255*6236dae4SAndroid Build Coastguard Worker
9256*6236dae4SAndroid Build Coastguard Worker	sunos)
9257*6236dae4SAndroid Build Coastguard Worker	  major=.$current
9258*6236dae4SAndroid Build Coastguard Worker	  versuffix=.$current.$revision
9259*6236dae4SAndroid Build Coastguard Worker	  ;;
9260*6236dae4SAndroid Build Coastguard Worker
9261*6236dae4SAndroid Build Coastguard Worker	windows)
9262*6236dae4SAndroid Build Coastguard Worker	  # Use '-' rather than '.', since we only want one
9263*6236dae4SAndroid Build Coastguard Worker	  # extension on DOS 8.3 file systems.
9264*6236dae4SAndroid Build Coastguard Worker	  func_arith $current - $age
9265*6236dae4SAndroid Build Coastguard Worker	  major=$func_arith_result
9266*6236dae4SAndroid Build Coastguard Worker	  versuffix=-$major
9267*6236dae4SAndroid Build Coastguard Worker	  ;;
9268*6236dae4SAndroid Build Coastguard Worker
9269*6236dae4SAndroid Build Coastguard Worker	*)
9270*6236dae4SAndroid Build Coastguard Worker	  func_fatal_configuration "unknown library version type '$version_type'"
9271*6236dae4SAndroid Build Coastguard Worker	  ;;
9272*6236dae4SAndroid Build Coastguard Worker	esac
9273*6236dae4SAndroid Build Coastguard Worker
9274*6236dae4SAndroid Build Coastguard Worker	# Clear the version info if we defaulted, and they specified a release.
9275*6236dae4SAndroid Build Coastguard Worker	if test -z "$vinfo" && test -n "$release"; then
9276*6236dae4SAndroid Build Coastguard Worker	  major=
9277*6236dae4SAndroid Build Coastguard Worker	  case $version_type in
9278*6236dae4SAndroid Build Coastguard Worker	  darwin)
9279*6236dae4SAndroid Build Coastguard Worker	    # we can't check for "0.0" in archive_cmds due to quoting
9280*6236dae4SAndroid Build Coastguard Worker	    # problems, so we reset it completely
9281*6236dae4SAndroid Build Coastguard Worker	    verstring=
9282*6236dae4SAndroid Build Coastguard Worker	    ;;
9283*6236dae4SAndroid Build Coastguard Worker	  *)
9284*6236dae4SAndroid Build Coastguard Worker	    verstring=0.0
9285*6236dae4SAndroid Build Coastguard Worker	    ;;
9286*6236dae4SAndroid Build Coastguard Worker	  esac
9287*6236dae4SAndroid Build Coastguard Worker	  if test no = "$need_version"; then
9288*6236dae4SAndroid Build Coastguard Worker	    versuffix=
9289*6236dae4SAndroid Build Coastguard Worker	  else
9290*6236dae4SAndroid Build Coastguard Worker	    versuffix=.0.0
9291*6236dae4SAndroid Build Coastguard Worker	  fi
9292*6236dae4SAndroid Build Coastguard Worker	fi
9293*6236dae4SAndroid Build Coastguard Worker
9294*6236dae4SAndroid Build Coastguard Worker	# Remove version info from name if versioning should be avoided
9295*6236dae4SAndroid Build Coastguard Worker	if test yes,no = "$avoid_version,$need_version"; then
9296*6236dae4SAndroid Build Coastguard Worker	  major=
9297*6236dae4SAndroid Build Coastguard Worker	  versuffix=
9298*6236dae4SAndroid Build Coastguard Worker	  verstring=
9299*6236dae4SAndroid Build Coastguard Worker	fi
9300*6236dae4SAndroid Build Coastguard Worker
9301*6236dae4SAndroid Build Coastguard Worker	# Check to see if the archive will have undefined symbols.
9302*6236dae4SAndroid Build Coastguard Worker	if test yes = "$allow_undefined"; then
9303*6236dae4SAndroid Build Coastguard Worker	  if test unsupported = "$allow_undefined_flag"; then
9304*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$build_old_libs"; then
9305*6236dae4SAndroid Build Coastguard Worker	      func_warning "undefined symbols not allowed in $host shared libraries; building static only"
9306*6236dae4SAndroid Build Coastguard Worker	      build_libtool_libs=no
9307*6236dae4SAndroid Build Coastguard Worker	    else
9308*6236dae4SAndroid Build Coastguard Worker	      func_fatal_error "can't build $host shared library unless -no-undefined is specified"
9309*6236dae4SAndroid Build Coastguard Worker	    fi
9310*6236dae4SAndroid Build Coastguard Worker	  fi
9311*6236dae4SAndroid Build Coastguard Worker	else
9312*6236dae4SAndroid Build Coastguard Worker	  # Don't allow undefined symbols.
9313*6236dae4SAndroid Build Coastguard Worker	  allow_undefined_flag=$no_undefined_flag
9314*6236dae4SAndroid Build Coastguard Worker	fi
9315*6236dae4SAndroid Build Coastguard Worker
9316*6236dae4SAndroid Build Coastguard Worker      fi
9317*6236dae4SAndroid Build Coastguard Worker
9318*6236dae4SAndroid Build Coastguard Worker      func_generate_dlsyms "$libname" "$libname" :
9319*6236dae4SAndroid Build Coastguard Worker      func_append libobjs " $symfileobj"
9320*6236dae4SAndroid Build Coastguard Worker      test " " = "$libobjs" && libobjs=
9321*6236dae4SAndroid Build Coastguard Worker
9322*6236dae4SAndroid Build Coastguard Worker      if test relink != "$opt_mode"; then
9323*6236dae4SAndroid Build Coastguard Worker	# Remove our outputs, but don't remove object files since they
9324*6236dae4SAndroid Build Coastguard Worker	# may have been created when compiling PIC objects.
9325*6236dae4SAndroid Build Coastguard Worker	removelist=
9326*6236dae4SAndroid Build Coastguard Worker	tempremovelist=`$ECHO "$output_objdir/*"`
9327*6236dae4SAndroid Build Coastguard Worker	for p in $tempremovelist; do
9328*6236dae4SAndroid Build Coastguard Worker	  case $p in
9329*6236dae4SAndroid Build Coastguard Worker	    *.$objext | *.gcno)
9330*6236dae4SAndroid Build Coastguard Worker	       ;;
9331*6236dae4SAndroid Build Coastguard Worker	    $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*)
9332*6236dae4SAndroid Build Coastguard Worker	       if test -n "$precious_files_regex"; then
9333*6236dae4SAndroid Build Coastguard Worker		 if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1
9334*6236dae4SAndroid Build Coastguard Worker		 then
9335*6236dae4SAndroid Build Coastguard Worker		   continue
9336*6236dae4SAndroid Build Coastguard Worker		 fi
9337*6236dae4SAndroid Build Coastguard Worker	       fi
9338*6236dae4SAndroid Build Coastguard Worker	       func_append removelist " $p"
9339*6236dae4SAndroid Build Coastguard Worker	       ;;
9340*6236dae4SAndroid Build Coastguard Worker	    *) ;;
9341*6236dae4SAndroid Build Coastguard Worker	  esac
9342*6236dae4SAndroid Build Coastguard Worker	done
9343*6236dae4SAndroid Build Coastguard Worker	test -n "$removelist" && \
9344*6236dae4SAndroid Build Coastguard Worker	  func_show_eval "${RM}r \$removelist"
9345*6236dae4SAndroid Build Coastguard Worker      fi
9346*6236dae4SAndroid Build Coastguard Worker
9347*6236dae4SAndroid Build Coastguard Worker      # Now set the variables for building old libraries.
9348*6236dae4SAndroid Build Coastguard Worker      if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then
9349*6236dae4SAndroid Build Coastguard Worker	func_append oldlibs " $output_objdir/$libname.$libext"
9350*6236dae4SAndroid Build Coastguard Worker
9351*6236dae4SAndroid Build Coastguard Worker	# Transform .lo files to .o files.
9352*6236dae4SAndroid Build Coastguard Worker	oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP`
9353*6236dae4SAndroid Build Coastguard Worker      fi
9354*6236dae4SAndroid Build Coastguard Worker
9355*6236dae4SAndroid Build Coastguard Worker      # Eliminate all temporary directories.
9356*6236dae4SAndroid Build Coastguard Worker      #for path in $notinst_path; do
9357*6236dae4SAndroid Build Coastguard Worker      #	lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"`
9358*6236dae4SAndroid Build Coastguard Worker      #	deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"`
9359*6236dae4SAndroid Build Coastguard Worker      #	dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"`
9360*6236dae4SAndroid Build Coastguard Worker      #done
9361*6236dae4SAndroid Build Coastguard Worker
9362*6236dae4SAndroid Build Coastguard Worker      if test -n "$xrpath"; then
9363*6236dae4SAndroid Build Coastguard Worker	# If the user specified any rpath flags, then add them.
9364*6236dae4SAndroid Build Coastguard Worker	temp_xrpath=
9365*6236dae4SAndroid Build Coastguard Worker	for libdir in $xrpath; do
9366*6236dae4SAndroid Build Coastguard Worker	  func_replace_sysroot "$libdir"
9367*6236dae4SAndroid Build Coastguard Worker	  func_append temp_xrpath " -R$func_replace_sysroot_result"
9368*6236dae4SAndroid Build Coastguard Worker	  case "$finalize_rpath " in
9369*6236dae4SAndroid Build Coastguard Worker	  *" $libdir "*) ;;
9370*6236dae4SAndroid Build Coastguard Worker	  *) func_append finalize_rpath " $libdir" ;;
9371*6236dae4SAndroid Build Coastguard Worker	  esac
9372*6236dae4SAndroid Build Coastguard Worker	done
9373*6236dae4SAndroid Build Coastguard Worker	if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then
9374*6236dae4SAndroid Build Coastguard Worker	  dependency_libs="$temp_xrpath $dependency_libs"
9375*6236dae4SAndroid Build Coastguard Worker	fi
9376*6236dae4SAndroid Build Coastguard Worker      fi
9377*6236dae4SAndroid Build Coastguard Worker
9378*6236dae4SAndroid Build Coastguard Worker      # Make sure dlfiles contains only unique files that won't be dlpreopened
9379*6236dae4SAndroid Build Coastguard Worker      old_dlfiles=$dlfiles
9380*6236dae4SAndroid Build Coastguard Worker      dlfiles=
9381*6236dae4SAndroid Build Coastguard Worker      for lib in $old_dlfiles; do
9382*6236dae4SAndroid Build Coastguard Worker	case " $dlprefiles $dlfiles " in
9383*6236dae4SAndroid Build Coastguard Worker	*" $lib "*) ;;
9384*6236dae4SAndroid Build Coastguard Worker	*) func_append dlfiles " $lib" ;;
9385*6236dae4SAndroid Build Coastguard Worker	esac
9386*6236dae4SAndroid Build Coastguard Worker      done
9387*6236dae4SAndroid Build Coastguard Worker
9388*6236dae4SAndroid Build Coastguard Worker      # Make sure dlprefiles contains only unique files
9389*6236dae4SAndroid Build Coastguard Worker      old_dlprefiles=$dlprefiles
9390*6236dae4SAndroid Build Coastguard Worker      dlprefiles=
9391*6236dae4SAndroid Build Coastguard Worker      for lib in $old_dlprefiles; do
9392*6236dae4SAndroid Build Coastguard Worker	case "$dlprefiles " in
9393*6236dae4SAndroid Build Coastguard Worker	*" $lib "*) ;;
9394*6236dae4SAndroid Build Coastguard Worker	*) func_append dlprefiles " $lib" ;;
9395*6236dae4SAndroid Build Coastguard Worker	esac
9396*6236dae4SAndroid Build Coastguard Worker      done
9397*6236dae4SAndroid Build Coastguard Worker
9398*6236dae4SAndroid Build Coastguard Worker      if test yes = "$build_libtool_libs"; then
9399*6236dae4SAndroid Build Coastguard Worker	if test -n "$rpath"; then
9400*6236dae4SAndroid Build Coastguard Worker	  case $host in
9401*6236dae4SAndroid Build Coastguard Worker	  *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*)
9402*6236dae4SAndroid Build Coastguard Worker	    # these systems don't actually have a c library (as such)!
9403*6236dae4SAndroid Build Coastguard Worker	    ;;
9404*6236dae4SAndroid Build Coastguard Worker	  *-*-rhapsody* | *-*-darwin1.[012])
9405*6236dae4SAndroid Build Coastguard Worker	    # Rhapsody C library is in the System framework
9406*6236dae4SAndroid Build Coastguard Worker	    func_append deplibs " System.ltframework"
9407*6236dae4SAndroid Build Coastguard Worker	    ;;
9408*6236dae4SAndroid Build Coastguard Worker	  *-*-netbsd*)
9409*6236dae4SAndroid Build Coastguard Worker	    # Don't link with libc until the a.out ld.so is fixed.
9410*6236dae4SAndroid Build Coastguard Worker	    ;;
9411*6236dae4SAndroid Build Coastguard Worker	  *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-midnightbsd*)
9412*6236dae4SAndroid Build Coastguard Worker	    # Do not include libc due to us having libc/libc_r.
9413*6236dae4SAndroid Build Coastguard Worker	    ;;
9414*6236dae4SAndroid Build Coastguard Worker	  *-*-sco3.2v5* | *-*-sco5v6*)
9415*6236dae4SAndroid Build Coastguard Worker	    # Causes problems with __ctype
9416*6236dae4SAndroid Build Coastguard Worker	    ;;
9417*6236dae4SAndroid Build Coastguard Worker	  *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*)
9418*6236dae4SAndroid Build Coastguard Worker	    # Compiler inserts libc in the correct place for threads to work
9419*6236dae4SAndroid Build Coastguard Worker	    ;;
9420*6236dae4SAndroid Build Coastguard Worker	  *)
9421*6236dae4SAndroid Build Coastguard Worker	    # Add libc to deplibs on all other systems if necessary.
9422*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$build_libtool_need_lc"; then
9423*6236dae4SAndroid Build Coastguard Worker	      func_append deplibs " -lc"
9424*6236dae4SAndroid Build Coastguard Worker	    fi
9425*6236dae4SAndroid Build Coastguard Worker	    ;;
9426*6236dae4SAndroid Build Coastguard Worker	  esac
9427*6236dae4SAndroid Build Coastguard Worker	fi
9428*6236dae4SAndroid Build Coastguard Worker
9429*6236dae4SAndroid Build Coastguard Worker	# Transform deplibs into only deplibs that can be linked in shared.
9430*6236dae4SAndroid Build Coastguard Worker	name_save=$name
9431*6236dae4SAndroid Build Coastguard Worker	libname_save=$libname
9432*6236dae4SAndroid Build Coastguard Worker	release_save=$release
9433*6236dae4SAndroid Build Coastguard Worker	versuffix_save=$versuffix
9434*6236dae4SAndroid Build Coastguard Worker	major_save=$major
9435*6236dae4SAndroid Build Coastguard Worker	# I'm not sure if I'm treating the release correctly.  I think
9436*6236dae4SAndroid Build Coastguard Worker	# release should show up in the -l (ie -lgmp5) so we don't want to
9437*6236dae4SAndroid Build Coastguard Worker	# add it in twice.  Is that correct?
9438*6236dae4SAndroid Build Coastguard Worker	release=
9439*6236dae4SAndroid Build Coastguard Worker	versuffix=
9440*6236dae4SAndroid Build Coastguard Worker	major=
9441*6236dae4SAndroid Build Coastguard Worker	newdeplibs=
9442*6236dae4SAndroid Build Coastguard Worker	droppeddeps=no
9443*6236dae4SAndroid Build Coastguard Worker	case $deplibs_check_method in
9444*6236dae4SAndroid Build Coastguard Worker	pass_all)
9445*6236dae4SAndroid Build Coastguard Worker	  # Don't check for shared/static.  Everything works.
9446*6236dae4SAndroid Build Coastguard Worker	  # This might be a little naive.  We might want to check
9447*6236dae4SAndroid Build Coastguard Worker	  # whether the library exists or not.  But this is on
9448*6236dae4SAndroid Build Coastguard Worker	  # osf3 & osf4 and I'm not really sure... Just
9449*6236dae4SAndroid Build Coastguard Worker	  # implementing what was already the behavior.
9450*6236dae4SAndroid Build Coastguard Worker	  newdeplibs=$deplibs
9451*6236dae4SAndroid Build Coastguard Worker	  ;;
9452*6236dae4SAndroid Build Coastguard Worker	test_compile)
9453*6236dae4SAndroid Build Coastguard Worker	  # This code stresses the "libraries are programs" paradigm to its
9454*6236dae4SAndroid Build Coastguard Worker	  # limits. Maybe even breaks it.  We compile a program, linking it
9455*6236dae4SAndroid Build Coastguard Worker	  # against the deplibs as a proxy for the library.  Then we can check
9456*6236dae4SAndroid Build Coastguard Worker	  # whether they linked in statically or dynamically with ldd.
9457*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || $RM conftest.c
9458*6236dae4SAndroid Build Coastguard Worker	  cat > conftest.c <<EOF
9459*6236dae4SAndroid Build Coastguard Worker	  int main() { return 0; }
9460*6236dae4SAndroid Build Coastguard WorkerEOF
9461*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || $RM conftest
9462*6236dae4SAndroid Build Coastguard Worker	  if $LTCC $LTCFLAGS -o conftest conftest.c $deplibs; then
9463*6236dae4SAndroid Build Coastguard Worker	    ldd_output=`ldd conftest`
9464*6236dae4SAndroid Build Coastguard Worker	    for i in $deplibs; do
9465*6236dae4SAndroid Build Coastguard Worker	      case $i in
9466*6236dae4SAndroid Build Coastguard Worker	      -l*)
9467*6236dae4SAndroid Build Coastguard Worker		func_stripname -l '' "$i"
9468*6236dae4SAndroid Build Coastguard Worker		name=$func_stripname_result
9469*6236dae4SAndroid Build Coastguard Worker		if test yes = "$allow_libtool_libs_with_static_runtimes"; then
9470*6236dae4SAndroid Build Coastguard Worker		  case " $predeps $postdeps " in
9471*6236dae4SAndroid Build Coastguard Worker		  *" $i "*)
9472*6236dae4SAndroid Build Coastguard Worker		    func_append newdeplibs " $i"
9473*6236dae4SAndroid Build Coastguard Worker		    i=
9474*6236dae4SAndroid Build Coastguard Worker		    ;;
9475*6236dae4SAndroid Build Coastguard Worker		  esac
9476*6236dae4SAndroid Build Coastguard Worker		fi
9477*6236dae4SAndroid Build Coastguard Worker		if test -n "$i"; then
9478*6236dae4SAndroid Build Coastguard Worker		  libname=`eval "\\$ECHO \"$libname_spec\""`
9479*6236dae4SAndroid Build Coastguard Worker		  deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
9480*6236dae4SAndroid Build Coastguard Worker		  set dummy $deplib_matches; shift
9481*6236dae4SAndroid Build Coastguard Worker		  deplib_match=$1
9482*6236dae4SAndroid Build Coastguard Worker		  if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0; then
9483*6236dae4SAndroid Build Coastguard Worker		    func_append newdeplibs " $i"
9484*6236dae4SAndroid Build Coastguard Worker		  else
9485*6236dae4SAndroid Build Coastguard Worker		    droppeddeps=yes
9486*6236dae4SAndroid Build Coastguard Worker		    echo
9487*6236dae4SAndroid Build Coastguard Worker		    $ECHO "*** Warning: dynamic linker does not accept needed library $i."
9488*6236dae4SAndroid Build Coastguard Worker		    echo "*** I have the capability to make that library automatically link in when"
9489*6236dae4SAndroid Build Coastguard Worker		    echo "*** you link to this library.  But I can only do this if you have a"
9490*6236dae4SAndroid Build Coastguard Worker		    echo "*** shared version of the library, which I believe you do not have"
9491*6236dae4SAndroid Build Coastguard Worker		    echo "*** because a test_compile did reveal that the linker did not use it for"
9492*6236dae4SAndroid Build Coastguard Worker		    echo "*** its dynamic dependency list that programs get resolved with at runtime."
9493*6236dae4SAndroid Build Coastguard Worker		  fi
9494*6236dae4SAndroid Build Coastguard Worker		fi
9495*6236dae4SAndroid Build Coastguard Worker		;;
9496*6236dae4SAndroid Build Coastguard Worker	      *)
9497*6236dae4SAndroid Build Coastguard Worker		func_append newdeplibs " $i"
9498*6236dae4SAndroid Build Coastguard Worker		;;
9499*6236dae4SAndroid Build Coastguard Worker	      esac
9500*6236dae4SAndroid Build Coastguard Worker	    done
9501*6236dae4SAndroid Build Coastguard Worker	  else
9502*6236dae4SAndroid Build Coastguard Worker	    # Error occurred in the first compile.  Let's try to salvage
9503*6236dae4SAndroid Build Coastguard Worker	    # the situation: Compile a separate program for each library.
9504*6236dae4SAndroid Build Coastguard Worker	    for i in $deplibs; do
9505*6236dae4SAndroid Build Coastguard Worker	      case $i in
9506*6236dae4SAndroid Build Coastguard Worker	      -l*)
9507*6236dae4SAndroid Build Coastguard Worker		func_stripname -l '' "$i"
9508*6236dae4SAndroid Build Coastguard Worker		name=$func_stripname_result
9509*6236dae4SAndroid Build Coastguard Worker		$opt_dry_run || $RM conftest
9510*6236dae4SAndroid Build Coastguard Worker		if $LTCC $LTCFLAGS -o conftest conftest.c $i; then
9511*6236dae4SAndroid Build Coastguard Worker		  ldd_output=`ldd conftest`
9512*6236dae4SAndroid Build Coastguard Worker		  if test yes = "$allow_libtool_libs_with_static_runtimes"; then
9513*6236dae4SAndroid Build Coastguard Worker		    case " $predeps $postdeps " in
9514*6236dae4SAndroid Build Coastguard Worker		    *" $i "*)
9515*6236dae4SAndroid Build Coastguard Worker		      func_append newdeplibs " $i"
9516*6236dae4SAndroid Build Coastguard Worker		      i=
9517*6236dae4SAndroid Build Coastguard Worker		      ;;
9518*6236dae4SAndroid Build Coastguard Worker		    esac
9519*6236dae4SAndroid Build Coastguard Worker		  fi
9520*6236dae4SAndroid Build Coastguard Worker		  if test -n "$i"; then
9521*6236dae4SAndroid Build Coastguard Worker		    libname=`eval "\\$ECHO \"$libname_spec\""`
9522*6236dae4SAndroid Build Coastguard Worker		    deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
9523*6236dae4SAndroid Build Coastguard Worker		    set dummy $deplib_matches; shift
9524*6236dae4SAndroid Build Coastguard Worker		    deplib_match=$1
9525*6236dae4SAndroid Build Coastguard Worker		    if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0; then
9526*6236dae4SAndroid Build Coastguard Worker		      func_append newdeplibs " $i"
9527*6236dae4SAndroid Build Coastguard Worker		    else
9528*6236dae4SAndroid Build Coastguard Worker		      droppeddeps=yes
9529*6236dae4SAndroid Build Coastguard Worker		      echo
9530*6236dae4SAndroid Build Coastguard Worker		      $ECHO "*** Warning: dynamic linker does not accept needed library $i."
9531*6236dae4SAndroid Build Coastguard Worker		      echo "*** I have the capability to make that library automatically link in when"
9532*6236dae4SAndroid Build Coastguard Worker		      echo "*** you link to this library.  But I can only do this if you have a"
9533*6236dae4SAndroid Build Coastguard Worker		      echo "*** shared version of the library, which you do not appear to have"
9534*6236dae4SAndroid Build Coastguard Worker		      echo "*** because a test_compile did reveal that the linker did not use this one"
9535*6236dae4SAndroid Build Coastguard Worker		      echo "*** as a dynamic dependency that programs can get resolved with at runtime."
9536*6236dae4SAndroid Build Coastguard Worker		    fi
9537*6236dae4SAndroid Build Coastguard Worker		  fi
9538*6236dae4SAndroid Build Coastguard Worker		else
9539*6236dae4SAndroid Build Coastguard Worker		  droppeddeps=yes
9540*6236dae4SAndroid Build Coastguard Worker		  echo
9541*6236dae4SAndroid Build Coastguard Worker		  $ECHO "*** Warning!  Library $i is needed by this library but I was not able to"
9542*6236dae4SAndroid Build Coastguard Worker		  echo "*** make it link in!  You will probably need to install it or some"
9543*6236dae4SAndroid Build Coastguard Worker		  echo "*** library that it depends on before this library will be fully"
9544*6236dae4SAndroid Build Coastguard Worker		  echo "*** functional.  Installing it before continuing would be even better."
9545*6236dae4SAndroid Build Coastguard Worker		fi
9546*6236dae4SAndroid Build Coastguard Worker		;;
9547*6236dae4SAndroid Build Coastguard Worker	      *)
9548*6236dae4SAndroid Build Coastguard Worker		func_append newdeplibs " $i"
9549*6236dae4SAndroid Build Coastguard Worker		;;
9550*6236dae4SAndroid Build Coastguard Worker	      esac
9551*6236dae4SAndroid Build Coastguard Worker	    done
9552*6236dae4SAndroid Build Coastguard Worker	  fi
9553*6236dae4SAndroid Build Coastguard Worker	  ;;
9554*6236dae4SAndroid Build Coastguard Worker	file_magic*)
9555*6236dae4SAndroid Build Coastguard Worker	  set dummy $deplibs_check_method; shift
9556*6236dae4SAndroid Build Coastguard Worker	  file_magic_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
9557*6236dae4SAndroid Build Coastguard Worker	  for a_deplib in $deplibs; do
9558*6236dae4SAndroid Build Coastguard Worker	    case $a_deplib in
9559*6236dae4SAndroid Build Coastguard Worker	    -l*)
9560*6236dae4SAndroid Build Coastguard Worker	      func_stripname -l '' "$a_deplib"
9561*6236dae4SAndroid Build Coastguard Worker	      name=$func_stripname_result
9562*6236dae4SAndroid Build Coastguard Worker	      if test yes = "$allow_libtool_libs_with_static_runtimes"; then
9563*6236dae4SAndroid Build Coastguard Worker		case " $predeps $postdeps " in
9564*6236dae4SAndroid Build Coastguard Worker		*" $a_deplib "*)
9565*6236dae4SAndroid Build Coastguard Worker		  func_append newdeplibs " $a_deplib"
9566*6236dae4SAndroid Build Coastguard Worker		  a_deplib=
9567*6236dae4SAndroid Build Coastguard Worker		  ;;
9568*6236dae4SAndroid Build Coastguard Worker		esac
9569*6236dae4SAndroid Build Coastguard Worker	      fi
9570*6236dae4SAndroid Build Coastguard Worker	      if test -n "$a_deplib"; then
9571*6236dae4SAndroid Build Coastguard Worker		libname=`eval "\\$ECHO \"$libname_spec\""`
9572*6236dae4SAndroid Build Coastguard Worker		if test -n "$file_magic_glob"; then
9573*6236dae4SAndroid Build Coastguard Worker		  libnameglob=`func_echo_all "$libname" | $SED -e $file_magic_glob`
9574*6236dae4SAndroid Build Coastguard Worker		else
9575*6236dae4SAndroid Build Coastguard Worker		  libnameglob=$libname
9576*6236dae4SAndroid Build Coastguard Worker		fi
9577*6236dae4SAndroid Build Coastguard Worker		test yes = "$want_nocaseglob" && nocaseglob=`shopt -p nocaseglob`
9578*6236dae4SAndroid Build Coastguard Worker		for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
9579*6236dae4SAndroid Build Coastguard Worker		  if test yes = "$want_nocaseglob"; then
9580*6236dae4SAndroid Build Coastguard Worker		    shopt -s nocaseglob
9581*6236dae4SAndroid Build Coastguard Worker		    potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null`
9582*6236dae4SAndroid Build Coastguard Worker		    $nocaseglob
9583*6236dae4SAndroid Build Coastguard Worker		  else
9584*6236dae4SAndroid Build Coastguard Worker		    potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null`
9585*6236dae4SAndroid Build Coastguard Worker		  fi
9586*6236dae4SAndroid Build Coastguard Worker		  for potent_lib in $potential_libs; do
9587*6236dae4SAndroid Build Coastguard Worker		      # Follow soft links.
9588*6236dae4SAndroid Build Coastguard Worker		      if ls -lLd "$potent_lib" 2>/dev/null |
9589*6236dae4SAndroid Build Coastguard Worker			 $GREP " -> " >/dev/null; then
9590*6236dae4SAndroid Build Coastguard Worker			continue
9591*6236dae4SAndroid Build Coastguard Worker		      fi
9592*6236dae4SAndroid Build Coastguard Worker		      # The statement above tries to avoid entering an
9593*6236dae4SAndroid Build Coastguard Worker		      # endless loop below, in case of cyclic links.
9594*6236dae4SAndroid Build Coastguard Worker		      # We might still enter an endless loop, since a link
9595*6236dae4SAndroid Build Coastguard Worker		      # loop can be closed while we follow links,
9596*6236dae4SAndroid Build Coastguard Worker		      # but so what?
9597*6236dae4SAndroid Build Coastguard Worker		      potlib=$potent_lib
9598*6236dae4SAndroid Build Coastguard Worker		      while test -h "$potlib" 2>/dev/null; do
9599*6236dae4SAndroid Build Coastguard Worker			potliblink=`ls -ld $potlib | $SED 's/.* -> //'`
9600*6236dae4SAndroid Build Coastguard Worker			case $potliblink in
9601*6236dae4SAndroid Build Coastguard Worker			[\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;;
9602*6236dae4SAndroid Build Coastguard Worker			*) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";;
9603*6236dae4SAndroid Build Coastguard Worker			esac
9604*6236dae4SAndroid Build Coastguard Worker		      done
9605*6236dae4SAndroid Build Coastguard Worker		      if eval $file_magic_cmd \"\$potlib\" 2>/dev/null |
9606*6236dae4SAndroid Build Coastguard Worker			 $SED -e 10q |
9607*6236dae4SAndroid Build Coastguard Worker			 $EGREP "$file_magic_regex" > /dev/null; then
9608*6236dae4SAndroid Build Coastguard Worker			func_append newdeplibs " $a_deplib"
9609*6236dae4SAndroid Build Coastguard Worker			a_deplib=
9610*6236dae4SAndroid Build Coastguard Worker			break 2
9611*6236dae4SAndroid Build Coastguard Worker		      fi
9612*6236dae4SAndroid Build Coastguard Worker		  done
9613*6236dae4SAndroid Build Coastguard Worker		done
9614*6236dae4SAndroid Build Coastguard Worker	      fi
9615*6236dae4SAndroid Build Coastguard Worker	      if test -n "$a_deplib"; then
9616*6236dae4SAndroid Build Coastguard Worker		droppeddeps=yes
9617*6236dae4SAndroid Build Coastguard Worker		echo
9618*6236dae4SAndroid Build Coastguard Worker		$ECHO "*** Warning: linker path does not have real file for library $a_deplib."
9619*6236dae4SAndroid Build Coastguard Worker		echo "*** I have the capability to make that library automatically link in when"
9620*6236dae4SAndroid Build Coastguard Worker		echo "*** you link to this library.  But I can only do this if you have a"
9621*6236dae4SAndroid Build Coastguard Worker		echo "*** shared version of the library, which you do not appear to have"
9622*6236dae4SAndroid Build Coastguard Worker		echo "*** because I did check the linker path looking for a file starting"
9623*6236dae4SAndroid Build Coastguard Worker		if test -z "$potlib"; then
9624*6236dae4SAndroid Build Coastguard Worker		  $ECHO "*** with $libname but no candidates were found. (...for file magic test)"
9625*6236dae4SAndroid Build Coastguard Worker		else
9626*6236dae4SAndroid Build Coastguard Worker		  $ECHO "*** with $libname and none of the candidates passed a file format test"
9627*6236dae4SAndroid Build Coastguard Worker		  $ECHO "*** using a file magic. Last file checked: $potlib"
9628*6236dae4SAndroid Build Coastguard Worker		fi
9629*6236dae4SAndroid Build Coastguard Worker	      fi
9630*6236dae4SAndroid Build Coastguard Worker	      ;;
9631*6236dae4SAndroid Build Coastguard Worker	    *)
9632*6236dae4SAndroid Build Coastguard Worker	      # Add a -L argument.
9633*6236dae4SAndroid Build Coastguard Worker	      func_append newdeplibs " $a_deplib"
9634*6236dae4SAndroid Build Coastguard Worker	      ;;
9635*6236dae4SAndroid Build Coastguard Worker	    esac
9636*6236dae4SAndroid Build Coastguard Worker	  done # Gone through all deplibs.
9637*6236dae4SAndroid Build Coastguard Worker	  ;;
9638*6236dae4SAndroid Build Coastguard Worker	match_pattern*)
9639*6236dae4SAndroid Build Coastguard Worker	  set dummy $deplibs_check_method; shift
9640*6236dae4SAndroid Build Coastguard Worker	  match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
9641*6236dae4SAndroid Build Coastguard Worker	  for a_deplib in $deplibs; do
9642*6236dae4SAndroid Build Coastguard Worker	    case $a_deplib in
9643*6236dae4SAndroid Build Coastguard Worker	    -l*)
9644*6236dae4SAndroid Build Coastguard Worker	      func_stripname -l '' "$a_deplib"
9645*6236dae4SAndroid Build Coastguard Worker	      name=$func_stripname_result
9646*6236dae4SAndroid Build Coastguard Worker	      if test yes = "$allow_libtool_libs_with_static_runtimes"; then
9647*6236dae4SAndroid Build Coastguard Worker		case " $predeps $postdeps " in
9648*6236dae4SAndroid Build Coastguard Worker		*" $a_deplib "*)
9649*6236dae4SAndroid Build Coastguard Worker		  func_append newdeplibs " $a_deplib"
9650*6236dae4SAndroid Build Coastguard Worker		  a_deplib=
9651*6236dae4SAndroid Build Coastguard Worker		  ;;
9652*6236dae4SAndroid Build Coastguard Worker		esac
9653*6236dae4SAndroid Build Coastguard Worker	      fi
9654*6236dae4SAndroid Build Coastguard Worker	      if test -n "$a_deplib"; then
9655*6236dae4SAndroid Build Coastguard Worker		libname=`eval "\\$ECHO \"$libname_spec\""`
9656*6236dae4SAndroid Build Coastguard Worker		for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
9657*6236dae4SAndroid Build Coastguard Worker		  potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
9658*6236dae4SAndroid Build Coastguard Worker		  for potent_lib in $potential_libs; do
9659*6236dae4SAndroid Build Coastguard Worker		    potlib=$potent_lib # see symlink-check above in file_magic test
9660*6236dae4SAndroid Build Coastguard Worker		    if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \
9661*6236dae4SAndroid Build Coastguard Worker		       $EGREP "$match_pattern_regex" > /dev/null; then
9662*6236dae4SAndroid Build Coastguard Worker		      func_append newdeplibs " $a_deplib"
9663*6236dae4SAndroid Build Coastguard Worker		      a_deplib=
9664*6236dae4SAndroid Build Coastguard Worker		      break 2
9665*6236dae4SAndroid Build Coastguard Worker		    fi
9666*6236dae4SAndroid Build Coastguard Worker		  done
9667*6236dae4SAndroid Build Coastguard Worker		done
9668*6236dae4SAndroid Build Coastguard Worker	      fi
9669*6236dae4SAndroid Build Coastguard Worker	      if test -n "$a_deplib"; then
9670*6236dae4SAndroid Build Coastguard Worker		droppeddeps=yes
9671*6236dae4SAndroid Build Coastguard Worker		echo
9672*6236dae4SAndroid Build Coastguard Worker		$ECHO "*** Warning: linker path does not have real file for library $a_deplib."
9673*6236dae4SAndroid Build Coastguard Worker		echo "*** I have the capability to make that library automatically link in when"
9674*6236dae4SAndroid Build Coastguard Worker		echo "*** you link to this library.  But I can only do this if you have a"
9675*6236dae4SAndroid Build Coastguard Worker		echo "*** shared version of the library, which you do not appear to have"
9676*6236dae4SAndroid Build Coastguard Worker		echo "*** because I did check the linker path looking for a file starting"
9677*6236dae4SAndroid Build Coastguard Worker		if test -z "$potlib"; then
9678*6236dae4SAndroid Build Coastguard Worker		  $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)"
9679*6236dae4SAndroid Build Coastguard Worker		else
9680*6236dae4SAndroid Build Coastguard Worker		  $ECHO "*** with $libname and none of the candidates passed a file format test"
9681*6236dae4SAndroid Build Coastguard Worker		  $ECHO "*** using a regex pattern. Last file checked: $potlib"
9682*6236dae4SAndroid Build Coastguard Worker		fi
9683*6236dae4SAndroid Build Coastguard Worker	      fi
9684*6236dae4SAndroid Build Coastguard Worker	      ;;
9685*6236dae4SAndroid Build Coastguard Worker	    *)
9686*6236dae4SAndroid Build Coastguard Worker	      # Add a -L argument.
9687*6236dae4SAndroid Build Coastguard Worker	      func_append newdeplibs " $a_deplib"
9688*6236dae4SAndroid Build Coastguard Worker	      ;;
9689*6236dae4SAndroid Build Coastguard Worker	    esac
9690*6236dae4SAndroid Build Coastguard Worker	  done # Gone through all deplibs.
9691*6236dae4SAndroid Build Coastguard Worker	  ;;
9692*6236dae4SAndroid Build Coastguard Worker	none | unknown | *)
9693*6236dae4SAndroid Build Coastguard Worker	  newdeplibs=
9694*6236dae4SAndroid Build Coastguard Worker	  tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'`
9695*6236dae4SAndroid Build Coastguard Worker	  if test yes = "$allow_libtool_libs_with_static_runtimes"; then
9696*6236dae4SAndroid Build Coastguard Worker	    for i in $predeps $postdeps; do
9697*6236dae4SAndroid Build Coastguard Worker	      # can't use Xsed below, because $i might contain '/'
9698*6236dae4SAndroid Build Coastguard Worker	      tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"`
9699*6236dae4SAndroid Build Coastguard Worker	    done
9700*6236dae4SAndroid Build Coastguard Worker	  fi
9701*6236dae4SAndroid Build Coastguard Worker	  case $tmp_deplibs in
9702*6236dae4SAndroid Build Coastguard Worker	  *[!\	\ ]*)
9703*6236dae4SAndroid Build Coastguard Worker	    echo
9704*6236dae4SAndroid Build Coastguard Worker	    if test none = "$deplibs_check_method"; then
9705*6236dae4SAndroid Build Coastguard Worker	      echo "*** Warning: inter-library dependencies are not supported in this platform."
9706*6236dae4SAndroid Build Coastguard Worker	    else
9707*6236dae4SAndroid Build Coastguard Worker	      echo "*** Warning: inter-library dependencies are not known to be supported."
9708*6236dae4SAndroid Build Coastguard Worker	    fi
9709*6236dae4SAndroid Build Coastguard Worker	    echo "*** All declared inter-library dependencies are being dropped."
9710*6236dae4SAndroid Build Coastguard Worker	    droppeddeps=yes
9711*6236dae4SAndroid Build Coastguard Worker	    ;;
9712*6236dae4SAndroid Build Coastguard Worker	  esac
9713*6236dae4SAndroid Build Coastguard Worker	  ;;
9714*6236dae4SAndroid Build Coastguard Worker	esac
9715*6236dae4SAndroid Build Coastguard Worker	versuffix=$versuffix_save
9716*6236dae4SAndroid Build Coastguard Worker	major=$major_save
9717*6236dae4SAndroid Build Coastguard Worker	release=$release_save
9718*6236dae4SAndroid Build Coastguard Worker	libname=$libname_save
9719*6236dae4SAndroid Build Coastguard Worker	name=$name_save
9720*6236dae4SAndroid Build Coastguard Worker
9721*6236dae4SAndroid Build Coastguard Worker	case $host in
9722*6236dae4SAndroid Build Coastguard Worker	*-*-rhapsody* | *-*-darwin1.[012])
9723*6236dae4SAndroid Build Coastguard Worker	  # On Rhapsody replace the C library with the System framework
9724*6236dae4SAndroid Build Coastguard Worker	  newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'`
9725*6236dae4SAndroid Build Coastguard Worker	  ;;
9726*6236dae4SAndroid Build Coastguard Worker	esac
9727*6236dae4SAndroid Build Coastguard Worker
9728*6236dae4SAndroid Build Coastguard Worker	if test yes = "$droppeddeps"; then
9729*6236dae4SAndroid Build Coastguard Worker	  if test yes = "$module"; then
9730*6236dae4SAndroid Build Coastguard Worker	    echo
9731*6236dae4SAndroid Build Coastguard Worker	    echo "*** Warning: libtool could not satisfy all declared inter-library"
9732*6236dae4SAndroid Build Coastguard Worker	    $ECHO "*** dependencies of module $libname.  Therefore, libtool will create"
9733*6236dae4SAndroid Build Coastguard Worker	    echo "*** a static module, that should work as long as the dlopening"
9734*6236dae4SAndroid Build Coastguard Worker	    echo "*** application is linked with the -dlopen flag."
9735*6236dae4SAndroid Build Coastguard Worker	    if test -z "$global_symbol_pipe"; then
9736*6236dae4SAndroid Build Coastguard Worker	      echo
9737*6236dae4SAndroid Build Coastguard Worker	      echo "*** However, this would only work if libtool was able to extract symbol"
9738*6236dae4SAndroid Build Coastguard Worker	      echo "*** lists from a program, using 'nm' or equivalent, but libtool could"
9739*6236dae4SAndroid Build Coastguard Worker	      echo "*** not find such a program.  So, this module is probably useless."
9740*6236dae4SAndroid Build Coastguard Worker	      echo "*** 'nm' from GNU binutils and a full rebuild may help."
9741*6236dae4SAndroid Build Coastguard Worker	    fi
9742*6236dae4SAndroid Build Coastguard Worker	    if test no = "$build_old_libs"; then
9743*6236dae4SAndroid Build Coastguard Worker	      oldlibs=$output_objdir/$libname.$libext
9744*6236dae4SAndroid Build Coastguard Worker	      build_libtool_libs=module
9745*6236dae4SAndroid Build Coastguard Worker	      build_old_libs=yes
9746*6236dae4SAndroid Build Coastguard Worker	    else
9747*6236dae4SAndroid Build Coastguard Worker	      build_libtool_libs=no
9748*6236dae4SAndroid Build Coastguard Worker	    fi
9749*6236dae4SAndroid Build Coastguard Worker	  else
9750*6236dae4SAndroid Build Coastguard Worker	    echo "*** The inter-library dependencies that have been dropped here will be"
9751*6236dae4SAndroid Build Coastguard Worker	    echo "*** automatically added whenever a program is linked with this library"
9752*6236dae4SAndroid Build Coastguard Worker	    echo "*** or is declared to -dlopen it."
9753*6236dae4SAndroid Build Coastguard Worker
9754*6236dae4SAndroid Build Coastguard Worker	    if test no = "$allow_undefined"; then
9755*6236dae4SAndroid Build Coastguard Worker	      echo
9756*6236dae4SAndroid Build Coastguard Worker	      echo "*** Since this library must not contain undefined symbols,"
9757*6236dae4SAndroid Build Coastguard Worker	      echo "*** because either the platform does not support them or"
9758*6236dae4SAndroid Build Coastguard Worker	      echo "*** it was explicitly requested with -no-undefined,"
9759*6236dae4SAndroid Build Coastguard Worker	      echo "*** libtool will only create a static version of it."
9760*6236dae4SAndroid Build Coastguard Worker	      if test no = "$build_old_libs"; then
9761*6236dae4SAndroid Build Coastguard Worker		oldlibs=$output_objdir/$libname.$libext
9762*6236dae4SAndroid Build Coastguard Worker		build_libtool_libs=module
9763*6236dae4SAndroid Build Coastguard Worker		build_old_libs=yes
9764*6236dae4SAndroid Build Coastguard Worker	      else
9765*6236dae4SAndroid Build Coastguard Worker		build_libtool_libs=no
9766*6236dae4SAndroid Build Coastguard Worker	      fi
9767*6236dae4SAndroid Build Coastguard Worker	    fi
9768*6236dae4SAndroid Build Coastguard Worker	  fi
9769*6236dae4SAndroid Build Coastguard Worker	fi
9770*6236dae4SAndroid Build Coastguard Worker	# Done checking deplibs!
9771*6236dae4SAndroid Build Coastguard Worker	deplibs=$newdeplibs
9772*6236dae4SAndroid Build Coastguard Worker      fi
9773*6236dae4SAndroid Build Coastguard Worker      # Time to change all our "foo.ltframework" stuff back to "-framework foo"
9774*6236dae4SAndroid Build Coastguard Worker      case $host in
9775*6236dae4SAndroid Build Coastguard Worker	*-*-darwin*)
9776*6236dae4SAndroid Build Coastguard Worker	  newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
9777*6236dae4SAndroid Build Coastguard Worker	  new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
9778*6236dae4SAndroid Build Coastguard Worker	  deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
9779*6236dae4SAndroid Build Coastguard Worker	  ;;
9780*6236dae4SAndroid Build Coastguard Worker      esac
9781*6236dae4SAndroid Build Coastguard Worker
9782*6236dae4SAndroid Build Coastguard Worker      # move library search paths that coincide with paths to not yet
9783*6236dae4SAndroid Build Coastguard Worker      # installed libraries to the beginning of the library search list
9784*6236dae4SAndroid Build Coastguard Worker      new_libs=
9785*6236dae4SAndroid Build Coastguard Worker      for path in $notinst_path; do
9786*6236dae4SAndroid Build Coastguard Worker	case " $new_libs " in
9787*6236dae4SAndroid Build Coastguard Worker	*" -L$path/$objdir "*) ;;
9788*6236dae4SAndroid Build Coastguard Worker	*)
9789*6236dae4SAndroid Build Coastguard Worker	  case " $deplibs " in
9790*6236dae4SAndroid Build Coastguard Worker	  *" -L$path/$objdir "*)
9791*6236dae4SAndroid Build Coastguard Worker	    func_append new_libs " -L$path/$objdir" ;;
9792*6236dae4SAndroid Build Coastguard Worker	  esac
9793*6236dae4SAndroid Build Coastguard Worker	  ;;
9794*6236dae4SAndroid Build Coastguard Worker	esac
9795*6236dae4SAndroid Build Coastguard Worker      done
9796*6236dae4SAndroid Build Coastguard Worker      for deplib in $deplibs; do
9797*6236dae4SAndroid Build Coastguard Worker	case $deplib in
9798*6236dae4SAndroid Build Coastguard Worker	-L*)
9799*6236dae4SAndroid Build Coastguard Worker	  case " $new_libs " in
9800*6236dae4SAndroid Build Coastguard Worker	  *" $deplib "*) ;;
9801*6236dae4SAndroid Build Coastguard Worker	  *) func_append new_libs " $deplib" ;;
9802*6236dae4SAndroid Build Coastguard Worker	  esac
9803*6236dae4SAndroid Build Coastguard Worker	  ;;
9804*6236dae4SAndroid Build Coastguard Worker	*) func_append new_libs " $deplib" ;;
9805*6236dae4SAndroid Build Coastguard Worker	esac
9806*6236dae4SAndroid Build Coastguard Worker      done
9807*6236dae4SAndroid Build Coastguard Worker      deplibs=$new_libs
9808*6236dae4SAndroid Build Coastguard Worker
9809*6236dae4SAndroid Build Coastguard Worker      # All the library-specific variables (install_libdir is set above).
9810*6236dae4SAndroid Build Coastguard Worker      library_names=
9811*6236dae4SAndroid Build Coastguard Worker      old_library=
9812*6236dae4SAndroid Build Coastguard Worker      dlname=
9813*6236dae4SAndroid Build Coastguard Worker
9814*6236dae4SAndroid Build Coastguard Worker      # Test again, we may have decided not to build it any more
9815*6236dae4SAndroid Build Coastguard Worker      if test yes = "$build_libtool_libs"; then
9816*6236dae4SAndroid Build Coastguard Worker	# Remove $wl instances when linking with ld.
9817*6236dae4SAndroid Build Coastguard Worker	# FIXME: should test the right _cmds variable.
9818*6236dae4SAndroid Build Coastguard Worker	case $archive_cmds in
9819*6236dae4SAndroid Build Coastguard Worker	  *\$LD\ *) wl= ;;
9820*6236dae4SAndroid Build Coastguard Worker        esac
9821*6236dae4SAndroid Build Coastguard Worker	if test yes = "$hardcode_into_libs"; then
9822*6236dae4SAndroid Build Coastguard Worker	  # Hardcode the library paths
9823*6236dae4SAndroid Build Coastguard Worker	  hardcode_libdirs=
9824*6236dae4SAndroid Build Coastguard Worker	  dep_rpath=
9825*6236dae4SAndroid Build Coastguard Worker	  rpath=$finalize_rpath
9826*6236dae4SAndroid Build Coastguard Worker	  test relink = "$opt_mode" || rpath=$compile_rpath$rpath
9827*6236dae4SAndroid Build Coastguard Worker	  for libdir in $rpath; do
9828*6236dae4SAndroid Build Coastguard Worker	    if test -n "$hardcode_libdir_flag_spec"; then
9829*6236dae4SAndroid Build Coastguard Worker	      if test -n "$hardcode_libdir_separator"; then
9830*6236dae4SAndroid Build Coastguard Worker		func_replace_sysroot "$libdir"
9831*6236dae4SAndroid Build Coastguard Worker		libdir=$func_replace_sysroot_result
9832*6236dae4SAndroid Build Coastguard Worker		if test -z "$hardcode_libdirs"; then
9833*6236dae4SAndroid Build Coastguard Worker		  hardcode_libdirs=$libdir
9834*6236dae4SAndroid Build Coastguard Worker		else
9835*6236dae4SAndroid Build Coastguard Worker		  # Just accumulate the unique libdirs.
9836*6236dae4SAndroid Build Coastguard Worker		  case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
9837*6236dae4SAndroid Build Coastguard Worker		  *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
9838*6236dae4SAndroid Build Coastguard Worker		    ;;
9839*6236dae4SAndroid Build Coastguard Worker		  *)
9840*6236dae4SAndroid Build Coastguard Worker		    func_append hardcode_libdirs "$hardcode_libdir_separator$libdir"
9841*6236dae4SAndroid Build Coastguard Worker		    ;;
9842*6236dae4SAndroid Build Coastguard Worker		  esac
9843*6236dae4SAndroid Build Coastguard Worker		fi
9844*6236dae4SAndroid Build Coastguard Worker	      else
9845*6236dae4SAndroid Build Coastguard Worker		eval flag=\"$hardcode_libdir_flag_spec\"
9846*6236dae4SAndroid Build Coastguard Worker		func_append dep_rpath " $flag"
9847*6236dae4SAndroid Build Coastguard Worker	      fi
9848*6236dae4SAndroid Build Coastguard Worker	    elif test -n "$runpath_var"; then
9849*6236dae4SAndroid Build Coastguard Worker	      case "$perm_rpath " in
9850*6236dae4SAndroid Build Coastguard Worker	      *" $libdir "*) ;;
9851*6236dae4SAndroid Build Coastguard Worker	      *) func_append perm_rpath " $libdir" ;;
9852*6236dae4SAndroid Build Coastguard Worker	      esac
9853*6236dae4SAndroid Build Coastguard Worker	    fi
9854*6236dae4SAndroid Build Coastguard Worker	  done
9855*6236dae4SAndroid Build Coastguard Worker	  # Substitute the hardcoded libdirs into the rpath.
9856*6236dae4SAndroid Build Coastguard Worker	  if test -n "$hardcode_libdir_separator" &&
9857*6236dae4SAndroid Build Coastguard Worker	     test -n "$hardcode_libdirs"; then
9858*6236dae4SAndroid Build Coastguard Worker	    libdir=$hardcode_libdirs
9859*6236dae4SAndroid Build Coastguard Worker	    eval "dep_rpath=\"$hardcode_libdir_flag_spec\""
9860*6236dae4SAndroid Build Coastguard Worker	  fi
9861*6236dae4SAndroid Build Coastguard Worker	  if test -n "$runpath_var" && test -n "$perm_rpath"; then
9862*6236dae4SAndroid Build Coastguard Worker	    # We should set the runpath_var.
9863*6236dae4SAndroid Build Coastguard Worker	    rpath=
9864*6236dae4SAndroid Build Coastguard Worker	    for dir in $perm_rpath; do
9865*6236dae4SAndroid Build Coastguard Worker	      func_append rpath "$dir:"
9866*6236dae4SAndroid Build Coastguard Worker	    done
9867*6236dae4SAndroid Build Coastguard Worker	    eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var"
9868*6236dae4SAndroid Build Coastguard Worker	  fi
9869*6236dae4SAndroid Build Coastguard Worker	  test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs"
9870*6236dae4SAndroid Build Coastguard Worker	fi
9871*6236dae4SAndroid Build Coastguard Worker
9872*6236dae4SAndroid Build Coastguard Worker	shlibpath=$finalize_shlibpath
9873*6236dae4SAndroid Build Coastguard Worker	test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath
9874*6236dae4SAndroid Build Coastguard Worker	if test -n "$shlibpath"; then
9875*6236dae4SAndroid Build Coastguard Worker	  eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var"
9876*6236dae4SAndroid Build Coastguard Worker	fi
9877*6236dae4SAndroid Build Coastguard Worker
9878*6236dae4SAndroid Build Coastguard Worker	# Get the real and link names of the library.
9879*6236dae4SAndroid Build Coastguard Worker	eval shared_ext=\"$shrext_cmds\"
9880*6236dae4SAndroid Build Coastguard Worker	eval library_names=\"$library_names_spec\"
9881*6236dae4SAndroid Build Coastguard Worker	set dummy $library_names
9882*6236dae4SAndroid Build Coastguard Worker	shift
9883*6236dae4SAndroid Build Coastguard Worker	realname=$1
9884*6236dae4SAndroid Build Coastguard Worker	shift
9885*6236dae4SAndroid Build Coastguard Worker
9886*6236dae4SAndroid Build Coastguard Worker	if test -n "$soname_spec"; then
9887*6236dae4SAndroid Build Coastguard Worker	  eval soname=\"$soname_spec\"
9888*6236dae4SAndroid Build Coastguard Worker	else
9889*6236dae4SAndroid Build Coastguard Worker	  soname=$realname
9890*6236dae4SAndroid Build Coastguard Worker	fi
9891*6236dae4SAndroid Build Coastguard Worker	if test -z "$dlname"; then
9892*6236dae4SAndroid Build Coastguard Worker	  dlname=$soname
9893*6236dae4SAndroid Build Coastguard Worker	fi
9894*6236dae4SAndroid Build Coastguard Worker
9895*6236dae4SAndroid Build Coastguard Worker	lib=$output_objdir/$realname
9896*6236dae4SAndroid Build Coastguard Worker	linknames=
9897*6236dae4SAndroid Build Coastguard Worker	for link
9898*6236dae4SAndroid Build Coastguard Worker	do
9899*6236dae4SAndroid Build Coastguard Worker	  func_append linknames " $link"
9900*6236dae4SAndroid Build Coastguard Worker	done
9901*6236dae4SAndroid Build Coastguard Worker
9902*6236dae4SAndroid Build Coastguard Worker	# Use standard objects if they are pic
9903*6236dae4SAndroid Build Coastguard Worker	test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP`
9904*6236dae4SAndroid Build Coastguard Worker	test "X$libobjs" = "X " && libobjs=
9905*6236dae4SAndroid Build Coastguard Worker
9906*6236dae4SAndroid Build Coastguard Worker	delfiles=
9907*6236dae4SAndroid Build Coastguard Worker	if test -n "$export_symbols" && test -n "$include_expsyms"; then
9908*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp"
9909*6236dae4SAndroid Build Coastguard Worker	  export_symbols=$output_objdir/$libname.uexp
9910*6236dae4SAndroid Build Coastguard Worker	  func_append delfiles " $export_symbols"
9911*6236dae4SAndroid Build Coastguard Worker	fi
9912*6236dae4SAndroid Build Coastguard Worker
9913*6236dae4SAndroid Build Coastguard Worker	orig_export_symbols=
9914*6236dae4SAndroid Build Coastguard Worker	case $host_os in
9915*6236dae4SAndroid Build Coastguard Worker	cygwin* | mingw* | cegcc*)
9916*6236dae4SAndroid Build Coastguard Worker	  if test -n "$export_symbols" && test -z "$export_symbols_regex"; then
9917*6236dae4SAndroid Build Coastguard Worker	    # exporting using user supplied symfile
9918*6236dae4SAndroid Build Coastguard Worker	    func_dll_def_p "$export_symbols" || {
9919*6236dae4SAndroid Build Coastguard Worker	      # and it's NOT already a .def file. Must figure out
9920*6236dae4SAndroid Build Coastguard Worker	      # which of the given symbols are data symbols and tag
9921*6236dae4SAndroid Build Coastguard Worker	      # them as such. So, trigger use of export_symbols_cmds.
9922*6236dae4SAndroid Build Coastguard Worker	      # export_symbols gets reassigned inside the "prepare
9923*6236dae4SAndroid Build Coastguard Worker	      # the list of exported symbols" if statement, so the
9924*6236dae4SAndroid Build Coastguard Worker	      # include_expsyms logic still works.
9925*6236dae4SAndroid Build Coastguard Worker	      orig_export_symbols=$export_symbols
9926*6236dae4SAndroid Build Coastguard Worker	      export_symbols=
9927*6236dae4SAndroid Build Coastguard Worker	      always_export_symbols=yes
9928*6236dae4SAndroid Build Coastguard Worker	    }
9929*6236dae4SAndroid Build Coastguard Worker	  fi
9930*6236dae4SAndroid Build Coastguard Worker	  ;;
9931*6236dae4SAndroid Build Coastguard Worker	esac
9932*6236dae4SAndroid Build Coastguard Worker
9933*6236dae4SAndroid Build Coastguard Worker	# Prepare the list of exported symbols
9934*6236dae4SAndroid Build Coastguard Worker	if test -z "$export_symbols"; then
9935*6236dae4SAndroid Build Coastguard Worker	  if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then
9936*6236dae4SAndroid Build Coastguard Worker	    func_verbose "generating symbol list for '$libname.la'"
9937*6236dae4SAndroid Build Coastguard Worker	    export_symbols=$output_objdir/$libname.exp
9938*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || $RM $export_symbols
9939*6236dae4SAndroid Build Coastguard Worker	    cmds=$export_symbols_cmds
9940*6236dae4SAndroid Build Coastguard Worker	    save_ifs=$IFS; IFS='~'
9941*6236dae4SAndroid Build Coastguard Worker	    for cmd1 in $cmds; do
9942*6236dae4SAndroid Build Coastguard Worker	      IFS=$save_ifs
9943*6236dae4SAndroid Build Coastguard Worker	      # Take the normal branch if the nm_file_list_spec branch
9944*6236dae4SAndroid Build Coastguard Worker	      # doesn't work or if tool conversion is not needed.
9945*6236dae4SAndroid Build Coastguard Worker	      case $nm_file_list_spec~$to_tool_file_cmd in
9946*6236dae4SAndroid Build Coastguard Worker		*~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*)
9947*6236dae4SAndroid Build Coastguard Worker		  try_normal_branch=yes
9948*6236dae4SAndroid Build Coastguard Worker		  eval cmd=\"$cmd1\"
9949*6236dae4SAndroid Build Coastguard Worker		  func_len " $cmd"
9950*6236dae4SAndroid Build Coastguard Worker		  len=$func_len_result
9951*6236dae4SAndroid Build Coastguard Worker		  ;;
9952*6236dae4SAndroid Build Coastguard Worker		*)
9953*6236dae4SAndroid Build Coastguard Worker		  try_normal_branch=no
9954*6236dae4SAndroid Build Coastguard Worker		  ;;
9955*6236dae4SAndroid Build Coastguard Worker	      esac
9956*6236dae4SAndroid Build Coastguard Worker	      if test yes = "$try_normal_branch" \
9957*6236dae4SAndroid Build Coastguard Worker		 && { test "$len" -lt "$max_cmd_len" \
9958*6236dae4SAndroid Build Coastguard Worker		      || test "$max_cmd_len" -le -1; }
9959*6236dae4SAndroid Build Coastguard Worker	      then
9960*6236dae4SAndroid Build Coastguard Worker		func_show_eval "$cmd" 'exit $?'
9961*6236dae4SAndroid Build Coastguard Worker		skipped_export=false
9962*6236dae4SAndroid Build Coastguard Worker	      elif test -n "$nm_file_list_spec"; then
9963*6236dae4SAndroid Build Coastguard Worker		func_basename "$output"
9964*6236dae4SAndroid Build Coastguard Worker		output_la=$func_basename_result
9965*6236dae4SAndroid Build Coastguard Worker		save_libobjs=$libobjs
9966*6236dae4SAndroid Build Coastguard Worker		save_output=$output
9967*6236dae4SAndroid Build Coastguard Worker		output=$output_objdir/$output_la.nm
9968*6236dae4SAndroid Build Coastguard Worker		func_to_tool_file "$output"
9969*6236dae4SAndroid Build Coastguard Worker		libobjs=$nm_file_list_spec$func_to_tool_file_result
9970*6236dae4SAndroid Build Coastguard Worker		func_append delfiles " $output"
9971*6236dae4SAndroid Build Coastguard Worker		func_verbose "creating $NM input file list: $output"
9972*6236dae4SAndroid Build Coastguard Worker		for obj in $save_libobjs; do
9973*6236dae4SAndroid Build Coastguard Worker		  func_to_tool_file "$obj"
9974*6236dae4SAndroid Build Coastguard Worker		  $ECHO "$func_to_tool_file_result"
9975*6236dae4SAndroid Build Coastguard Worker		done > "$output"
9976*6236dae4SAndroid Build Coastguard Worker		eval cmd=\"$cmd1\"
9977*6236dae4SAndroid Build Coastguard Worker		func_show_eval "$cmd" 'exit $?'
9978*6236dae4SAndroid Build Coastguard Worker		output=$save_output
9979*6236dae4SAndroid Build Coastguard Worker		libobjs=$save_libobjs
9980*6236dae4SAndroid Build Coastguard Worker		skipped_export=false
9981*6236dae4SAndroid Build Coastguard Worker	      else
9982*6236dae4SAndroid Build Coastguard Worker		# The command line is too long to execute in one step.
9983*6236dae4SAndroid Build Coastguard Worker		func_verbose "using reloadable object file for export list..."
9984*6236dae4SAndroid Build Coastguard Worker		skipped_export=:
9985*6236dae4SAndroid Build Coastguard Worker		# Break out early, otherwise skipped_export may be
9986*6236dae4SAndroid Build Coastguard Worker		# set to false by a later but shorter cmd.
9987*6236dae4SAndroid Build Coastguard Worker		break
9988*6236dae4SAndroid Build Coastguard Worker	      fi
9989*6236dae4SAndroid Build Coastguard Worker	    done
9990*6236dae4SAndroid Build Coastguard Worker	    IFS=$save_ifs
9991*6236dae4SAndroid Build Coastguard Worker	    if test -n "$export_symbols_regex" && test : != "$skipped_export"; then
9992*6236dae4SAndroid Build Coastguard Worker	      func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
9993*6236dae4SAndroid Build Coastguard Worker	      func_show_eval '$MV "${export_symbols}T" "$export_symbols"'
9994*6236dae4SAndroid Build Coastguard Worker	    fi
9995*6236dae4SAndroid Build Coastguard Worker	  fi
9996*6236dae4SAndroid Build Coastguard Worker	fi
9997*6236dae4SAndroid Build Coastguard Worker
9998*6236dae4SAndroid Build Coastguard Worker	if test -n "$export_symbols" && test -n "$include_expsyms"; then
9999*6236dae4SAndroid Build Coastguard Worker	  tmp_export_symbols=$export_symbols
10000*6236dae4SAndroid Build Coastguard Worker	  test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols
10001*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
10002*6236dae4SAndroid Build Coastguard Worker	fi
10003*6236dae4SAndroid Build Coastguard Worker
10004*6236dae4SAndroid Build Coastguard Worker	if test : != "$skipped_export" && test -n "$orig_export_symbols"; then
10005*6236dae4SAndroid Build Coastguard Worker	  # The given exports_symbols file has to be filtered, so filter it.
10006*6236dae4SAndroid Build Coastguard Worker	  func_verbose "filter symbol list for '$libname.la' to tag DATA exports"
10007*6236dae4SAndroid Build Coastguard Worker	  # FIXME: $output_objdir/$libname.filter potentially contains lots of
10008*6236dae4SAndroid Build Coastguard Worker	  # 's' commands, which not all seds can handle. GNU sed should be fine
10009*6236dae4SAndroid Build Coastguard Worker	  # though. Also, the filter scales superlinearly with the number of
10010*6236dae4SAndroid Build Coastguard Worker	  # global variables. join(1) would be nice here, but unfortunately
10011*6236dae4SAndroid Build Coastguard Worker	  # isn't a blessed tool.
10012*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter
10013*6236dae4SAndroid Build Coastguard Worker	  func_append delfiles " $export_symbols $output_objdir/$libname.filter"
10014*6236dae4SAndroid Build Coastguard Worker	  export_symbols=$output_objdir/$libname.def
10015*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
10016*6236dae4SAndroid Build Coastguard Worker	fi
10017*6236dae4SAndroid Build Coastguard Worker
10018*6236dae4SAndroid Build Coastguard Worker	tmp_deplibs=
10019*6236dae4SAndroid Build Coastguard Worker	for test_deplib in $deplibs; do
10020*6236dae4SAndroid Build Coastguard Worker	  case " $convenience " in
10021*6236dae4SAndroid Build Coastguard Worker	  *" $test_deplib "*) ;;
10022*6236dae4SAndroid Build Coastguard Worker	  *)
10023*6236dae4SAndroid Build Coastguard Worker	    func_append tmp_deplibs " $test_deplib"
10024*6236dae4SAndroid Build Coastguard Worker	    ;;
10025*6236dae4SAndroid Build Coastguard Worker	  esac
10026*6236dae4SAndroid Build Coastguard Worker	done
10027*6236dae4SAndroid Build Coastguard Worker	deplibs=$tmp_deplibs
10028*6236dae4SAndroid Build Coastguard Worker
10029*6236dae4SAndroid Build Coastguard Worker	if test -n "$convenience"; then
10030*6236dae4SAndroid Build Coastguard Worker	  if test -n "$whole_archive_flag_spec" &&
10031*6236dae4SAndroid Build Coastguard Worker	    test yes = "$compiler_needs_object" &&
10032*6236dae4SAndroid Build Coastguard Worker	    test -z "$libobjs"; then
10033*6236dae4SAndroid Build Coastguard Worker	    # extract the archives, so we have objects to list.
10034*6236dae4SAndroid Build Coastguard Worker	    # TODO: could optimize this to just extract one archive.
10035*6236dae4SAndroid Build Coastguard Worker	    whole_archive_flag_spec=
10036*6236dae4SAndroid Build Coastguard Worker	  fi
10037*6236dae4SAndroid Build Coastguard Worker	  if test -n "$whole_archive_flag_spec"; then
10038*6236dae4SAndroid Build Coastguard Worker	    save_libobjs=$libobjs
10039*6236dae4SAndroid Build Coastguard Worker	    eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
10040*6236dae4SAndroid Build Coastguard Worker	    test "X$libobjs" = "X " && libobjs=
10041*6236dae4SAndroid Build Coastguard Worker	  else
10042*6236dae4SAndroid Build Coastguard Worker	    gentop=$output_objdir/${outputname}x
10043*6236dae4SAndroid Build Coastguard Worker	    func_append generated " $gentop"
10044*6236dae4SAndroid Build Coastguard Worker
10045*6236dae4SAndroid Build Coastguard Worker	    func_extract_archives $gentop $convenience
10046*6236dae4SAndroid Build Coastguard Worker	    func_append libobjs " $func_extract_archives_result"
10047*6236dae4SAndroid Build Coastguard Worker	    test "X$libobjs" = "X " && libobjs=
10048*6236dae4SAndroid Build Coastguard Worker	  fi
10049*6236dae4SAndroid Build Coastguard Worker	fi
10050*6236dae4SAndroid Build Coastguard Worker
10051*6236dae4SAndroid Build Coastguard Worker	if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then
10052*6236dae4SAndroid Build Coastguard Worker	  eval flag=\"$thread_safe_flag_spec\"
10053*6236dae4SAndroid Build Coastguard Worker	  func_append linker_flags " $flag"
10054*6236dae4SAndroid Build Coastguard Worker	fi
10055*6236dae4SAndroid Build Coastguard Worker
10056*6236dae4SAndroid Build Coastguard Worker	# Make a backup of the uninstalled library when relinking
10057*6236dae4SAndroid Build Coastguard Worker	if test relink = "$opt_mode"; then
10058*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $?
10059*6236dae4SAndroid Build Coastguard Worker	fi
10060*6236dae4SAndroid Build Coastguard Worker
10061*6236dae4SAndroid Build Coastguard Worker	# Do each of the archive commands.
10062*6236dae4SAndroid Build Coastguard Worker	if test yes = "$module" && test -n "$module_cmds"; then
10063*6236dae4SAndroid Build Coastguard Worker	  if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
10064*6236dae4SAndroid Build Coastguard Worker	    eval test_cmds=\"$module_expsym_cmds\"
10065*6236dae4SAndroid Build Coastguard Worker	    cmds=$module_expsym_cmds
10066*6236dae4SAndroid Build Coastguard Worker	  else
10067*6236dae4SAndroid Build Coastguard Worker	    eval test_cmds=\"$module_cmds\"
10068*6236dae4SAndroid Build Coastguard Worker	    cmds=$module_cmds
10069*6236dae4SAndroid Build Coastguard Worker	  fi
10070*6236dae4SAndroid Build Coastguard Worker	else
10071*6236dae4SAndroid Build Coastguard Worker	  if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
10072*6236dae4SAndroid Build Coastguard Worker	    eval test_cmds=\"$archive_expsym_cmds\"
10073*6236dae4SAndroid Build Coastguard Worker	    cmds=$archive_expsym_cmds
10074*6236dae4SAndroid Build Coastguard Worker	  else
10075*6236dae4SAndroid Build Coastguard Worker	    eval test_cmds=\"$archive_cmds\"
10076*6236dae4SAndroid Build Coastguard Worker	    cmds=$archive_cmds
10077*6236dae4SAndroid Build Coastguard Worker	  fi
10078*6236dae4SAndroid Build Coastguard Worker	fi
10079*6236dae4SAndroid Build Coastguard Worker
10080*6236dae4SAndroid Build Coastguard Worker	if test : != "$skipped_export" &&
10081*6236dae4SAndroid Build Coastguard Worker	   func_len " $test_cmds" &&
10082*6236dae4SAndroid Build Coastguard Worker	   len=$func_len_result &&
10083*6236dae4SAndroid Build Coastguard Worker	   test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
10084*6236dae4SAndroid Build Coastguard Worker	  :
10085*6236dae4SAndroid Build Coastguard Worker	else
10086*6236dae4SAndroid Build Coastguard Worker	  # The command line is too long to link in one step, link piecewise
10087*6236dae4SAndroid Build Coastguard Worker	  # or, if using GNU ld and skipped_export is not :, use a linker
10088*6236dae4SAndroid Build Coastguard Worker	  # script.
10089*6236dae4SAndroid Build Coastguard Worker
10090*6236dae4SAndroid Build Coastguard Worker	  # Save the value of $output and $libobjs because we want to
10091*6236dae4SAndroid Build Coastguard Worker	  # use them later.  If we have whole_archive_flag_spec, we
10092*6236dae4SAndroid Build Coastguard Worker	  # want to use save_libobjs as it was before
10093*6236dae4SAndroid Build Coastguard Worker	  # whole_archive_flag_spec was expanded, because we can't
10094*6236dae4SAndroid Build Coastguard Worker	  # assume the linker understands whole_archive_flag_spec.
10095*6236dae4SAndroid Build Coastguard Worker	  # This may have to be revisited, in case too many
10096*6236dae4SAndroid Build Coastguard Worker	  # convenience libraries get linked in and end up exceeding
10097*6236dae4SAndroid Build Coastguard Worker	  # the spec.
10098*6236dae4SAndroid Build Coastguard Worker	  if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then
10099*6236dae4SAndroid Build Coastguard Worker	    save_libobjs=$libobjs
10100*6236dae4SAndroid Build Coastguard Worker	  fi
10101*6236dae4SAndroid Build Coastguard Worker	  save_output=$output
10102*6236dae4SAndroid Build Coastguard Worker	  func_basename "$output"
10103*6236dae4SAndroid Build Coastguard Worker	  output_la=$func_basename_result
10104*6236dae4SAndroid Build Coastguard Worker
10105*6236dae4SAndroid Build Coastguard Worker	  # Clear the reloadable object creation command queue and
10106*6236dae4SAndroid Build Coastguard Worker	  # initialize k to one.
10107*6236dae4SAndroid Build Coastguard Worker	  test_cmds=
10108*6236dae4SAndroid Build Coastguard Worker	  concat_cmds=
10109*6236dae4SAndroid Build Coastguard Worker	  objlist=
10110*6236dae4SAndroid Build Coastguard Worker	  last_robj=
10111*6236dae4SAndroid Build Coastguard Worker	  k=1
10112*6236dae4SAndroid Build Coastguard Worker
10113*6236dae4SAndroid Build Coastguard Worker	  if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then
10114*6236dae4SAndroid Build Coastguard Worker	    output=$output_objdir/$output_la.lnkscript
10115*6236dae4SAndroid Build Coastguard Worker	    func_verbose "creating GNU ld script: $output"
10116*6236dae4SAndroid Build Coastguard Worker	    echo 'INPUT (' > $output
10117*6236dae4SAndroid Build Coastguard Worker	    for obj in $save_libobjs
10118*6236dae4SAndroid Build Coastguard Worker	    do
10119*6236dae4SAndroid Build Coastguard Worker	      func_to_tool_file "$obj"
10120*6236dae4SAndroid Build Coastguard Worker	      $ECHO "$func_to_tool_file_result" >> $output
10121*6236dae4SAndroid Build Coastguard Worker	    done
10122*6236dae4SAndroid Build Coastguard Worker	    echo ')' >> $output
10123*6236dae4SAndroid Build Coastguard Worker	    func_append delfiles " $output"
10124*6236dae4SAndroid Build Coastguard Worker	    func_to_tool_file "$output"
10125*6236dae4SAndroid Build Coastguard Worker	    output=$func_to_tool_file_result
10126*6236dae4SAndroid Build Coastguard Worker	  elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then
10127*6236dae4SAndroid Build Coastguard Worker	    output=$output_objdir/$output_la.lnk
10128*6236dae4SAndroid Build Coastguard Worker	    func_verbose "creating linker input file list: $output"
10129*6236dae4SAndroid Build Coastguard Worker	    : > $output
10130*6236dae4SAndroid Build Coastguard Worker	    set x $save_libobjs
10131*6236dae4SAndroid Build Coastguard Worker	    shift
10132*6236dae4SAndroid Build Coastguard Worker	    firstobj=
10133*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$compiler_needs_object"; then
10134*6236dae4SAndroid Build Coastguard Worker	      firstobj="$1 "
10135*6236dae4SAndroid Build Coastguard Worker	      shift
10136*6236dae4SAndroid Build Coastguard Worker	    fi
10137*6236dae4SAndroid Build Coastguard Worker	    for obj
10138*6236dae4SAndroid Build Coastguard Worker	    do
10139*6236dae4SAndroid Build Coastguard Worker	      func_to_tool_file "$obj"
10140*6236dae4SAndroid Build Coastguard Worker	      $ECHO "$func_to_tool_file_result" >> $output
10141*6236dae4SAndroid Build Coastguard Worker	    done
10142*6236dae4SAndroid Build Coastguard Worker	    func_append delfiles " $output"
10143*6236dae4SAndroid Build Coastguard Worker	    func_to_tool_file "$output"
10144*6236dae4SAndroid Build Coastguard Worker	    output=$firstobj\"$file_list_spec$func_to_tool_file_result\"
10145*6236dae4SAndroid Build Coastguard Worker	  else
10146*6236dae4SAndroid Build Coastguard Worker	    if test -n "$save_libobjs"; then
10147*6236dae4SAndroid Build Coastguard Worker	      func_verbose "creating reloadable object files..."
10148*6236dae4SAndroid Build Coastguard Worker	      output=$output_objdir/$output_la-$k.$objext
10149*6236dae4SAndroid Build Coastguard Worker	      eval test_cmds=\"$reload_cmds\"
10150*6236dae4SAndroid Build Coastguard Worker	      func_len " $test_cmds"
10151*6236dae4SAndroid Build Coastguard Worker	      len0=$func_len_result
10152*6236dae4SAndroid Build Coastguard Worker	      len=$len0
10153*6236dae4SAndroid Build Coastguard Worker
10154*6236dae4SAndroid Build Coastguard Worker	      # Loop over the list of objects to be linked.
10155*6236dae4SAndroid Build Coastguard Worker	      for obj in $save_libobjs
10156*6236dae4SAndroid Build Coastguard Worker	      do
10157*6236dae4SAndroid Build Coastguard Worker		func_len " $obj"
10158*6236dae4SAndroid Build Coastguard Worker		func_arith $len + $func_len_result
10159*6236dae4SAndroid Build Coastguard Worker		len=$func_arith_result
10160*6236dae4SAndroid Build Coastguard Worker		if test -z "$objlist" ||
10161*6236dae4SAndroid Build Coastguard Worker		   test "$len" -lt "$max_cmd_len"; then
10162*6236dae4SAndroid Build Coastguard Worker		  func_append objlist " $obj"
10163*6236dae4SAndroid Build Coastguard Worker		else
10164*6236dae4SAndroid Build Coastguard Worker		  # The command $test_cmds is almost too long, add a
10165*6236dae4SAndroid Build Coastguard Worker		  # command to the queue.
10166*6236dae4SAndroid Build Coastguard Worker		  if test 1 -eq "$k"; then
10167*6236dae4SAndroid Build Coastguard Worker		    # The first file doesn't have a previous command to add.
10168*6236dae4SAndroid Build Coastguard Worker		    reload_objs=$objlist
10169*6236dae4SAndroid Build Coastguard Worker		    eval concat_cmds=\"$reload_cmds\"
10170*6236dae4SAndroid Build Coastguard Worker		  else
10171*6236dae4SAndroid Build Coastguard Worker		    # All subsequent reloadable object files will link in
10172*6236dae4SAndroid Build Coastguard Worker		    # the last one created.
10173*6236dae4SAndroid Build Coastguard Worker		    reload_objs="$objlist $last_robj"
10174*6236dae4SAndroid Build Coastguard Worker		    eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\"
10175*6236dae4SAndroid Build Coastguard Worker		  fi
10176*6236dae4SAndroid Build Coastguard Worker		  last_robj=$output_objdir/$output_la-$k.$objext
10177*6236dae4SAndroid Build Coastguard Worker		  func_arith $k + 1
10178*6236dae4SAndroid Build Coastguard Worker		  k=$func_arith_result
10179*6236dae4SAndroid Build Coastguard Worker		  output=$output_objdir/$output_la-$k.$objext
10180*6236dae4SAndroid Build Coastguard Worker		  objlist=" $obj"
10181*6236dae4SAndroid Build Coastguard Worker		  func_len " $last_robj"
10182*6236dae4SAndroid Build Coastguard Worker		  func_arith $len0 + $func_len_result
10183*6236dae4SAndroid Build Coastguard Worker		  len=$func_arith_result
10184*6236dae4SAndroid Build Coastguard Worker		fi
10185*6236dae4SAndroid Build Coastguard Worker	      done
10186*6236dae4SAndroid Build Coastguard Worker	      # Handle the remaining objects by creating one last
10187*6236dae4SAndroid Build Coastguard Worker	      # reloadable object file.  All subsequent reloadable object
10188*6236dae4SAndroid Build Coastguard Worker	      # files will link in the last one created.
10189*6236dae4SAndroid Build Coastguard Worker	      test -z "$concat_cmds" || concat_cmds=$concat_cmds~
10190*6236dae4SAndroid Build Coastguard Worker	      reload_objs="$objlist $last_robj"
10191*6236dae4SAndroid Build Coastguard Worker	      eval concat_cmds=\"\$concat_cmds$reload_cmds\"
10192*6236dae4SAndroid Build Coastguard Worker	      if test -n "$last_robj"; then
10193*6236dae4SAndroid Build Coastguard Worker	        eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\"
10194*6236dae4SAndroid Build Coastguard Worker	      fi
10195*6236dae4SAndroid Build Coastguard Worker	      func_append delfiles " $output"
10196*6236dae4SAndroid Build Coastguard Worker
10197*6236dae4SAndroid Build Coastguard Worker	    else
10198*6236dae4SAndroid Build Coastguard Worker	      output=
10199*6236dae4SAndroid Build Coastguard Worker	    fi
10200*6236dae4SAndroid Build Coastguard Worker
10201*6236dae4SAndroid Build Coastguard Worker	    ${skipped_export-false} && {
10202*6236dae4SAndroid Build Coastguard Worker	      func_verbose "generating symbol list for '$libname.la'"
10203*6236dae4SAndroid Build Coastguard Worker	      export_symbols=$output_objdir/$libname.exp
10204*6236dae4SAndroid Build Coastguard Worker	      $opt_dry_run || $RM $export_symbols
10205*6236dae4SAndroid Build Coastguard Worker	      libobjs=$output
10206*6236dae4SAndroid Build Coastguard Worker	      # Append the command to create the export file.
10207*6236dae4SAndroid Build Coastguard Worker	      test -z "$concat_cmds" || concat_cmds=$concat_cmds~
10208*6236dae4SAndroid Build Coastguard Worker	      eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\"
10209*6236dae4SAndroid Build Coastguard Worker	      if test -n "$last_robj"; then
10210*6236dae4SAndroid Build Coastguard Worker		eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\"
10211*6236dae4SAndroid Build Coastguard Worker	      fi
10212*6236dae4SAndroid Build Coastguard Worker	    }
10213*6236dae4SAndroid Build Coastguard Worker
10214*6236dae4SAndroid Build Coastguard Worker	    test -n "$save_libobjs" &&
10215*6236dae4SAndroid Build Coastguard Worker	      func_verbose "creating a temporary reloadable object file: $output"
10216*6236dae4SAndroid Build Coastguard Worker
10217*6236dae4SAndroid Build Coastguard Worker	    # Loop through the commands generated above and execute them.
10218*6236dae4SAndroid Build Coastguard Worker	    save_ifs=$IFS; IFS='~'
10219*6236dae4SAndroid Build Coastguard Worker	    for cmd in $concat_cmds; do
10220*6236dae4SAndroid Build Coastguard Worker	      IFS=$save_ifs
10221*6236dae4SAndroid Build Coastguard Worker	      $opt_quiet || {
10222*6236dae4SAndroid Build Coastguard Worker		  func_quote_arg expand,pretty "$cmd"
10223*6236dae4SAndroid Build Coastguard Worker		  eval "func_echo $func_quote_arg_result"
10224*6236dae4SAndroid Build Coastguard Worker	      }
10225*6236dae4SAndroid Build Coastguard Worker	      $opt_dry_run || eval "$cmd" || {
10226*6236dae4SAndroid Build Coastguard Worker		lt_exit=$?
10227*6236dae4SAndroid Build Coastguard Worker
10228*6236dae4SAndroid Build Coastguard Worker		# Restore the uninstalled library and exit
10229*6236dae4SAndroid Build Coastguard Worker		if test relink = "$opt_mode"; then
10230*6236dae4SAndroid Build Coastguard Worker		  ( cd "$output_objdir" && \
10231*6236dae4SAndroid Build Coastguard Worker		    $RM "${realname}T" && \
10232*6236dae4SAndroid Build Coastguard Worker		    $MV "${realname}U" "$realname" )
10233*6236dae4SAndroid Build Coastguard Worker		fi
10234*6236dae4SAndroid Build Coastguard Worker
10235*6236dae4SAndroid Build Coastguard Worker		exit $lt_exit
10236*6236dae4SAndroid Build Coastguard Worker	      }
10237*6236dae4SAndroid Build Coastguard Worker	    done
10238*6236dae4SAndroid Build Coastguard Worker	    IFS=$save_ifs
10239*6236dae4SAndroid Build Coastguard Worker
10240*6236dae4SAndroid Build Coastguard Worker	    if test -n "$export_symbols_regex" && ${skipped_export-false}; then
10241*6236dae4SAndroid Build Coastguard Worker	      func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
10242*6236dae4SAndroid Build Coastguard Worker	      func_show_eval '$MV "${export_symbols}T" "$export_symbols"'
10243*6236dae4SAndroid Build Coastguard Worker	    fi
10244*6236dae4SAndroid Build Coastguard Worker	  fi
10245*6236dae4SAndroid Build Coastguard Worker
10246*6236dae4SAndroid Build Coastguard Worker          ${skipped_export-false} && {
10247*6236dae4SAndroid Build Coastguard Worker	    if test -n "$export_symbols" && test -n "$include_expsyms"; then
10248*6236dae4SAndroid Build Coastguard Worker	      tmp_export_symbols=$export_symbols
10249*6236dae4SAndroid Build Coastguard Worker	      test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols
10250*6236dae4SAndroid Build Coastguard Worker	      $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
10251*6236dae4SAndroid Build Coastguard Worker	    fi
10252*6236dae4SAndroid Build Coastguard Worker
10253*6236dae4SAndroid Build Coastguard Worker	    if test -n "$orig_export_symbols"; then
10254*6236dae4SAndroid Build Coastguard Worker	      # The given exports_symbols file has to be filtered, so filter it.
10255*6236dae4SAndroid Build Coastguard Worker	      func_verbose "filter symbol list for '$libname.la' to tag DATA exports"
10256*6236dae4SAndroid Build Coastguard Worker	      # FIXME: $output_objdir/$libname.filter potentially contains lots of
10257*6236dae4SAndroid Build Coastguard Worker	      # 's' commands, which not all seds can handle. GNU sed should be fine
10258*6236dae4SAndroid Build Coastguard Worker	      # though. Also, the filter scales superlinearly with the number of
10259*6236dae4SAndroid Build Coastguard Worker	      # global variables. join(1) would be nice here, but unfortunately
10260*6236dae4SAndroid Build Coastguard Worker	      # isn't a blessed tool.
10261*6236dae4SAndroid Build Coastguard Worker	      $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter
10262*6236dae4SAndroid Build Coastguard Worker	      func_append delfiles " $export_symbols $output_objdir/$libname.filter"
10263*6236dae4SAndroid Build Coastguard Worker	      export_symbols=$output_objdir/$libname.def
10264*6236dae4SAndroid Build Coastguard Worker	      $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
10265*6236dae4SAndroid Build Coastguard Worker	    fi
10266*6236dae4SAndroid Build Coastguard Worker	  }
10267*6236dae4SAndroid Build Coastguard Worker
10268*6236dae4SAndroid Build Coastguard Worker	  libobjs=$output
10269*6236dae4SAndroid Build Coastguard Worker	  # Restore the value of output.
10270*6236dae4SAndroid Build Coastguard Worker	  output=$save_output
10271*6236dae4SAndroid Build Coastguard Worker
10272*6236dae4SAndroid Build Coastguard Worker	  if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then
10273*6236dae4SAndroid Build Coastguard Worker	    eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
10274*6236dae4SAndroid Build Coastguard Worker	    test "X$libobjs" = "X " && libobjs=
10275*6236dae4SAndroid Build Coastguard Worker	  fi
10276*6236dae4SAndroid Build Coastguard Worker	  # Expand the library linking commands again to reset the
10277*6236dae4SAndroid Build Coastguard Worker	  # value of $libobjs for piecewise linking.
10278*6236dae4SAndroid Build Coastguard Worker
10279*6236dae4SAndroid Build Coastguard Worker	  # Do each of the archive commands.
10280*6236dae4SAndroid Build Coastguard Worker	  if test yes = "$module" && test -n "$module_cmds"; then
10281*6236dae4SAndroid Build Coastguard Worker	    if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
10282*6236dae4SAndroid Build Coastguard Worker	      cmds=$module_expsym_cmds
10283*6236dae4SAndroid Build Coastguard Worker	    else
10284*6236dae4SAndroid Build Coastguard Worker	      cmds=$module_cmds
10285*6236dae4SAndroid Build Coastguard Worker	    fi
10286*6236dae4SAndroid Build Coastguard Worker	  else
10287*6236dae4SAndroid Build Coastguard Worker	    if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
10288*6236dae4SAndroid Build Coastguard Worker	      cmds=$archive_expsym_cmds
10289*6236dae4SAndroid Build Coastguard Worker	    else
10290*6236dae4SAndroid Build Coastguard Worker	      cmds=$archive_cmds
10291*6236dae4SAndroid Build Coastguard Worker	    fi
10292*6236dae4SAndroid Build Coastguard Worker	  fi
10293*6236dae4SAndroid Build Coastguard Worker	fi
10294*6236dae4SAndroid Build Coastguard Worker
10295*6236dae4SAndroid Build Coastguard Worker	if test -n "$delfiles"; then
10296*6236dae4SAndroid Build Coastguard Worker	  # Append the command to remove temporary files to $cmds.
10297*6236dae4SAndroid Build Coastguard Worker	  eval cmds=\"\$cmds~\$RM $delfiles\"
10298*6236dae4SAndroid Build Coastguard Worker	fi
10299*6236dae4SAndroid Build Coastguard Worker
10300*6236dae4SAndroid Build Coastguard Worker	# Add any objects from preloaded convenience libraries
10301*6236dae4SAndroid Build Coastguard Worker	if test -n "$dlprefiles"; then
10302*6236dae4SAndroid Build Coastguard Worker	  gentop=$output_objdir/${outputname}x
10303*6236dae4SAndroid Build Coastguard Worker	  func_append generated " $gentop"
10304*6236dae4SAndroid Build Coastguard Worker
10305*6236dae4SAndroid Build Coastguard Worker	  func_extract_archives $gentop $dlprefiles
10306*6236dae4SAndroid Build Coastguard Worker	  func_append libobjs " $func_extract_archives_result"
10307*6236dae4SAndroid Build Coastguard Worker	  test "X$libobjs" = "X " && libobjs=
10308*6236dae4SAndroid Build Coastguard Worker	fi
10309*6236dae4SAndroid Build Coastguard Worker
10310*6236dae4SAndroid Build Coastguard Worker	save_ifs=$IFS; IFS='~'
10311*6236dae4SAndroid Build Coastguard Worker	for cmd in $cmds; do
10312*6236dae4SAndroid Build Coastguard Worker	  IFS=$sp$nl
10313*6236dae4SAndroid Build Coastguard Worker	  eval cmd=\"$cmd\"
10314*6236dae4SAndroid Build Coastguard Worker	  IFS=$save_ifs
10315*6236dae4SAndroid Build Coastguard Worker	  $opt_quiet || {
10316*6236dae4SAndroid Build Coastguard Worker	    func_quote_arg expand,pretty "$cmd"
10317*6236dae4SAndroid Build Coastguard Worker	    eval "func_echo $func_quote_arg_result"
10318*6236dae4SAndroid Build Coastguard Worker	  }
10319*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || eval "$cmd" || {
10320*6236dae4SAndroid Build Coastguard Worker	    lt_exit=$?
10321*6236dae4SAndroid Build Coastguard Worker
10322*6236dae4SAndroid Build Coastguard Worker	    # Restore the uninstalled library and exit
10323*6236dae4SAndroid Build Coastguard Worker	    if test relink = "$opt_mode"; then
10324*6236dae4SAndroid Build Coastguard Worker	      ( cd "$output_objdir" && \
10325*6236dae4SAndroid Build Coastguard Worker	        $RM "${realname}T" && \
10326*6236dae4SAndroid Build Coastguard Worker		$MV "${realname}U" "$realname" )
10327*6236dae4SAndroid Build Coastguard Worker	    fi
10328*6236dae4SAndroid Build Coastguard Worker
10329*6236dae4SAndroid Build Coastguard Worker	    exit $lt_exit
10330*6236dae4SAndroid Build Coastguard Worker	  }
10331*6236dae4SAndroid Build Coastguard Worker	done
10332*6236dae4SAndroid Build Coastguard Worker	IFS=$save_ifs
10333*6236dae4SAndroid Build Coastguard Worker
10334*6236dae4SAndroid Build Coastguard Worker	# Restore the uninstalled library and exit
10335*6236dae4SAndroid Build Coastguard Worker	if test relink = "$opt_mode"; then
10336*6236dae4SAndroid Build Coastguard Worker	  $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $?
10337*6236dae4SAndroid Build Coastguard Worker
10338*6236dae4SAndroid Build Coastguard Worker	  if test -n "$convenience"; then
10339*6236dae4SAndroid Build Coastguard Worker	    if test -z "$whole_archive_flag_spec"; then
10340*6236dae4SAndroid Build Coastguard Worker	      func_show_eval '${RM}r "$gentop"'
10341*6236dae4SAndroid Build Coastguard Worker	    fi
10342*6236dae4SAndroid Build Coastguard Worker	  fi
10343*6236dae4SAndroid Build Coastguard Worker
10344*6236dae4SAndroid Build Coastguard Worker	  exit $EXIT_SUCCESS
10345*6236dae4SAndroid Build Coastguard Worker	fi
10346*6236dae4SAndroid Build Coastguard Worker
10347*6236dae4SAndroid Build Coastguard Worker	# Create links to the real library.
10348*6236dae4SAndroid Build Coastguard Worker	for linkname in $linknames; do
10349*6236dae4SAndroid Build Coastguard Worker	  if test "$realname" != "$linkname"; then
10350*6236dae4SAndroid Build Coastguard Worker	    func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?'
10351*6236dae4SAndroid Build Coastguard Worker	  fi
10352*6236dae4SAndroid Build Coastguard Worker	done
10353*6236dae4SAndroid Build Coastguard Worker
10354*6236dae4SAndroid Build Coastguard Worker	# If -module or -export-dynamic was specified, set the dlname.
10355*6236dae4SAndroid Build Coastguard Worker	if test yes = "$module" || test yes = "$export_dynamic"; then
10356*6236dae4SAndroid Build Coastguard Worker	  # On all known operating systems, these are identical.
10357*6236dae4SAndroid Build Coastguard Worker	  dlname=$soname
10358*6236dae4SAndroid Build Coastguard Worker	fi
10359*6236dae4SAndroid Build Coastguard Worker      fi
10360*6236dae4SAndroid Build Coastguard Worker      ;;
10361*6236dae4SAndroid Build Coastguard Worker
10362*6236dae4SAndroid Build Coastguard Worker    obj)
10363*6236dae4SAndroid Build Coastguard Worker      if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
10364*6236dae4SAndroid Build Coastguard Worker	func_warning "'-dlopen' is ignored for objects"
10365*6236dae4SAndroid Build Coastguard Worker      fi
10366*6236dae4SAndroid Build Coastguard Worker
10367*6236dae4SAndroid Build Coastguard Worker      case " $deplibs" in
10368*6236dae4SAndroid Build Coastguard Worker      *\ -l* | *\ -L*)
10369*6236dae4SAndroid Build Coastguard Worker	func_warning "'-l' and '-L' are ignored for objects" ;;
10370*6236dae4SAndroid Build Coastguard Worker      esac
10371*6236dae4SAndroid Build Coastguard Worker
10372*6236dae4SAndroid Build Coastguard Worker      test -n "$rpath" && \
10373*6236dae4SAndroid Build Coastguard Worker	func_warning "'-rpath' is ignored for objects"
10374*6236dae4SAndroid Build Coastguard Worker
10375*6236dae4SAndroid Build Coastguard Worker      test -n "$xrpath" && \
10376*6236dae4SAndroid Build Coastguard Worker	func_warning "'-R' is ignored for objects"
10377*6236dae4SAndroid Build Coastguard Worker
10378*6236dae4SAndroid Build Coastguard Worker      test -n "$vinfo" && \
10379*6236dae4SAndroid Build Coastguard Worker	func_warning "'-version-info' is ignored for objects"
10380*6236dae4SAndroid Build Coastguard Worker
10381*6236dae4SAndroid Build Coastguard Worker      test -n "$release" && \
10382*6236dae4SAndroid Build Coastguard Worker	func_warning "'-release' is ignored for objects"
10383*6236dae4SAndroid Build Coastguard Worker
10384*6236dae4SAndroid Build Coastguard Worker      case $output in
10385*6236dae4SAndroid Build Coastguard Worker      *.lo)
10386*6236dae4SAndroid Build Coastguard Worker	test -n "$objs$old_deplibs" && \
10387*6236dae4SAndroid Build Coastguard Worker	  func_fatal_error "cannot build library object '$output' from non-libtool objects"
10388*6236dae4SAndroid Build Coastguard Worker
10389*6236dae4SAndroid Build Coastguard Worker	libobj=$output
10390*6236dae4SAndroid Build Coastguard Worker	func_lo2o "$libobj"
10391*6236dae4SAndroid Build Coastguard Worker	obj=$func_lo2o_result
10392*6236dae4SAndroid Build Coastguard Worker	;;
10393*6236dae4SAndroid Build Coastguard Worker      *)
10394*6236dae4SAndroid Build Coastguard Worker	libobj=
10395*6236dae4SAndroid Build Coastguard Worker	obj=$output
10396*6236dae4SAndroid Build Coastguard Worker	;;
10397*6236dae4SAndroid Build Coastguard Worker      esac
10398*6236dae4SAndroid Build Coastguard Worker
10399*6236dae4SAndroid Build Coastguard Worker      # Delete the old objects.
10400*6236dae4SAndroid Build Coastguard Worker      $opt_dry_run || $RM $obj $libobj
10401*6236dae4SAndroid Build Coastguard Worker
10402*6236dae4SAndroid Build Coastguard Worker      # Objects from convenience libraries.  This assumes
10403*6236dae4SAndroid Build Coastguard Worker      # single-version convenience libraries.  Whenever we create
10404*6236dae4SAndroid Build Coastguard Worker      # different ones for PIC/non-PIC, this we'll have to duplicate
10405*6236dae4SAndroid Build Coastguard Worker      # the extraction.
10406*6236dae4SAndroid Build Coastguard Worker      reload_conv_objs=
10407*6236dae4SAndroid Build Coastguard Worker      gentop=
10408*6236dae4SAndroid Build Coastguard Worker      # if reload_cmds runs $LD directly, get rid of -Wl from
10409*6236dae4SAndroid Build Coastguard Worker      # whole_archive_flag_spec and hope we can get by with turning comma
10410*6236dae4SAndroid Build Coastguard Worker      # into space.
10411*6236dae4SAndroid Build Coastguard Worker      case $reload_cmds in
10412*6236dae4SAndroid Build Coastguard Worker        *\$LD[\ \$]*) wl= ;;
10413*6236dae4SAndroid Build Coastguard Worker      esac
10414*6236dae4SAndroid Build Coastguard Worker      if test -n "$convenience"; then
10415*6236dae4SAndroid Build Coastguard Worker	if test -n "$whole_archive_flag_spec"; then
10416*6236dae4SAndroid Build Coastguard Worker	  eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\"
10417*6236dae4SAndroid Build Coastguard Worker	  test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'`
10418*6236dae4SAndroid Build Coastguard Worker	  reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags
10419*6236dae4SAndroid Build Coastguard Worker	else
10420*6236dae4SAndroid Build Coastguard Worker	  gentop=$output_objdir/${obj}x
10421*6236dae4SAndroid Build Coastguard Worker	  func_append generated " $gentop"
10422*6236dae4SAndroid Build Coastguard Worker
10423*6236dae4SAndroid Build Coastguard Worker	  func_extract_archives $gentop $convenience
10424*6236dae4SAndroid Build Coastguard Worker	  reload_conv_objs="$reload_objs $func_extract_archives_result"
10425*6236dae4SAndroid Build Coastguard Worker	fi
10426*6236dae4SAndroid Build Coastguard Worker      fi
10427*6236dae4SAndroid Build Coastguard Worker
10428*6236dae4SAndroid Build Coastguard Worker      # If we're not building shared, we need to use non_pic_objs
10429*6236dae4SAndroid Build Coastguard Worker      test yes = "$build_libtool_libs" || libobjs=$non_pic_objects
10430*6236dae4SAndroid Build Coastguard Worker
10431*6236dae4SAndroid Build Coastguard Worker      # Create the old-style object.
10432*6236dae4SAndroid Build Coastguard Worker      reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs
10433*6236dae4SAndroid Build Coastguard Worker
10434*6236dae4SAndroid Build Coastguard Worker      output=$obj
10435*6236dae4SAndroid Build Coastguard Worker      func_execute_cmds "$reload_cmds" 'exit $?'
10436*6236dae4SAndroid Build Coastguard Worker
10437*6236dae4SAndroid Build Coastguard Worker      # Exit if we aren't doing a library object file.
10438*6236dae4SAndroid Build Coastguard Worker      if test -z "$libobj"; then
10439*6236dae4SAndroid Build Coastguard Worker	if test -n "$gentop"; then
10440*6236dae4SAndroid Build Coastguard Worker	  func_show_eval '${RM}r "$gentop"'
10441*6236dae4SAndroid Build Coastguard Worker	fi
10442*6236dae4SAndroid Build Coastguard Worker
10443*6236dae4SAndroid Build Coastguard Worker	exit $EXIT_SUCCESS
10444*6236dae4SAndroid Build Coastguard Worker      fi
10445*6236dae4SAndroid Build Coastguard Worker
10446*6236dae4SAndroid Build Coastguard Worker      test yes = "$build_libtool_libs" || {
10447*6236dae4SAndroid Build Coastguard Worker	if test -n "$gentop"; then
10448*6236dae4SAndroid Build Coastguard Worker	  func_show_eval '${RM}r "$gentop"'
10449*6236dae4SAndroid Build Coastguard Worker	fi
10450*6236dae4SAndroid Build Coastguard Worker
10451*6236dae4SAndroid Build Coastguard Worker	# Create an invalid libtool object if no PIC, so that we don't
10452*6236dae4SAndroid Build Coastguard Worker	# accidentally link it into a program.
10453*6236dae4SAndroid Build Coastguard Worker	# $show "echo timestamp > $libobj"
10454*6236dae4SAndroid Build Coastguard Worker	# $opt_dry_run || eval "echo timestamp > $libobj" || exit $?
10455*6236dae4SAndroid Build Coastguard Worker	exit $EXIT_SUCCESS
10456*6236dae4SAndroid Build Coastguard Worker      }
10457*6236dae4SAndroid Build Coastguard Worker
10458*6236dae4SAndroid Build Coastguard Worker      if test -n "$pic_flag" || test default != "$pic_mode"; then
10459*6236dae4SAndroid Build Coastguard Worker	# Only do commands if we really have different PIC objects.
10460*6236dae4SAndroid Build Coastguard Worker	reload_objs="$libobjs $reload_conv_objs"
10461*6236dae4SAndroid Build Coastguard Worker	output=$libobj
10462*6236dae4SAndroid Build Coastguard Worker	func_execute_cmds "$reload_cmds" 'exit $?'
10463*6236dae4SAndroid Build Coastguard Worker      fi
10464*6236dae4SAndroid Build Coastguard Worker
10465*6236dae4SAndroid Build Coastguard Worker      if test -n "$gentop"; then
10466*6236dae4SAndroid Build Coastguard Worker	func_show_eval '${RM}r "$gentop"'
10467*6236dae4SAndroid Build Coastguard Worker      fi
10468*6236dae4SAndroid Build Coastguard Worker
10469*6236dae4SAndroid Build Coastguard Worker      exit $EXIT_SUCCESS
10470*6236dae4SAndroid Build Coastguard Worker      ;;
10471*6236dae4SAndroid Build Coastguard Worker
10472*6236dae4SAndroid Build Coastguard Worker    prog)
10473*6236dae4SAndroid Build Coastguard Worker      case $host in
10474*6236dae4SAndroid Build Coastguard Worker	*cygwin*) func_stripname '' '.exe' "$output"
10475*6236dae4SAndroid Build Coastguard Worker	          output=$func_stripname_result.exe;;
10476*6236dae4SAndroid Build Coastguard Worker      esac
10477*6236dae4SAndroid Build Coastguard Worker      test -n "$vinfo" && \
10478*6236dae4SAndroid Build Coastguard Worker	func_warning "'-version-info' is ignored for programs"
10479*6236dae4SAndroid Build Coastguard Worker
10480*6236dae4SAndroid Build Coastguard Worker      test -n "$release" && \
10481*6236dae4SAndroid Build Coastguard Worker	func_warning "'-release' is ignored for programs"
10482*6236dae4SAndroid Build Coastguard Worker
10483*6236dae4SAndroid Build Coastguard Worker      $preload \
10484*6236dae4SAndroid Build Coastguard Worker	&& test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \
10485*6236dae4SAndroid Build Coastguard Worker	&& func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support."
10486*6236dae4SAndroid Build Coastguard Worker
10487*6236dae4SAndroid Build Coastguard Worker      case $host in
10488*6236dae4SAndroid Build Coastguard Worker      *-*-rhapsody* | *-*-darwin1.[012])
10489*6236dae4SAndroid Build Coastguard Worker	# On Rhapsody replace the C library is the System framework
10490*6236dae4SAndroid Build Coastguard Worker	compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'`
10491*6236dae4SAndroid Build Coastguard Worker	finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'`
10492*6236dae4SAndroid Build Coastguard Worker	;;
10493*6236dae4SAndroid Build Coastguard Worker      esac
10494*6236dae4SAndroid Build Coastguard Worker
10495*6236dae4SAndroid Build Coastguard Worker      case $host in
10496*6236dae4SAndroid Build Coastguard Worker      *-*-darwin*)
10497*6236dae4SAndroid Build Coastguard Worker	# Don't allow lazy linking, it breaks C++ global constructors
10498*6236dae4SAndroid Build Coastguard Worker	# But is supposedly fixed on 10.4 or later (yay!).
10499*6236dae4SAndroid Build Coastguard Worker	if test CXX = "$tagname"; then
10500*6236dae4SAndroid Build Coastguard Worker	  case ${MACOSX_DEPLOYMENT_TARGET-10.0} in
10501*6236dae4SAndroid Build Coastguard Worker	    10.[0123])
10502*6236dae4SAndroid Build Coastguard Worker	      func_append compile_command " $wl-bind_at_load"
10503*6236dae4SAndroid Build Coastguard Worker	      func_append finalize_command " $wl-bind_at_load"
10504*6236dae4SAndroid Build Coastguard Worker	    ;;
10505*6236dae4SAndroid Build Coastguard Worker	  esac
10506*6236dae4SAndroid Build Coastguard Worker	fi
10507*6236dae4SAndroid Build Coastguard Worker	# Time to change all our "foo.ltframework" stuff back to "-framework foo"
10508*6236dae4SAndroid Build Coastguard Worker	compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
10509*6236dae4SAndroid Build Coastguard Worker	finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
10510*6236dae4SAndroid Build Coastguard Worker	;;
10511*6236dae4SAndroid Build Coastguard Worker      esac
10512*6236dae4SAndroid Build Coastguard Worker
10513*6236dae4SAndroid Build Coastguard Worker
10514*6236dae4SAndroid Build Coastguard Worker      # move library search paths that coincide with paths to not yet
10515*6236dae4SAndroid Build Coastguard Worker      # installed libraries to the beginning of the library search list
10516*6236dae4SAndroid Build Coastguard Worker      new_libs=
10517*6236dae4SAndroid Build Coastguard Worker      for path in $notinst_path; do
10518*6236dae4SAndroid Build Coastguard Worker	case " $new_libs " in
10519*6236dae4SAndroid Build Coastguard Worker	*" -L$path/$objdir "*) ;;
10520*6236dae4SAndroid Build Coastguard Worker	*)
10521*6236dae4SAndroid Build Coastguard Worker	  case " $compile_deplibs " in
10522*6236dae4SAndroid Build Coastguard Worker	  *" -L$path/$objdir "*)
10523*6236dae4SAndroid Build Coastguard Worker	    func_append new_libs " -L$path/$objdir" ;;
10524*6236dae4SAndroid Build Coastguard Worker	  esac
10525*6236dae4SAndroid Build Coastguard Worker	  ;;
10526*6236dae4SAndroid Build Coastguard Worker	esac
10527*6236dae4SAndroid Build Coastguard Worker      done
10528*6236dae4SAndroid Build Coastguard Worker      for deplib in $compile_deplibs; do
10529*6236dae4SAndroid Build Coastguard Worker	case $deplib in
10530*6236dae4SAndroid Build Coastguard Worker	-L*)
10531*6236dae4SAndroid Build Coastguard Worker	  case " $new_libs " in
10532*6236dae4SAndroid Build Coastguard Worker	  *" $deplib "*) ;;
10533*6236dae4SAndroid Build Coastguard Worker	  *) func_append new_libs " $deplib" ;;
10534*6236dae4SAndroid Build Coastguard Worker	  esac
10535*6236dae4SAndroid Build Coastguard Worker	  ;;
10536*6236dae4SAndroid Build Coastguard Worker	*) func_append new_libs " $deplib" ;;
10537*6236dae4SAndroid Build Coastguard Worker	esac
10538*6236dae4SAndroid Build Coastguard Worker      done
10539*6236dae4SAndroid Build Coastguard Worker      compile_deplibs=$new_libs
10540*6236dae4SAndroid Build Coastguard Worker
10541*6236dae4SAndroid Build Coastguard Worker
10542*6236dae4SAndroid Build Coastguard Worker      func_append compile_command " $compile_deplibs"
10543*6236dae4SAndroid Build Coastguard Worker      func_append finalize_command " $finalize_deplibs"
10544*6236dae4SAndroid Build Coastguard Worker
10545*6236dae4SAndroid Build Coastguard Worker      if test -n "$rpath$xrpath"; then
10546*6236dae4SAndroid Build Coastguard Worker	# If the user specified any rpath flags, then add them.
10547*6236dae4SAndroid Build Coastguard Worker	for libdir in $rpath $xrpath; do
10548*6236dae4SAndroid Build Coastguard Worker	  # This is the magic to use -rpath.
10549*6236dae4SAndroid Build Coastguard Worker	  case "$finalize_rpath " in
10550*6236dae4SAndroid Build Coastguard Worker	  *" $libdir "*) ;;
10551*6236dae4SAndroid Build Coastguard Worker	  *) func_append finalize_rpath " $libdir" ;;
10552*6236dae4SAndroid Build Coastguard Worker	  esac
10553*6236dae4SAndroid Build Coastguard Worker	done
10554*6236dae4SAndroid Build Coastguard Worker      fi
10555*6236dae4SAndroid Build Coastguard Worker
10556*6236dae4SAndroid Build Coastguard Worker      # Now hardcode the library paths
10557*6236dae4SAndroid Build Coastguard Worker      rpath=
10558*6236dae4SAndroid Build Coastguard Worker      hardcode_libdirs=
10559*6236dae4SAndroid Build Coastguard Worker      for libdir in $compile_rpath $finalize_rpath; do
10560*6236dae4SAndroid Build Coastguard Worker	if test -n "$hardcode_libdir_flag_spec"; then
10561*6236dae4SAndroid Build Coastguard Worker	  if test -n "$hardcode_libdir_separator"; then
10562*6236dae4SAndroid Build Coastguard Worker	    if test -z "$hardcode_libdirs"; then
10563*6236dae4SAndroid Build Coastguard Worker	      hardcode_libdirs=$libdir
10564*6236dae4SAndroid Build Coastguard Worker	    else
10565*6236dae4SAndroid Build Coastguard Worker	      # Just accumulate the unique libdirs.
10566*6236dae4SAndroid Build Coastguard Worker	      case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
10567*6236dae4SAndroid Build Coastguard Worker	      *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
10568*6236dae4SAndroid Build Coastguard Worker		;;
10569*6236dae4SAndroid Build Coastguard Worker	      *)
10570*6236dae4SAndroid Build Coastguard Worker		func_append hardcode_libdirs "$hardcode_libdir_separator$libdir"
10571*6236dae4SAndroid Build Coastguard Worker		;;
10572*6236dae4SAndroid Build Coastguard Worker	      esac
10573*6236dae4SAndroid Build Coastguard Worker	    fi
10574*6236dae4SAndroid Build Coastguard Worker	  else
10575*6236dae4SAndroid Build Coastguard Worker	    eval flag=\"$hardcode_libdir_flag_spec\"
10576*6236dae4SAndroid Build Coastguard Worker	    func_append rpath " $flag"
10577*6236dae4SAndroid Build Coastguard Worker	  fi
10578*6236dae4SAndroid Build Coastguard Worker	elif test -n "$runpath_var"; then
10579*6236dae4SAndroid Build Coastguard Worker	  case "$perm_rpath " in
10580*6236dae4SAndroid Build Coastguard Worker	  *" $libdir "*) ;;
10581*6236dae4SAndroid Build Coastguard Worker	  *) func_append perm_rpath " $libdir" ;;
10582*6236dae4SAndroid Build Coastguard Worker	  esac
10583*6236dae4SAndroid Build Coastguard Worker	fi
10584*6236dae4SAndroid Build Coastguard Worker	case $host in
10585*6236dae4SAndroid Build Coastguard Worker	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
10586*6236dae4SAndroid Build Coastguard Worker	  testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'`
10587*6236dae4SAndroid Build Coastguard Worker	  case :$dllsearchpath: in
10588*6236dae4SAndroid Build Coastguard Worker	  *":$libdir:"*) ;;
10589*6236dae4SAndroid Build Coastguard Worker	  ::) dllsearchpath=$libdir;;
10590*6236dae4SAndroid Build Coastguard Worker	  *) func_append dllsearchpath ":$libdir";;
10591*6236dae4SAndroid Build Coastguard Worker	  esac
10592*6236dae4SAndroid Build Coastguard Worker	  case :$dllsearchpath: in
10593*6236dae4SAndroid Build Coastguard Worker	  *":$testbindir:"*) ;;
10594*6236dae4SAndroid Build Coastguard Worker	  ::) dllsearchpath=$testbindir;;
10595*6236dae4SAndroid Build Coastguard Worker	  *) func_append dllsearchpath ":$testbindir";;
10596*6236dae4SAndroid Build Coastguard Worker	  esac
10597*6236dae4SAndroid Build Coastguard Worker	  ;;
10598*6236dae4SAndroid Build Coastguard Worker	esac
10599*6236dae4SAndroid Build Coastguard Worker      done
10600*6236dae4SAndroid Build Coastguard Worker      # Substitute the hardcoded libdirs into the rpath.
10601*6236dae4SAndroid Build Coastguard Worker      if test -n "$hardcode_libdir_separator" &&
10602*6236dae4SAndroid Build Coastguard Worker	 test -n "$hardcode_libdirs"; then
10603*6236dae4SAndroid Build Coastguard Worker	libdir=$hardcode_libdirs
10604*6236dae4SAndroid Build Coastguard Worker	eval rpath=\" $hardcode_libdir_flag_spec\"
10605*6236dae4SAndroid Build Coastguard Worker      fi
10606*6236dae4SAndroid Build Coastguard Worker      compile_rpath=$rpath
10607*6236dae4SAndroid Build Coastguard Worker
10608*6236dae4SAndroid Build Coastguard Worker      rpath=
10609*6236dae4SAndroid Build Coastguard Worker      hardcode_libdirs=
10610*6236dae4SAndroid Build Coastguard Worker      for libdir in $finalize_rpath; do
10611*6236dae4SAndroid Build Coastguard Worker	if test -n "$hardcode_libdir_flag_spec"; then
10612*6236dae4SAndroid Build Coastguard Worker	  if test -n "$hardcode_libdir_separator"; then
10613*6236dae4SAndroid Build Coastguard Worker	    if test -z "$hardcode_libdirs"; then
10614*6236dae4SAndroid Build Coastguard Worker	      hardcode_libdirs=$libdir
10615*6236dae4SAndroid Build Coastguard Worker	    else
10616*6236dae4SAndroid Build Coastguard Worker	      # Just accumulate the unique libdirs.
10617*6236dae4SAndroid Build Coastguard Worker	      case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
10618*6236dae4SAndroid Build Coastguard Worker	      *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
10619*6236dae4SAndroid Build Coastguard Worker		;;
10620*6236dae4SAndroid Build Coastguard Worker	      *)
10621*6236dae4SAndroid Build Coastguard Worker		func_append hardcode_libdirs "$hardcode_libdir_separator$libdir"
10622*6236dae4SAndroid Build Coastguard Worker		;;
10623*6236dae4SAndroid Build Coastguard Worker	      esac
10624*6236dae4SAndroid Build Coastguard Worker	    fi
10625*6236dae4SAndroid Build Coastguard Worker	  else
10626*6236dae4SAndroid Build Coastguard Worker	    eval flag=\"$hardcode_libdir_flag_spec\"
10627*6236dae4SAndroid Build Coastguard Worker	    func_append rpath " $flag"
10628*6236dae4SAndroid Build Coastguard Worker	  fi
10629*6236dae4SAndroid Build Coastguard Worker	elif test -n "$runpath_var"; then
10630*6236dae4SAndroid Build Coastguard Worker	  case "$finalize_perm_rpath " in
10631*6236dae4SAndroid Build Coastguard Worker	  *" $libdir "*) ;;
10632*6236dae4SAndroid Build Coastguard Worker	  *) func_append finalize_perm_rpath " $libdir" ;;
10633*6236dae4SAndroid Build Coastguard Worker	  esac
10634*6236dae4SAndroid Build Coastguard Worker	fi
10635*6236dae4SAndroid Build Coastguard Worker      done
10636*6236dae4SAndroid Build Coastguard Worker      # Substitute the hardcoded libdirs into the rpath.
10637*6236dae4SAndroid Build Coastguard Worker      if test -n "$hardcode_libdir_separator" &&
10638*6236dae4SAndroid Build Coastguard Worker	 test -n "$hardcode_libdirs"; then
10639*6236dae4SAndroid Build Coastguard Worker	libdir=$hardcode_libdirs
10640*6236dae4SAndroid Build Coastguard Worker	eval rpath=\" $hardcode_libdir_flag_spec\"
10641*6236dae4SAndroid Build Coastguard Worker      fi
10642*6236dae4SAndroid Build Coastguard Worker      finalize_rpath=$rpath
10643*6236dae4SAndroid Build Coastguard Worker
10644*6236dae4SAndroid Build Coastguard Worker      if test -n "$libobjs" && test yes = "$build_old_libs"; then
10645*6236dae4SAndroid Build Coastguard Worker	# Transform all the library objects into standard objects.
10646*6236dae4SAndroid Build Coastguard Worker	compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
10647*6236dae4SAndroid Build Coastguard Worker	finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
10648*6236dae4SAndroid Build Coastguard Worker      fi
10649*6236dae4SAndroid Build Coastguard Worker
10650*6236dae4SAndroid Build Coastguard Worker      func_generate_dlsyms "$outputname" "@PROGRAM@" false
10651*6236dae4SAndroid Build Coastguard Worker
10652*6236dae4SAndroid Build Coastguard Worker      # template prelinking step
10653*6236dae4SAndroid Build Coastguard Worker      if test -n "$prelink_cmds"; then
10654*6236dae4SAndroid Build Coastguard Worker	func_execute_cmds "$prelink_cmds" 'exit $?'
10655*6236dae4SAndroid Build Coastguard Worker      fi
10656*6236dae4SAndroid Build Coastguard Worker
10657*6236dae4SAndroid Build Coastguard Worker      wrappers_required=:
10658*6236dae4SAndroid Build Coastguard Worker      case $host in
10659*6236dae4SAndroid Build Coastguard Worker      *cegcc* | *mingw32ce*)
10660*6236dae4SAndroid Build Coastguard Worker        # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway.
10661*6236dae4SAndroid Build Coastguard Worker        wrappers_required=false
10662*6236dae4SAndroid Build Coastguard Worker        ;;
10663*6236dae4SAndroid Build Coastguard Worker      *cygwin* | *mingw* )
10664*6236dae4SAndroid Build Coastguard Worker        test yes = "$build_libtool_libs" || wrappers_required=false
10665*6236dae4SAndroid Build Coastguard Worker        ;;
10666*6236dae4SAndroid Build Coastguard Worker      *)
10667*6236dae4SAndroid Build Coastguard Worker        if test no = "$need_relink" || test yes != "$build_libtool_libs"; then
10668*6236dae4SAndroid Build Coastguard Worker          wrappers_required=false
10669*6236dae4SAndroid Build Coastguard Worker        fi
10670*6236dae4SAndroid Build Coastguard Worker        ;;
10671*6236dae4SAndroid Build Coastguard Worker      esac
10672*6236dae4SAndroid Build Coastguard Worker      $wrappers_required || {
10673*6236dae4SAndroid Build Coastguard Worker	# Replace the output file specification.
10674*6236dae4SAndroid Build Coastguard Worker	compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
10675*6236dae4SAndroid Build Coastguard Worker	link_command=$compile_command$compile_rpath
10676*6236dae4SAndroid Build Coastguard Worker
10677*6236dae4SAndroid Build Coastguard Worker	# We have no uninstalled library dependencies, so finalize right now.
10678*6236dae4SAndroid Build Coastguard Worker	exit_status=0
10679*6236dae4SAndroid Build Coastguard Worker	func_show_eval "$link_command" 'exit_status=$?'
10680*6236dae4SAndroid Build Coastguard Worker
10681*6236dae4SAndroid Build Coastguard Worker	if test -n "$postlink_cmds"; then
10682*6236dae4SAndroid Build Coastguard Worker	  func_to_tool_file "$output"
10683*6236dae4SAndroid Build Coastguard Worker	  postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'`
10684*6236dae4SAndroid Build Coastguard Worker	  func_execute_cmds "$postlink_cmds" 'exit $?'
10685*6236dae4SAndroid Build Coastguard Worker	fi
10686*6236dae4SAndroid Build Coastguard Worker
10687*6236dae4SAndroid Build Coastguard Worker	# Delete the generated files.
10688*6236dae4SAndroid Build Coastguard Worker	if test -f "$output_objdir/${outputname}S.$objext"; then
10689*6236dae4SAndroid Build Coastguard Worker	  func_show_eval '$RM "$output_objdir/${outputname}S.$objext"'
10690*6236dae4SAndroid Build Coastguard Worker	fi
10691*6236dae4SAndroid Build Coastguard Worker
10692*6236dae4SAndroid Build Coastguard Worker	exit $exit_status
10693*6236dae4SAndroid Build Coastguard Worker      }
10694*6236dae4SAndroid Build Coastguard Worker
10695*6236dae4SAndroid Build Coastguard Worker      if test -n "$compile_shlibpath$finalize_shlibpath"; then
10696*6236dae4SAndroid Build Coastguard Worker	compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command"
10697*6236dae4SAndroid Build Coastguard Worker      fi
10698*6236dae4SAndroid Build Coastguard Worker      if test -n "$finalize_shlibpath"; then
10699*6236dae4SAndroid Build Coastguard Worker	finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command"
10700*6236dae4SAndroid Build Coastguard Worker      fi
10701*6236dae4SAndroid Build Coastguard Worker
10702*6236dae4SAndroid Build Coastguard Worker      compile_var=
10703*6236dae4SAndroid Build Coastguard Worker      finalize_var=
10704*6236dae4SAndroid Build Coastguard Worker      if test -n "$runpath_var"; then
10705*6236dae4SAndroid Build Coastguard Worker	if test -n "$perm_rpath"; then
10706*6236dae4SAndroid Build Coastguard Worker	  # We should set the runpath_var.
10707*6236dae4SAndroid Build Coastguard Worker	  rpath=
10708*6236dae4SAndroid Build Coastguard Worker	  for dir in $perm_rpath; do
10709*6236dae4SAndroid Build Coastguard Worker	    func_append rpath "$dir:"
10710*6236dae4SAndroid Build Coastguard Worker	  done
10711*6236dae4SAndroid Build Coastguard Worker	  compile_var="$runpath_var=\"$rpath\$$runpath_var\" "
10712*6236dae4SAndroid Build Coastguard Worker	fi
10713*6236dae4SAndroid Build Coastguard Worker	if test -n "$finalize_perm_rpath"; then
10714*6236dae4SAndroid Build Coastguard Worker	  # We should set the runpath_var.
10715*6236dae4SAndroid Build Coastguard Worker	  rpath=
10716*6236dae4SAndroid Build Coastguard Worker	  for dir in $finalize_perm_rpath; do
10717*6236dae4SAndroid Build Coastguard Worker	    func_append rpath "$dir:"
10718*6236dae4SAndroid Build Coastguard Worker	  done
10719*6236dae4SAndroid Build Coastguard Worker	  finalize_var="$runpath_var=\"$rpath\$$runpath_var\" "
10720*6236dae4SAndroid Build Coastguard Worker	fi
10721*6236dae4SAndroid Build Coastguard Worker      fi
10722*6236dae4SAndroid Build Coastguard Worker
10723*6236dae4SAndroid Build Coastguard Worker      if test yes = "$no_install"; then
10724*6236dae4SAndroid Build Coastguard Worker	# We don't need to create a wrapper script.
10725*6236dae4SAndroid Build Coastguard Worker	link_command=$compile_var$compile_command$compile_rpath
10726*6236dae4SAndroid Build Coastguard Worker	# Replace the output file specification.
10727*6236dae4SAndroid Build Coastguard Worker	link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
10728*6236dae4SAndroid Build Coastguard Worker	# Delete the old output file.
10729*6236dae4SAndroid Build Coastguard Worker	$opt_dry_run || $RM $output
10730*6236dae4SAndroid Build Coastguard Worker	# Link the executable and exit
10731*6236dae4SAndroid Build Coastguard Worker	func_show_eval "$link_command" 'exit $?'
10732*6236dae4SAndroid Build Coastguard Worker
10733*6236dae4SAndroid Build Coastguard Worker	if test -n "$postlink_cmds"; then
10734*6236dae4SAndroid Build Coastguard Worker	  func_to_tool_file "$output"
10735*6236dae4SAndroid Build Coastguard Worker	  postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'`
10736*6236dae4SAndroid Build Coastguard Worker	  func_execute_cmds "$postlink_cmds" 'exit $?'
10737*6236dae4SAndroid Build Coastguard Worker	fi
10738*6236dae4SAndroid Build Coastguard Worker
10739*6236dae4SAndroid Build Coastguard Worker	exit $EXIT_SUCCESS
10740*6236dae4SAndroid Build Coastguard Worker      fi
10741*6236dae4SAndroid Build Coastguard Worker
10742*6236dae4SAndroid Build Coastguard Worker      case $hardcode_action,$fast_install in
10743*6236dae4SAndroid Build Coastguard Worker        relink,*)
10744*6236dae4SAndroid Build Coastguard Worker	  # Fast installation is not supported
10745*6236dae4SAndroid Build Coastguard Worker	  link_command=$compile_var$compile_command$compile_rpath
10746*6236dae4SAndroid Build Coastguard Worker	  relink_command=$finalize_var$finalize_command$finalize_rpath
10747*6236dae4SAndroid Build Coastguard Worker
10748*6236dae4SAndroid Build Coastguard Worker	  func_warning "this platform does not like uninstalled shared libraries"
10749*6236dae4SAndroid Build Coastguard Worker	  func_warning "'$output' will be relinked during installation"
10750*6236dae4SAndroid Build Coastguard Worker	  ;;
10751*6236dae4SAndroid Build Coastguard Worker        *,yes)
10752*6236dae4SAndroid Build Coastguard Worker	  link_command=$finalize_var$compile_command$finalize_rpath
10753*6236dae4SAndroid Build Coastguard Worker	  relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'`
10754*6236dae4SAndroid Build Coastguard Worker          ;;
10755*6236dae4SAndroid Build Coastguard Worker	*,no)
10756*6236dae4SAndroid Build Coastguard Worker	  link_command=$compile_var$compile_command$compile_rpath
10757*6236dae4SAndroid Build Coastguard Worker	  relink_command=$finalize_var$finalize_command$finalize_rpath
10758*6236dae4SAndroid Build Coastguard Worker          ;;
10759*6236dae4SAndroid Build Coastguard Worker	*,needless)
10760*6236dae4SAndroid Build Coastguard Worker	  link_command=$finalize_var$compile_command$finalize_rpath
10761*6236dae4SAndroid Build Coastguard Worker	  relink_command=
10762*6236dae4SAndroid Build Coastguard Worker          ;;
10763*6236dae4SAndroid Build Coastguard Worker      esac
10764*6236dae4SAndroid Build Coastguard Worker
10765*6236dae4SAndroid Build Coastguard Worker      # Replace the output file specification.
10766*6236dae4SAndroid Build Coastguard Worker      link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
10767*6236dae4SAndroid Build Coastguard Worker
10768*6236dae4SAndroid Build Coastguard Worker      # Delete the old output files.
10769*6236dae4SAndroid Build Coastguard Worker      $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname
10770*6236dae4SAndroid Build Coastguard Worker
10771*6236dae4SAndroid Build Coastguard Worker      func_show_eval "$link_command" 'exit $?'
10772*6236dae4SAndroid Build Coastguard Worker
10773*6236dae4SAndroid Build Coastguard Worker      if test -n "$postlink_cmds"; then
10774*6236dae4SAndroid Build Coastguard Worker	func_to_tool_file "$output_objdir/$outputname"
10775*6236dae4SAndroid Build Coastguard Worker	postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'`
10776*6236dae4SAndroid Build Coastguard Worker	func_execute_cmds "$postlink_cmds" 'exit $?'
10777*6236dae4SAndroid Build Coastguard Worker      fi
10778*6236dae4SAndroid Build Coastguard Worker
10779*6236dae4SAndroid Build Coastguard Worker      # Now create the wrapper script.
10780*6236dae4SAndroid Build Coastguard Worker      func_verbose "creating $output"
10781*6236dae4SAndroid Build Coastguard Worker
10782*6236dae4SAndroid Build Coastguard Worker      # Quote the relink command for shipping.
10783*6236dae4SAndroid Build Coastguard Worker      if test -n "$relink_command"; then
10784*6236dae4SAndroid Build Coastguard Worker	# Preserve any variables that may affect compiler behavior
10785*6236dae4SAndroid Build Coastguard Worker	for var in $variables_saved_for_relink; do
10786*6236dae4SAndroid Build Coastguard Worker	  if eval test -z \"\${$var+set}\"; then
10787*6236dae4SAndroid Build Coastguard Worker	    relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command"
10788*6236dae4SAndroid Build Coastguard Worker	  elif eval var_value=\$$var; test -z "$var_value"; then
10789*6236dae4SAndroid Build Coastguard Worker	    relink_command="$var=; export $var; $relink_command"
10790*6236dae4SAndroid Build Coastguard Worker	  else
10791*6236dae4SAndroid Build Coastguard Worker	    func_quote_arg pretty "$var_value"
10792*6236dae4SAndroid Build Coastguard Worker	    relink_command="$var=$func_quote_arg_result; export $var; $relink_command"
10793*6236dae4SAndroid Build Coastguard Worker	  fi
10794*6236dae4SAndroid Build Coastguard Worker	done
10795*6236dae4SAndroid Build Coastguard Worker	func_quote eval cd "`pwd`"
10796*6236dae4SAndroid Build Coastguard Worker	func_quote_arg pretty,unquoted "($func_quote_result; $relink_command)"
10797*6236dae4SAndroid Build Coastguard Worker	relink_command=$func_quote_arg_unquoted_result
10798*6236dae4SAndroid Build Coastguard Worker      fi
10799*6236dae4SAndroid Build Coastguard Worker
10800*6236dae4SAndroid Build Coastguard Worker      # Only actually do things if not in dry run mode.
10801*6236dae4SAndroid Build Coastguard Worker      $opt_dry_run || {
10802*6236dae4SAndroid Build Coastguard Worker	# win32 will think the script is a binary if it has
10803*6236dae4SAndroid Build Coastguard Worker	# a .exe suffix, so we strip it off here.
10804*6236dae4SAndroid Build Coastguard Worker	case $output in
10805*6236dae4SAndroid Build Coastguard Worker	  *.exe) func_stripname '' '.exe' "$output"
10806*6236dae4SAndroid Build Coastguard Worker	         output=$func_stripname_result ;;
10807*6236dae4SAndroid Build Coastguard Worker	esac
10808*6236dae4SAndroid Build Coastguard Worker	# test for cygwin because mv fails w/o .exe extensions
10809*6236dae4SAndroid Build Coastguard Worker	case $host in
10810*6236dae4SAndroid Build Coastguard Worker	  *cygwin*)
10811*6236dae4SAndroid Build Coastguard Worker	    exeext=.exe
10812*6236dae4SAndroid Build Coastguard Worker	    func_stripname '' '.exe' "$outputname"
10813*6236dae4SAndroid Build Coastguard Worker	    outputname=$func_stripname_result ;;
10814*6236dae4SAndroid Build Coastguard Worker	  *) exeext= ;;
10815*6236dae4SAndroid Build Coastguard Worker	esac
10816*6236dae4SAndroid Build Coastguard Worker	case $host in
10817*6236dae4SAndroid Build Coastguard Worker	  *cygwin* | *mingw* )
10818*6236dae4SAndroid Build Coastguard Worker	    func_dirname_and_basename "$output" "" "."
10819*6236dae4SAndroid Build Coastguard Worker	    output_name=$func_basename_result
10820*6236dae4SAndroid Build Coastguard Worker	    output_path=$func_dirname_result
10821*6236dae4SAndroid Build Coastguard Worker	    cwrappersource=$output_path/$objdir/lt-$output_name.c
10822*6236dae4SAndroid Build Coastguard Worker	    cwrapper=$output_path/$output_name.exe
10823*6236dae4SAndroid Build Coastguard Worker	    $RM $cwrappersource $cwrapper
10824*6236dae4SAndroid Build Coastguard Worker	    trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15
10825*6236dae4SAndroid Build Coastguard Worker
10826*6236dae4SAndroid Build Coastguard Worker	    func_emit_cwrapperexe_src > $cwrappersource
10827*6236dae4SAndroid Build Coastguard Worker
10828*6236dae4SAndroid Build Coastguard Worker	    # The wrapper executable is built using the $host compiler,
10829*6236dae4SAndroid Build Coastguard Worker	    # because it contains $host paths and files. If cross-
10830*6236dae4SAndroid Build Coastguard Worker	    # compiling, it, like the target executable, must be
10831*6236dae4SAndroid Build Coastguard Worker	    # executed on the $host or under an emulation environment.
10832*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || {
10833*6236dae4SAndroid Build Coastguard Worker	      $LTCC $LTCFLAGS -o $cwrapper $cwrappersource
10834*6236dae4SAndroid Build Coastguard Worker	      $STRIP $cwrapper
10835*6236dae4SAndroid Build Coastguard Worker	    }
10836*6236dae4SAndroid Build Coastguard Worker
10837*6236dae4SAndroid Build Coastguard Worker	    # Now, create the wrapper script for func_source use:
10838*6236dae4SAndroid Build Coastguard Worker	    func_ltwrapper_scriptname $cwrapper
10839*6236dae4SAndroid Build Coastguard Worker	    $RM $func_ltwrapper_scriptname_result
10840*6236dae4SAndroid Build Coastguard Worker	    trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15
10841*6236dae4SAndroid Build Coastguard Worker	    $opt_dry_run || {
10842*6236dae4SAndroid Build Coastguard Worker	      # note: this script will not be executed, so do not chmod.
10843*6236dae4SAndroid Build Coastguard Worker	      if test "x$build" = "x$host"; then
10844*6236dae4SAndroid Build Coastguard Worker		$cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result
10845*6236dae4SAndroid Build Coastguard Worker	      else
10846*6236dae4SAndroid Build Coastguard Worker		func_emit_wrapper no > $func_ltwrapper_scriptname_result
10847*6236dae4SAndroid Build Coastguard Worker	      fi
10848*6236dae4SAndroid Build Coastguard Worker	    }
10849*6236dae4SAndroid Build Coastguard Worker	  ;;
10850*6236dae4SAndroid Build Coastguard Worker	  * )
10851*6236dae4SAndroid Build Coastguard Worker	    $RM $output
10852*6236dae4SAndroid Build Coastguard Worker	    trap "$RM $output; exit $EXIT_FAILURE" 1 2 15
10853*6236dae4SAndroid Build Coastguard Worker
10854*6236dae4SAndroid Build Coastguard Worker	    func_emit_wrapper no > $output
10855*6236dae4SAndroid Build Coastguard Worker	    chmod +x $output
10856*6236dae4SAndroid Build Coastguard Worker	  ;;
10857*6236dae4SAndroid Build Coastguard Worker	esac
10858*6236dae4SAndroid Build Coastguard Worker      }
10859*6236dae4SAndroid Build Coastguard Worker      exit $EXIT_SUCCESS
10860*6236dae4SAndroid Build Coastguard Worker      ;;
10861*6236dae4SAndroid Build Coastguard Worker    esac
10862*6236dae4SAndroid Build Coastguard Worker
10863*6236dae4SAndroid Build Coastguard Worker    # See if we need to build an old-fashioned archive.
10864*6236dae4SAndroid Build Coastguard Worker    for oldlib in $oldlibs; do
10865*6236dae4SAndroid Build Coastguard Worker
10866*6236dae4SAndroid Build Coastguard Worker      case $build_libtool_libs in
10867*6236dae4SAndroid Build Coastguard Worker        convenience)
10868*6236dae4SAndroid Build Coastguard Worker	  oldobjs="$libobjs_save $symfileobj"
10869*6236dae4SAndroid Build Coastguard Worker	  addlibs=$convenience
10870*6236dae4SAndroid Build Coastguard Worker	  build_libtool_libs=no
10871*6236dae4SAndroid Build Coastguard Worker	  ;;
10872*6236dae4SAndroid Build Coastguard Worker	module)
10873*6236dae4SAndroid Build Coastguard Worker	  oldobjs=$libobjs_save
10874*6236dae4SAndroid Build Coastguard Worker	  addlibs=$old_convenience
10875*6236dae4SAndroid Build Coastguard Worker	  build_libtool_libs=no
10876*6236dae4SAndroid Build Coastguard Worker          ;;
10877*6236dae4SAndroid Build Coastguard Worker	*)
10878*6236dae4SAndroid Build Coastguard Worker	  oldobjs="$old_deplibs $non_pic_objects"
10879*6236dae4SAndroid Build Coastguard Worker	  $preload && test -f "$symfileobj" \
10880*6236dae4SAndroid Build Coastguard Worker	    && func_append oldobjs " $symfileobj"
10881*6236dae4SAndroid Build Coastguard Worker	  addlibs=$old_convenience
10882*6236dae4SAndroid Build Coastguard Worker	  ;;
10883*6236dae4SAndroid Build Coastguard Worker      esac
10884*6236dae4SAndroid Build Coastguard Worker
10885*6236dae4SAndroid Build Coastguard Worker      if test -n "$addlibs"; then
10886*6236dae4SAndroid Build Coastguard Worker	gentop=$output_objdir/${outputname}x
10887*6236dae4SAndroid Build Coastguard Worker	func_append generated " $gentop"
10888*6236dae4SAndroid Build Coastguard Worker
10889*6236dae4SAndroid Build Coastguard Worker	func_extract_archives $gentop $addlibs
10890*6236dae4SAndroid Build Coastguard Worker	func_append oldobjs " $func_extract_archives_result"
10891*6236dae4SAndroid Build Coastguard Worker      fi
10892*6236dae4SAndroid Build Coastguard Worker
10893*6236dae4SAndroid Build Coastguard Worker      # Do each command in the archive commands.
10894*6236dae4SAndroid Build Coastguard Worker      if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then
10895*6236dae4SAndroid Build Coastguard Worker	cmds=$old_archive_from_new_cmds
10896*6236dae4SAndroid Build Coastguard Worker      else
10897*6236dae4SAndroid Build Coastguard Worker
10898*6236dae4SAndroid Build Coastguard Worker	# Add any objects from preloaded convenience libraries
10899*6236dae4SAndroid Build Coastguard Worker	if test -n "$dlprefiles"; then
10900*6236dae4SAndroid Build Coastguard Worker	  gentop=$output_objdir/${outputname}x
10901*6236dae4SAndroid Build Coastguard Worker	  func_append generated " $gentop"
10902*6236dae4SAndroid Build Coastguard Worker
10903*6236dae4SAndroid Build Coastguard Worker	  func_extract_archives $gentop $dlprefiles
10904*6236dae4SAndroid Build Coastguard Worker	  func_append oldobjs " $func_extract_archives_result"
10905*6236dae4SAndroid Build Coastguard Worker	fi
10906*6236dae4SAndroid Build Coastguard Worker
10907*6236dae4SAndroid Build Coastguard Worker	# POSIX demands no paths to be encoded in archives.  We have
10908*6236dae4SAndroid Build Coastguard Worker	# to avoid creating archives with duplicate basenames if we
10909*6236dae4SAndroid Build Coastguard Worker	# might have to extract them afterwards, e.g., when creating a
10910*6236dae4SAndroid Build Coastguard Worker	# static archive out of a convenience library, or when linking
10911*6236dae4SAndroid Build Coastguard Worker	# the entirety of a libtool archive into another (currently
10912*6236dae4SAndroid Build Coastguard Worker	# not supported by libtool).
10913*6236dae4SAndroid Build Coastguard Worker	if (for obj in $oldobjs
10914*6236dae4SAndroid Build Coastguard Worker	    do
10915*6236dae4SAndroid Build Coastguard Worker	      func_basename "$obj"
10916*6236dae4SAndroid Build Coastguard Worker	      $ECHO "$func_basename_result"
10917*6236dae4SAndroid Build Coastguard Worker	    done | sort | sort -uc >/dev/null 2>&1); then
10918*6236dae4SAndroid Build Coastguard Worker	  :
10919*6236dae4SAndroid Build Coastguard Worker	else
10920*6236dae4SAndroid Build Coastguard Worker	  echo "copying selected object files to avoid basename conflicts..."
10921*6236dae4SAndroid Build Coastguard Worker	  gentop=$output_objdir/${outputname}x
10922*6236dae4SAndroid Build Coastguard Worker	  func_append generated " $gentop"
10923*6236dae4SAndroid Build Coastguard Worker	  func_mkdir_p "$gentop"
10924*6236dae4SAndroid Build Coastguard Worker	  save_oldobjs=$oldobjs
10925*6236dae4SAndroid Build Coastguard Worker	  oldobjs=
10926*6236dae4SAndroid Build Coastguard Worker	  counter=1
10927*6236dae4SAndroid Build Coastguard Worker	  for obj in $save_oldobjs
10928*6236dae4SAndroid Build Coastguard Worker	  do
10929*6236dae4SAndroid Build Coastguard Worker	    func_basename "$obj"
10930*6236dae4SAndroid Build Coastguard Worker	    objbase=$func_basename_result
10931*6236dae4SAndroid Build Coastguard Worker	    case " $oldobjs " in
10932*6236dae4SAndroid Build Coastguard Worker	    " ") oldobjs=$obj ;;
10933*6236dae4SAndroid Build Coastguard Worker	    *[\ /]"$objbase "*)
10934*6236dae4SAndroid Build Coastguard Worker	      while :; do
10935*6236dae4SAndroid Build Coastguard Worker		# Make sure we don't pick an alternate name that also
10936*6236dae4SAndroid Build Coastguard Worker		# overlaps.
10937*6236dae4SAndroid Build Coastguard Worker		newobj=lt$counter-$objbase
10938*6236dae4SAndroid Build Coastguard Worker		func_arith $counter + 1
10939*6236dae4SAndroid Build Coastguard Worker		counter=$func_arith_result
10940*6236dae4SAndroid Build Coastguard Worker		case " $oldobjs " in
10941*6236dae4SAndroid Build Coastguard Worker		*[\ /]"$newobj "*) ;;
10942*6236dae4SAndroid Build Coastguard Worker		*) if test ! -f "$gentop/$newobj"; then break; fi ;;
10943*6236dae4SAndroid Build Coastguard Worker		esac
10944*6236dae4SAndroid Build Coastguard Worker	      done
10945*6236dae4SAndroid Build Coastguard Worker	      func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj"
10946*6236dae4SAndroid Build Coastguard Worker	      func_append oldobjs " $gentop/$newobj"
10947*6236dae4SAndroid Build Coastguard Worker	      ;;
10948*6236dae4SAndroid Build Coastguard Worker	    *) func_append oldobjs " $obj" ;;
10949*6236dae4SAndroid Build Coastguard Worker	    esac
10950*6236dae4SAndroid Build Coastguard Worker	  done
10951*6236dae4SAndroid Build Coastguard Worker	fi
10952*6236dae4SAndroid Build Coastguard Worker	func_to_tool_file "$oldlib" func_convert_file_msys_to_w32
10953*6236dae4SAndroid Build Coastguard Worker	tool_oldlib=$func_to_tool_file_result
10954*6236dae4SAndroid Build Coastguard Worker	eval cmds=\"$old_archive_cmds\"
10955*6236dae4SAndroid Build Coastguard Worker
10956*6236dae4SAndroid Build Coastguard Worker	func_len " $cmds"
10957*6236dae4SAndroid Build Coastguard Worker	len=$func_len_result
10958*6236dae4SAndroid Build Coastguard Worker	if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
10959*6236dae4SAndroid Build Coastguard Worker	  cmds=$old_archive_cmds
10960*6236dae4SAndroid Build Coastguard Worker	elif test -n "$archiver_list_spec"; then
10961*6236dae4SAndroid Build Coastguard Worker	  func_verbose "using command file archive linking..."
10962*6236dae4SAndroid Build Coastguard Worker	  for obj in $oldobjs
10963*6236dae4SAndroid Build Coastguard Worker	  do
10964*6236dae4SAndroid Build Coastguard Worker	    func_to_tool_file "$obj"
10965*6236dae4SAndroid Build Coastguard Worker	    $ECHO "$func_to_tool_file_result"
10966*6236dae4SAndroid Build Coastguard Worker	  done > $output_objdir/$libname.libcmd
10967*6236dae4SAndroid Build Coastguard Worker	  func_to_tool_file "$output_objdir/$libname.libcmd"
10968*6236dae4SAndroid Build Coastguard Worker	  oldobjs=" $archiver_list_spec$func_to_tool_file_result"
10969*6236dae4SAndroid Build Coastguard Worker	  cmds=$old_archive_cmds
10970*6236dae4SAndroid Build Coastguard Worker	else
10971*6236dae4SAndroid Build Coastguard Worker	  # the command line is too long to link in one step, link in parts
10972*6236dae4SAndroid Build Coastguard Worker	  func_verbose "using piecewise archive linking..."
10973*6236dae4SAndroid Build Coastguard Worker	  save_RANLIB=$RANLIB
10974*6236dae4SAndroid Build Coastguard Worker	  RANLIB=:
10975*6236dae4SAndroid Build Coastguard Worker	  objlist=
10976*6236dae4SAndroid Build Coastguard Worker	  concat_cmds=
10977*6236dae4SAndroid Build Coastguard Worker	  save_oldobjs=$oldobjs
10978*6236dae4SAndroid Build Coastguard Worker	  oldobjs=
10979*6236dae4SAndroid Build Coastguard Worker	  # Is there a better way of finding the last object in the list?
10980*6236dae4SAndroid Build Coastguard Worker	  for obj in $save_oldobjs
10981*6236dae4SAndroid Build Coastguard Worker	  do
10982*6236dae4SAndroid Build Coastguard Worker	    last_oldobj=$obj
10983*6236dae4SAndroid Build Coastguard Worker	  done
10984*6236dae4SAndroid Build Coastguard Worker	  eval test_cmds=\"$old_archive_cmds\"
10985*6236dae4SAndroid Build Coastguard Worker	  func_len " $test_cmds"
10986*6236dae4SAndroid Build Coastguard Worker	  len0=$func_len_result
10987*6236dae4SAndroid Build Coastguard Worker	  len=$len0
10988*6236dae4SAndroid Build Coastguard Worker	  for obj in $save_oldobjs
10989*6236dae4SAndroid Build Coastguard Worker	  do
10990*6236dae4SAndroid Build Coastguard Worker	    func_len " $obj"
10991*6236dae4SAndroid Build Coastguard Worker	    func_arith $len + $func_len_result
10992*6236dae4SAndroid Build Coastguard Worker	    len=$func_arith_result
10993*6236dae4SAndroid Build Coastguard Worker	    func_append objlist " $obj"
10994*6236dae4SAndroid Build Coastguard Worker	    if test "$len" -lt "$max_cmd_len"; then
10995*6236dae4SAndroid Build Coastguard Worker	      :
10996*6236dae4SAndroid Build Coastguard Worker	    else
10997*6236dae4SAndroid Build Coastguard Worker	      # the above command should be used before it gets too long
10998*6236dae4SAndroid Build Coastguard Worker	      oldobjs=$objlist
10999*6236dae4SAndroid Build Coastguard Worker	      if test "$obj" = "$last_oldobj"; then
11000*6236dae4SAndroid Build Coastguard Worker		RANLIB=$save_RANLIB
11001*6236dae4SAndroid Build Coastguard Worker	      fi
11002*6236dae4SAndroid Build Coastguard Worker	      test -z "$concat_cmds" || concat_cmds=$concat_cmds~
11003*6236dae4SAndroid Build Coastguard Worker	      eval concat_cmds=\"\$concat_cmds$old_archive_cmds\"
11004*6236dae4SAndroid Build Coastguard Worker	      objlist=
11005*6236dae4SAndroid Build Coastguard Worker	      len=$len0
11006*6236dae4SAndroid Build Coastguard Worker	    fi
11007*6236dae4SAndroid Build Coastguard Worker	  done
11008*6236dae4SAndroid Build Coastguard Worker	  RANLIB=$save_RANLIB
11009*6236dae4SAndroid Build Coastguard Worker	  oldobjs=$objlist
11010*6236dae4SAndroid Build Coastguard Worker	  if test -z "$oldobjs"; then
11011*6236dae4SAndroid Build Coastguard Worker	    eval cmds=\"\$concat_cmds\"
11012*6236dae4SAndroid Build Coastguard Worker	  else
11013*6236dae4SAndroid Build Coastguard Worker	    eval cmds=\"\$concat_cmds~\$old_archive_cmds\"
11014*6236dae4SAndroid Build Coastguard Worker	  fi
11015*6236dae4SAndroid Build Coastguard Worker	fi
11016*6236dae4SAndroid Build Coastguard Worker      fi
11017*6236dae4SAndroid Build Coastguard Worker      func_execute_cmds "$cmds" 'exit $?'
11018*6236dae4SAndroid Build Coastguard Worker    done
11019*6236dae4SAndroid Build Coastguard Worker
11020*6236dae4SAndroid Build Coastguard Worker    test -n "$generated" && \
11021*6236dae4SAndroid Build Coastguard Worker      func_show_eval "${RM}r$generated"
11022*6236dae4SAndroid Build Coastguard Worker
11023*6236dae4SAndroid Build Coastguard Worker    # Now create the libtool archive.
11024*6236dae4SAndroid Build Coastguard Worker    case $output in
11025*6236dae4SAndroid Build Coastguard Worker    *.la)
11026*6236dae4SAndroid Build Coastguard Worker      old_library=
11027*6236dae4SAndroid Build Coastguard Worker      test yes = "$build_old_libs" && old_library=$libname.$libext
11028*6236dae4SAndroid Build Coastguard Worker      func_verbose "creating $output"
11029*6236dae4SAndroid Build Coastguard Worker
11030*6236dae4SAndroid Build Coastguard Worker      # Preserve any variables that may affect compiler behavior
11031*6236dae4SAndroid Build Coastguard Worker      for var in $variables_saved_for_relink; do
11032*6236dae4SAndroid Build Coastguard Worker	if eval test -z \"\${$var+set}\"; then
11033*6236dae4SAndroid Build Coastguard Worker	  relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command"
11034*6236dae4SAndroid Build Coastguard Worker	elif eval var_value=\$$var; test -z "$var_value"; then
11035*6236dae4SAndroid Build Coastguard Worker	  relink_command="$var=; export $var; $relink_command"
11036*6236dae4SAndroid Build Coastguard Worker	else
11037*6236dae4SAndroid Build Coastguard Worker	  func_quote_arg pretty,unquoted "$var_value"
11038*6236dae4SAndroid Build Coastguard Worker	  relink_command="$var=$func_quote_arg_unquoted_result; export $var; $relink_command"
11039*6236dae4SAndroid Build Coastguard Worker	fi
11040*6236dae4SAndroid Build Coastguard Worker      done
11041*6236dae4SAndroid Build Coastguard Worker      # Quote the link command for shipping.
11042*6236dae4SAndroid Build Coastguard Worker      func_quote eval cd "`pwd`"
11043*6236dae4SAndroid Build Coastguard Worker      relink_command="($func_quote_result; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
11044*6236dae4SAndroid Build Coastguard Worker      func_quote_arg pretty,unquoted "$relink_command"
11045*6236dae4SAndroid Build Coastguard Worker      relink_command=$func_quote_arg_unquoted_result
11046*6236dae4SAndroid Build Coastguard Worker      if test yes = "$hardcode_automatic"; then
11047*6236dae4SAndroid Build Coastguard Worker	relink_command=
11048*6236dae4SAndroid Build Coastguard Worker      fi
11049*6236dae4SAndroid Build Coastguard Worker
11050*6236dae4SAndroid Build Coastguard Worker      # Only create the output if not a dry run.
11051*6236dae4SAndroid Build Coastguard Worker      $opt_dry_run || {
11052*6236dae4SAndroid Build Coastguard Worker	for installed in no yes; do
11053*6236dae4SAndroid Build Coastguard Worker	  if test yes = "$installed"; then
11054*6236dae4SAndroid Build Coastguard Worker	    if test -z "$install_libdir"; then
11055*6236dae4SAndroid Build Coastguard Worker	      break
11056*6236dae4SAndroid Build Coastguard Worker	    fi
11057*6236dae4SAndroid Build Coastguard Worker	    output=$output_objdir/${outputname}i
11058*6236dae4SAndroid Build Coastguard Worker	    # Replace all uninstalled libtool libraries with the installed ones
11059*6236dae4SAndroid Build Coastguard Worker	    newdependency_libs=
11060*6236dae4SAndroid Build Coastguard Worker	    for deplib in $dependency_libs; do
11061*6236dae4SAndroid Build Coastguard Worker	      case $deplib in
11062*6236dae4SAndroid Build Coastguard Worker	      *.la)
11063*6236dae4SAndroid Build Coastguard Worker		func_basename "$deplib"
11064*6236dae4SAndroid Build Coastguard Worker		name=$func_basename_result
11065*6236dae4SAndroid Build Coastguard Worker		func_resolve_sysroot "$deplib"
11066*6236dae4SAndroid Build Coastguard Worker		eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result`
11067*6236dae4SAndroid Build Coastguard Worker		test -z "$libdir" && \
11068*6236dae4SAndroid Build Coastguard Worker		  func_fatal_error "'$deplib' is not a valid libtool archive"
11069*6236dae4SAndroid Build Coastguard Worker		func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name"
11070*6236dae4SAndroid Build Coastguard Worker		;;
11071*6236dae4SAndroid Build Coastguard Worker	      -L*)
11072*6236dae4SAndroid Build Coastguard Worker		func_stripname -L '' "$deplib"
11073*6236dae4SAndroid Build Coastguard Worker		func_replace_sysroot "$func_stripname_result"
11074*6236dae4SAndroid Build Coastguard Worker		func_append newdependency_libs " -L$func_replace_sysroot_result"
11075*6236dae4SAndroid Build Coastguard Worker		;;
11076*6236dae4SAndroid Build Coastguard Worker	      -R*)
11077*6236dae4SAndroid Build Coastguard Worker		func_stripname -R '' "$deplib"
11078*6236dae4SAndroid Build Coastguard Worker		func_replace_sysroot "$func_stripname_result"
11079*6236dae4SAndroid Build Coastguard Worker		func_append newdependency_libs " -R$func_replace_sysroot_result"
11080*6236dae4SAndroid Build Coastguard Worker		;;
11081*6236dae4SAndroid Build Coastguard Worker	      *) func_append newdependency_libs " $deplib" ;;
11082*6236dae4SAndroid Build Coastguard Worker	      esac
11083*6236dae4SAndroid Build Coastguard Worker	    done
11084*6236dae4SAndroid Build Coastguard Worker	    dependency_libs=$newdependency_libs
11085*6236dae4SAndroid Build Coastguard Worker	    newdlfiles=
11086*6236dae4SAndroid Build Coastguard Worker
11087*6236dae4SAndroid Build Coastguard Worker	    for lib in $dlfiles; do
11088*6236dae4SAndroid Build Coastguard Worker	      case $lib in
11089*6236dae4SAndroid Build Coastguard Worker	      *.la)
11090*6236dae4SAndroid Build Coastguard Worker	        func_basename "$lib"
11091*6236dae4SAndroid Build Coastguard Worker		name=$func_basename_result
11092*6236dae4SAndroid Build Coastguard Worker		eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
11093*6236dae4SAndroid Build Coastguard Worker		test -z "$libdir" && \
11094*6236dae4SAndroid Build Coastguard Worker		  func_fatal_error "'$lib' is not a valid libtool archive"
11095*6236dae4SAndroid Build Coastguard Worker		func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name"
11096*6236dae4SAndroid Build Coastguard Worker		;;
11097*6236dae4SAndroid Build Coastguard Worker	      *) func_append newdlfiles " $lib" ;;
11098*6236dae4SAndroid Build Coastguard Worker	      esac
11099*6236dae4SAndroid Build Coastguard Worker	    done
11100*6236dae4SAndroid Build Coastguard Worker	    dlfiles=$newdlfiles
11101*6236dae4SAndroid Build Coastguard Worker	    newdlprefiles=
11102*6236dae4SAndroid Build Coastguard Worker	    for lib in $dlprefiles; do
11103*6236dae4SAndroid Build Coastguard Worker	      case $lib in
11104*6236dae4SAndroid Build Coastguard Worker	      *.la)
11105*6236dae4SAndroid Build Coastguard Worker		# Only pass preopened files to the pseudo-archive (for
11106*6236dae4SAndroid Build Coastguard Worker		# eventual linking with the app. that links it) if we
11107*6236dae4SAndroid Build Coastguard Worker		# didn't already link the preopened objects directly into
11108*6236dae4SAndroid Build Coastguard Worker		# the library:
11109*6236dae4SAndroid Build Coastguard Worker		func_basename "$lib"
11110*6236dae4SAndroid Build Coastguard Worker		name=$func_basename_result
11111*6236dae4SAndroid Build Coastguard Worker		eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
11112*6236dae4SAndroid Build Coastguard Worker		test -z "$libdir" && \
11113*6236dae4SAndroid Build Coastguard Worker		  func_fatal_error "'$lib' is not a valid libtool archive"
11114*6236dae4SAndroid Build Coastguard Worker		func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name"
11115*6236dae4SAndroid Build Coastguard Worker		;;
11116*6236dae4SAndroid Build Coastguard Worker	      esac
11117*6236dae4SAndroid Build Coastguard Worker	    done
11118*6236dae4SAndroid Build Coastguard Worker	    dlprefiles=$newdlprefiles
11119*6236dae4SAndroid Build Coastguard Worker	  else
11120*6236dae4SAndroid Build Coastguard Worker	    newdlfiles=
11121*6236dae4SAndroid Build Coastguard Worker	    for lib in $dlfiles; do
11122*6236dae4SAndroid Build Coastguard Worker	      case $lib in
11123*6236dae4SAndroid Build Coastguard Worker		[\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;;
11124*6236dae4SAndroid Build Coastguard Worker		*) abs=`pwd`"/$lib" ;;
11125*6236dae4SAndroid Build Coastguard Worker	      esac
11126*6236dae4SAndroid Build Coastguard Worker	      func_append newdlfiles " $abs"
11127*6236dae4SAndroid Build Coastguard Worker	    done
11128*6236dae4SAndroid Build Coastguard Worker	    dlfiles=$newdlfiles
11129*6236dae4SAndroid Build Coastguard Worker	    newdlprefiles=
11130*6236dae4SAndroid Build Coastguard Worker	    for lib in $dlprefiles; do
11131*6236dae4SAndroid Build Coastguard Worker	      case $lib in
11132*6236dae4SAndroid Build Coastguard Worker		[\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;;
11133*6236dae4SAndroid Build Coastguard Worker		*) abs=`pwd`"/$lib" ;;
11134*6236dae4SAndroid Build Coastguard Worker	      esac
11135*6236dae4SAndroid Build Coastguard Worker	      func_append newdlprefiles " $abs"
11136*6236dae4SAndroid Build Coastguard Worker	    done
11137*6236dae4SAndroid Build Coastguard Worker	    dlprefiles=$newdlprefiles
11138*6236dae4SAndroid Build Coastguard Worker	  fi
11139*6236dae4SAndroid Build Coastguard Worker	  $RM $output
11140*6236dae4SAndroid Build Coastguard Worker	  # place dlname in correct position for cygwin
11141*6236dae4SAndroid Build Coastguard Worker	  # In fact, it would be nice if we could use this code for all target
11142*6236dae4SAndroid Build Coastguard Worker	  # systems that can't hard-code library paths into their executables
11143*6236dae4SAndroid Build Coastguard Worker	  # and that have no shared library path variable independent of PATH,
11144*6236dae4SAndroid Build Coastguard Worker	  # but it turns out we can't easily determine that from inspecting
11145*6236dae4SAndroid Build Coastguard Worker	  # libtool variables, so we have to hard-code the OSs to which it
11146*6236dae4SAndroid Build Coastguard Worker	  # applies here; at the moment, that means platforms that use the PE
11147*6236dae4SAndroid Build Coastguard Worker	  # object format with DLL files.  See the long comment at the top of
11148*6236dae4SAndroid Build Coastguard Worker	  # tests/bindir.at for full details.
11149*6236dae4SAndroid Build Coastguard Worker	  tdlname=$dlname
11150*6236dae4SAndroid Build Coastguard Worker	  case $host,$output,$installed,$module,$dlname in
11151*6236dae4SAndroid Build Coastguard Worker	    *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll)
11152*6236dae4SAndroid Build Coastguard Worker	      # If a -bindir argument was supplied, place the dll there.
11153*6236dae4SAndroid Build Coastguard Worker	      if test -n "$bindir"; then
11154*6236dae4SAndroid Build Coastguard Worker		func_relative_path "$install_libdir" "$bindir"
11155*6236dae4SAndroid Build Coastguard Worker		tdlname=$func_relative_path_result/$dlname
11156*6236dae4SAndroid Build Coastguard Worker	      else
11157*6236dae4SAndroid Build Coastguard Worker		# Otherwise fall back on heuristic.
11158*6236dae4SAndroid Build Coastguard Worker		tdlname=../bin/$dlname
11159*6236dae4SAndroid Build Coastguard Worker	      fi
11160*6236dae4SAndroid Build Coastguard Worker	      ;;
11161*6236dae4SAndroid Build Coastguard Worker	  esac
11162*6236dae4SAndroid Build Coastguard Worker	  $ECHO > $output "\
11163*6236dae4SAndroid Build Coastguard Worker# $outputname - a libtool library file
11164*6236dae4SAndroid Build Coastguard Worker# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
11165*6236dae4SAndroid Build Coastguard Worker#
11166*6236dae4SAndroid Build Coastguard Worker# Please DO NOT delete this file!
11167*6236dae4SAndroid Build Coastguard Worker# It is necessary for linking the library.
11168*6236dae4SAndroid Build Coastguard Worker
11169*6236dae4SAndroid Build Coastguard Worker# The name that we can dlopen(3).
11170*6236dae4SAndroid Build Coastguard Workerdlname='$tdlname'
11171*6236dae4SAndroid Build Coastguard Worker
11172*6236dae4SAndroid Build Coastguard Worker# Names of this library.
11173*6236dae4SAndroid Build Coastguard Workerlibrary_names='$library_names'
11174*6236dae4SAndroid Build Coastguard Worker
11175*6236dae4SAndroid Build Coastguard Worker# The name of the static archive.
11176*6236dae4SAndroid Build Coastguard Workerold_library='$old_library'
11177*6236dae4SAndroid Build Coastguard Worker
11178*6236dae4SAndroid Build Coastguard Worker# Linker flags that cannot go in dependency_libs.
11179*6236dae4SAndroid Build Coastguard Workerinherited_linker_flags='$new_inherited_linker_flags'
11180*6236dae4SAndroid Build Coastguard Worker
11181*6236dae4SAndroid Build Coastguard Worker# Libraries that this one depends upon.
11182*6236dae4SAndroid Build Coastguard Workerdependency_libs='$dependency_libs'
11183*6236dae4SAndroid Build Coastguard Worker
11184*6236dae4SAndroid Build Coastguard Worker# Names of additional weak libraries provided by this library
11185*6236dae4SAndroid Build Coastguard Workerweak_library_names='$weak_libs'
11186*6236dae4SAndroid Build Coastguard Worker
11187*6236dae4SAndroid Build Coastguard Worker# Version information for $libname.
11188*6236dae4SAndroid Build Coastguard Workercurrent=$current
11189*6236dae4SAndroid Build Coastguard Workerage=$age
11190*6236dae4SAndroid Build Coastguard Workerrevision=$revision
11191*6236dae4SAndroid Build Coastguard Worker
11192*6236dae4SAndroid Build Coastguard Worker# Is this an already installed library?
11193*6236dae4SAndroid Build Coastguard Workerinstalled=$installed
11194*6236dae4SAndroid Build Coastguard Worker
11195*6236dae4SAndroid Build Coastguard Worker# Should we warn about portability when linking against -modules?
11196*6236dae4SAndroid Build Coastguard Workershouldnotlink=$module
11197*6236dae4SAndroid Build Coastguard Worker
11198*6236dae4SAndroid Build Coastguard Worker# Files to dlopen/dlpreopen
11199*6236dae4SAndroid Build Coastguard Workerdlopen='$dlfiles'
11200*6236dae4SAndroid Build Coastguard Workerdlpreopen='$dlprefiles'
11201*6236dae4SAndroid Build Coastguard Worker
11202*6236dae4SAndroid Build Coastguard Worker# Directory that this library needs to be installed in:
11203*6236dae4SAndroid Build Coastguard Workerlibdir='$install_libdir'"
11204*6236dae4SAndroid Build Coastguard Worker	  if test no,yes = "$installed,$need_relink"; then
11205*6236dae4SAndroid Build Coastguard Worker	    $ECHO >> $output "\
11206*6236dae4SAndroid Build Coastguard Workerrelink_command=\"$relink_command\""
11207*6236dae4SAndroid Build Coastguard Worker	  fi
11208*6236dae4SAndroid Build Coastguard Worker	done
11209*6236dae4SAndroid Build Coastguard Worker      }
11210*6236dae4SAndroid Build Coastguard Worker
11211*6236dae4SAndroid Build Coastguard Worker      # Do a symbolic link so that the libtool archive can be found in
11212*6236dae4SAndroid Build Coastguard Worker      # LD_LIBRARY_PATH before the program is installed.
11213*6236dae4SAndroid Build Coastguard Worker      func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?'
11214*6236dae4SAndroid Build Coastguard Worker      ;;
11215*6236dae4SAndroid Build Coastguard Worker    esac
11216*6236dae4SAndroid Build Coastguard Worker    exit $EXIT_SUCCESS
11217*6236dae4SAndroid Build Coastguard Worker}
11218*6236dae4SAndroid Build Coastguard Worker
11219*6236dae4SAndroid Build Coastguard Workerif test link = "$opt_mode" || test relink = "$opt_mode"; then
11220*6236dae4SAndroid Build Coastguard Worker  func_mode_link ${1+"$@"}
11221*6236dae4SAndroid Build Coastguard Workerfi
11222*6236dae4SAndroid Build Coastguard Worker
11223*6236dae4SAndroid Build Coastguard Worker
11224*6236dae4SAndroid Build Coastguard Worker# func_mode_uninstall arg...
11225*6236dae4SAndroid Build Coastguard Workerfunc_mode_uninstall ()
11226*6236dae4SAndroid Build Coastguard Worker{
11227*6236dae4SAndroid Build Coastguard Worker    $debug_cmd
11228*6236dae4SAndroid Build Coastguard Worker
11229*6236dae4SAndroid Build Coastguard Worker    RM=$nonopt
11230*6236dae4SAndroid Build Coastguard Worker    files=
11231*6236dae4SAndroid Build Coastguard Worker    rmforce=false
11232*6236dae4SAndroid Build Coastguard Worker    exit_status=0
11233*6236dae4SAndroid Build Coastguard Worker
11234*6236dae4SAndroid Build Coastguard Worker    # This variable tells wrapper scripts just to set variables rather
11235*6236dae4SAndroid Build Coastguard Worker    # than running their programs.
11236*6236dae4SAndroid Build Coastguard Worker    libtool_install_magic=$magic
11237*6236dae4SAndroid Build Coastguard Worker
11238*6236dae4SAndroid Build Coastguard Worker    for arg
11239*6236dae4SAndroid Build Coastguard Worker    do
11240*6236dae4SAndroid Build Coastguard Worker      case $arg in
11241*6236dae4SAndroid Build Coastguard Worker      -f) func_append RM " $arg"; rmforce=: ;;
11242*6236dae4SAndroid Build Coastguard Worker      -*) func_append RM " $arg" ;;
11243*6236dae4SAndroid Build Coastguard Worker      *) func_append files " $arg" ;;
11244*6236dae4SAndroid Build Coastguard Worker      esac
11245*6236dae4SAndroid Build Coastguard Worker    done
11246*6236dae4SAndroid Build Coastguard Worker
11247*6236dae4SAndroid Build Coastguard Worker    test -z "$RM" && \
11248*6236dae4SAndroid Build Coastguard Worker      func_fatal_help "you must specify an RM program"
11249*6236dae4SAndroid Build Coastguard Worker
11250*6236dae4SAndroid Build Coastguard Worker    rmdirs=
11251*6236dae4SAndroid Build Coastguard Worker
11252*6236dae4SAndroid Build Coastguard Worker    for file in $files; do
11253*6236dae4SAndroid Build Coastguard Worker      func_dirname "$file" "" "."
11254*6236dae4SAndroid Build Coastguard Worker      dir=$func_dirname_result
11255*6236dae4SAndroid Build Coastguard Worker      if test . = "$dir"; then
11256*6236dae4SAndroid Build Coastguard Worker	odir=$objdir
11257*6236dae4SAndroid Build Coastguard Worker      else
11258*6236dae4SAndroid Build Coastguard Worker	odir=$dir/$objdir
11259*6236dae4SAndroid Build Coastguard Worker      fi
11260*6236dae4SAndroid Build Coastguard Worker      func_basename "$file"
11261*6236dae4SAndroid Build Coastguard Worker      name=$func_basename_result
11262*6236dae4SAndroid Build Coastguard Worker      test uninstall = "$opt_mode" && odir=$dir
11263*6236dae4SAndroid Build Coastguard Worker
11264*6236dae4SAndroid Build Coastguard Worker      # Remember odir for removal later, being careful to avoid duplicates
11265*6236dae4SAndroid Build Coastguard Worker      if test clean = "$opt_mode"; then
11266*6236dae4SAndroid Build Coastguard Worker	case " $rmdirs " in
11267*6236dae4SAndroid Build Coastguard Worker	  *" $odir "*) ;;
11268*6236dae4SAndroid Build Coastguard Worker	  *) func_append rmdirs " $odir" ;;
11269*6236dae4SAndroid Build Coastguard Worker	esac
11270*6236dae4SAndroid Build Coastguard Worker      fi
11271*6236dae4SAndroid Build Coastguard Worker
11272*6236dae4SAndroid Build Coastguard Worker      # Don't error if the file doesn't exist and rm -f was used.
11273*6236dae4SAndroid Build Coastguard Worker      if { test -L "$file"; } >/dev/null 2>&1 ||
11274*6236dae4SAndroid Build Coastguard Worker	 { test -h "$file"; } >/dev/null 2>&1 ||
11275*6236dae4SAndroid Build Coastguard Worker	 test -f "$file"; then
11276*6236dae4SAndroid Build Coastguard Worker	:
11277*6236dae4SAndroid Build Coastguard Worker      elif test -d "$file"; then
11278*6236dae4SAndroid Build Coastguard Worker	exit_status=1
11279*6236dae4SAndroid Build Coastguard Worker	continue
11280*6236dae4SAndroid Build Coastguard Worker      elif $rmforce; then
11281*6236dae4SAndroid Build Coastguard Worker	continue
11282*6236dae4SAndroid Build Coastguard Worker      fi
11283*6236dae4SAndroid Build Coastguard Worker
11284*6236dae4SAndroid Build Coastguard Worker      rmfiles=$file
11285*6236dae4SAndroid Build Coastguard Worker
11286*6236dae4SAndroid Build Coastguard Worker      case $name in
11287*6236dae4SAndroid Build Coastguard Worker      *.la)
11288*6236dae4SAndroid Build Coastguard Worker	# Possibly a libtool archive, so verify it.
11289*6236dae4SAndroid Build Coastguard Worker	if func_lalib_p "$file"; then
11290*6236dae4SAndroid Build Coastguard Worker	  func_source $dir/$name
11291*6236dae4SAndroid Build Coastguard Worker
11292*6236dae4SAndroid Build Coastguard Worker	  # Delete the libtool libraries and symlinks.
11293*6236dae4SAndroid Build Coastguard Worker	  for n in $library_names; do
11294*6236dae4SAndroid Build Coastguard Worker	    func_append rmfiles " $odir/$n"
11295*6236dae4SAndroid Build Coastguard Worker	  done
11296*6236dae4SAndroid Build Coastguard Worker	  test -n "$old_library" && func_append rmfiles " $odir/$old_library"
11297*6236dae4SAndroid Build Coastguard Worker
11298*6236dae4SAndroid Build Coastguard Worker	  case $opt_mode in
11299*6236dae4SAndroid Build Coastguard Worker	  clean)
11300*6236dae4SAndroid Build Coastguard Worker	    case " $library_names " in
11301*6236dae4SAndroid Build Coastguard Worker	    *" $dlname "*) ;;
11302*6236dae4SAndroid Build Coastguard Worker	    *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;;
11303*6236dae4SAndroid Build Coastguard Worker	    esac
11304*6236dae4SAndroid Build Coastguard Worker	    test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i"
11305*6236dae4SAndroid Build Coastguard Worker	    ;;
11306*6236dae4SAndroid Build Coastguard Worker	  uninstall)
11307*6236dae4SAndroid Build Coastguard Worker	    if test -n "$library_names"; then
11308*6236dae4SAndroid Build Coastguard Worker	      # Do each command in the postuninstall commands.
11309*6236dae4SAndroid Build Coastguard Worker	      func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1'
11310*6236dae4SAndroid Build Coastguard Worker	    fi
11311*6236dae4SAndroid Build Coastguard Worker
11312*6236dae4SAndroid Build Coastguard Worker	    if test -n "$old_library"; then
11313*6236dae4SAndroid Build Coastguard Worker	      # Do each command in the old_postuninstall commands.
11314*6236dae4SAndroid Build Coastguard Worker	      func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1'
11315*6236dae4SAndroid Build Coastguard Worker	    fi
11316*6236dae4SAndroid Build Coastguard Worker	    # FIXME: should reinstall the best remaining shared library.
11317*6236dae4SAndroid Build Coastguard Worker	    ;;
11318*6236dae4SAndroid Build Coastguard Worker	  esac
11319*6236dae4SAndroid Build Coastguard Worker	fi
11320*6236dae4SAndroid Build Coastguard Worker	;;
11321*6236dae4SAndroid Build Coastguard Worker
11322*6236dae4SAndroid Build Coastguard Worker      *.lo)
11323*6236dae4SAndroid Build Coastguard Worker	# Possibly a libtool object, so verify it.
11324*6236dae4SAndroid Build Coastguard Worker	if func_lalib_p "$file"; then
11325*6236dae4SAndroid Build Coastguard Worker
11326*6236dae4SAndroid Build Coastguard Worker	  # Read the .lo file
11327*6236dae4SAndroid Build Coastguard Worker	  func_source $dir/$name
11328*6236dae4SAndroid Build Coastguard Worker
11329*6236dae4SAndroid Build Coastguard Worker	  # Add PIC object to the list of files to remove.
11330*6236dae4SAndroid Build Coastguard Worker	  if test -n "$pic_object" && test none != "$pic_object"; then
11331*6236dae4SAndroid Build Coastguard Worker	    func_append rmfiles " $dir/$pic_object"
11332*6236dae4SAndroid Build Coastguard Worker	  fi
11333*6236dae4SAndroid Build Coastguard Worker
11334*6236dae4SAndroid Build Coastguard Worker	  # Add non-PIC object to the list of files to remove.
11335*6236dae4SAndroid Build Coastguard Worker	  if test -n "$non_pic_object" && test none != "$non_pic_object"; then
11336*6236dae4SAndroid Build Coastguard Worker	    func_append rmfiles " $dir/$non_pic_object"
11337*6236dae4SAndroid Build Coastguard Worker	  fi
11338*6236dae4SAndroid Build Coastguard Worker	fi
11339*6236dae4SAndroid Build Coastguard Worker	;;
11340*6236dae4SAndroid Build Coastguard Worker
11341*6236dae4SAndroid Build Coastguard Worker      *)
11342*6236dae4SAndroid Build Coastguard Worker	if test clean = "$opt_mode"; then
11343*6236dae4SAndroid Build Coastguard Worker	  noexename=$name
11344*6236dae4SAndroid Build Coastguard Worker	  case $file in
11345*6236dae4SAndroid Build Coastguard Worker	  *.exe)
11346*6236dae4SAndroid Build Coastguard Worker	    func_stripname '' '.exe' "$file"
11347*6236dae4SAndroid Build Coastguard Worker	    file=$func_stripname_result
11348*6236dae4SAndroid Build Coastguard Worker	    func_stripname '' '.exe' "$name"
11349*6236dae4SAndroid Build Coastguard Worker	    noexename=$func_stripname_result
11350*6236dae4SAndroid Build Coastguard Worker	    # $file with .exe has already been added to rmfiles,
11351*6236dae4SAndroid Build Coastguard Worker	    # add $file without .exe
11352*6236dae4SAndroid Build Coastguard Worker	    func_append rmfiles " $file"
11353*6236dae4SAndroid Build Coastguard Worker	    ;;
11354*6236dae4SAndroid Build Coastguard Worker	  esac
11355*6236dae4SAndroid Build Coastguard Worker	  # Do a test to see if this is a libtool program.
11356*6236dae4SAndroid Build Coastguard Worker	  if func_ltwrapper_p "$file"; then
11357*6236dae4SAndroid Build Coastguard Worker	    if func_ltwrapper_executable_p "$file"; then
11358*6236dae4SAndroid Build Coastguard Worker	      func_ltwrapper_scriptname "$file"
11359*6236dae4SAndroid Build Coastguard Worker	      relink_command=
11360*6236dae4SAndroid Build Coastguard Worker	      func_source $func_ltwrapper_scriptname_result
11361*6236dae4SAndroid Build Coastguard Worker	      func_append rmfiles " $func_ltwrapper_scriptname_result"
11362*6236dae4SAndroid Build Coastguard Worker	    else
11363*6236dae4SAndroid Build Coastguard Worker	      relink_command=
11364*6236dae4SAndroid Build Coastguard Worker	      func_source $dir/$noexename
11365*6236dae4SAndroid Build Coastguard Worker	    fi
11366*6236dae4SAndroid Build Coastguard Worker
11367*6236dae4SAndroid Build Coastguard Worker	    # note $name still contains .exe if it was in $file originally
11368*6236dae4SAndroid Build Coastguard Worker	    # as does the version of $file that was added into $rmfiles
11369*6236dae4SAndroid Build Coastguard Worker	    func_append rmfiles " $odir/$name $odir/${name}S.$objext"
11370*6236dae4SAndroid Build Coastguard Worker	    if test yes = "$fast_install" && test -n "$relink_command"; then
11371*6236dae4SAndroid Build Coastguard Worker	      func_append rmfiles " $odir/lt-$name"
11372*6236dae4SAndroid Build Coastguard Worker	    fi
11373*6236dae4SAndroid Build Coastguard Worker	    if test "X$noexename" != "X$name"; then
11374*6236dae4SAndroid Build Coastguard Worker	      func_append rmfiles " $odir/lt-$noexename.c"
11375*6236dae4SAndroid Build Coastguard Worker	    fi
11376*6236dae4SAndroid Build Coastguard Worker	  fi
11377*6236dae4SAndroid Build Coastguard Worker	fi
11378*6236dae4SAndroid Build Coastguard Worker	;;
11379*6236dae4SAndroid Build Coastguard Worker      esac
11380*6236dae4SAndroid Build Coastguard Worker      func_show_eval "$RM $rmfiles" 'exit_status=1'
11381*6236dae4SAndroid Build Coastguard Worker    done
11382*6236dae4SAndroid Build Coastguard Worker
11383*6236dae4SAndroid Build Coastguard Worker    # Try to remove the $objdir's in the directories where we deleted files
11384*6236dae4SAndroid Build Coastguard Worker    for dir in $rmdirs; do
11385*6236dae4SAndroid Build Coastguard Worker      if test -d "$dir"; then
11386*6236dae4SAndroid Build Coastguard Worker	func_show_eval "rmdir $dir >/dev/null 2>&1"
11387*6236dae4SAndroid Build Coastguard Worker      fi
11388*6236dae4SAndroid Build Coastguard Worker    done
11389*6236dae4SAndroid Build Coastguard Worker
11390*6236dae4SAndroid Build Coastguard Worker    exit $exit_status
11391*6236dae4SAndroid Build Coastguard Worker}
11392*6236dae4SAndroid Build Coastguard Worker
11393*6236dae4SAndroid Build Coastguard Workerif test uninstall = "$opt_mode" || test clean = "$opt_mode"; then
11394*6236dae4SAndroid Build Coastguard Worker  func_mode_uninstall ${1+"$@"}
11395*6236dae4SAndroid Build Coastguard Workerfi
11396*6236dae4SAndroid Build Coastguard Worker
11397*6236dae4SAndroid Build Coastguard Workertest -z "$opt_mode" && {
11398*6236dae4SAndroid Build Coastguard Worker  help=$generic_help
11399*6236dae4SAndroid Build Coastguard Worker  func_fatal_help "you must specify a MODE"
11400*6236dae4SAndroid Build Coastguard Worker}
11401*6236dae4SAndroid Build Coastguard Worker
11402*6236dae4SAndroid Build Coastguard Workertest -z "$exec_cmd" && \
11403*6236dae4SAndroid Build Coastguard Worker  func_fatal_help "invalid operation mode '$opt_mode'"
11404*6236dae4SAndroid Build Coastguard Worker
11405*6236dae4SAndroid Build Coastguard Workerif test -n "$exec_cmd"; then
11406*6236dae4SAndroid Build Coastguard Worker  eval exec "$exec_cmd"
11407*6236dae4SAndroid Build Coastguard Worker  exit $EXIT_FAILURE
11408*6236dae4SAndroid Build Coastguard Workerfi
11409*6236dae4SAndroid Build Coastguard Worker
11410*6236dae4SAndroid Build Coastguard Workerexit $exit_status
11411*6236dae4SAndroid Build Coastguard Worker
11412*6236dae4SAndroid Build Coastguard Worker
11413*6236dae4SAndroid Build Coastguard Worker# The TAGs below are defined such that we never get into a situation
11414*6236dae4SAndroid Build Coastguard Worker# where we disable both kinds of libraries.  Given conflicting
11415*6236dae4SAndroid Build Coastguard Worker# choices, we go for a static library, that is the most portable,
11416*6236dae4SAndroid Build Coastguard Worker# since we can't tell whether shared libraries were disabled because
11417*6236dae4SAndroid Build Coastguard Worker# the user asked for that or because the platform doesn't support
11418*6236dae4SAndroid Build Coastguard Worker# them.  This is particularly important on AIX, because we don't
11419*6236dae4SAndroid Build Coastguard Worker# support having both static and shared libraries enabled at the same
11420*6236dae4SAndroid Build Coastguard Worker# time on that platform, so we default to a shared-only configuration.
11421*6236dae4SAndroid Build Coastguard Worker# If a disable-shared tag is given, we'll fallback to a static-only
11422*6236dae4SAndroid Build Coastguard Worker# configuration.  But we'll never go from static-only to shared-only.
11423*6236dae4SAndroid Build Coastguard Worker
11424*6236dae4SAndroid Build Coastguard Worker# ### BEGIN LIBTOOL TAG CONFIG: disable-shared
11425*6236dae4SAndroid Build Coastguard Workerbuild_libtool_libs=no
11426*6236dae4SAndroid Build Coastguard Workerbuild_old_libs=yes
11427*6236dae4SAndroid Build Coastguard Worker# ### END LIBTOOL TAG CONFIG: disable-shared
11428*6236dae4SAndroid Build Coastguard Worker
11429*6236dae4SAndroid Build Coastguard Worker# ### BEGIN LIBTOOL TAG CONFIG: disable-static
11430*6236dae4SAndroid Build Coastguard Workerbuild_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac`
11431*6236dae4SAndroid Build Coastguard Worker# ### END LIBTOOL TAG CONFIG: disable-static
11432*6236dae4SAndroid Build Coastguard Worker
11433*6236dae4SAndroid Build Coastguard Worker# Local Variables:
11434*6236dae4SAndroid Build Coastguard Worker# mode:shell-script
11435*6236dae4SAndroid Build Coastguard Worker# sh-indentation:2
11436*6236dae4SAndroid Build Coastguard Worker# End:
11437