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='[0m' 539*6236dae4SAndroid Build Coastguard Worker tc_bold='[1m'; tc_standout='[7m' 540*6236dae4SAndroid Build Coastguard Worker tc_red='[31m'; tc_green='[32m' 541*6236dae4SAndroid Build Coastguard Worker tc_blue='[34m'; tc_cyan='[36m' 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 *) <_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