1*6236dae4SAndroid Build Coastguard Worker#! /bin/sh 2*6236dae4SAndroid Build Coastguard Worker# depcomp - compile a program generating dependencies as side-effects 3*6236dae4SAndroid Build Coastguard Worker 4*6236dae4SAndroid Build Coastguard Workerscriptversion=2018-03-07.03; # UTC 5*6236dae4SAndroid Build Coastguard Worker 6*6236dae4SAndroid Build Coastguard Worker# Copyright (C) 1999-2021 Free Software Foundation, Inc. 7*6236dae4SAndroid Build Coastguard Worker 8*6236dae4SAndroid Build Coastguard Worker# This program is free software; you can redistribute it and/or modify 9*6236dae4SAndroid Build Coastguard Worker# it under the terms of the GNU General Public License as published by 10*6236dae4SAndroid Build Coastguard Worker# the Free Software Foundation; either version 2, or (at your option) 11*6236dae4SAndroid Build Coastguard Worker# any later version. 12*6236dae4SAndroid Build Coastguard Worker 13*6236dae4SAndroid Build Coastguard Worker# This program is distributed in the hope that it will be useful, 14*6236dae4SAndroid Build Coastguard Worker# but WITHOUT ANY WARRANTY; without even the implied warranty of 15*6236dae4SAndroid Build Coastguard Worker# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16*6236dae4SAndroid Build Coastguard Worker# GNU General Public License for more details. 17*6236dae4SAndroid Build Coastguard Worker 18*6236dae4SAndroid Build Coastguard Worker# You should have received a copy of the GNU General Public License 19*6236dae4SAndroid Build Coastguard Worker# along with this program. If not, see <https://www.gnu.org/licenses/>. 20*6236dae4SAndroid Build Coastguard Worker 21*6236dae4SAndroid Build Coastguard Worker# As a special exception to the GNU General Public License, if you 22*6236dae4SAndroid Build Coastguard Worker# distribute this file as part of a program that contains a 23*6236dae4SAndroid Build Coastguard Worker# configuration script generated by Autoconf, you may include it under 24*6236dae4SAndroid Build Coastguard Worker# the same distribution terms that you use for the rest of that program. 25*6236dae4SAndroid Build Coastguard Worker 26*6236dae4SAndroid Build Coastguard Worker# Originally written by Alexandre Oliva <[email protected]>. 27*6236dae4SAndroid Build Coastguard Worker 28*6236dae4SAndroid Build Coastguard Workercase $1 in 29*6236dae4SAndroid Build Coastguard Worker '') 30*6236dae4SAndroid Build Coastguard Worker echo "$0: No command. Try '$0 --help' for more information." 1>&2 31*6236dae4SAndroid Build Coastguard Worker exit 1; 32*6236dae4SAndroid Build Coastguard Worker ;; 33*6236dae4SAndroid Build Coastguard Worker -h | --h*) 34*6236dae4SAndroid Build Coastguard Worker cat <<\EOF 35*6236dae4SAndroid Build Coastguard WorkerUsage: depcomp [--help] [--version] PROGRAM [ARGS] 36*6236dae4SAndroid Build Coastguard Worker 37*6236dae4SAndroid Build Coastguard WorkerRun PROGRAMS ARGS to compile a file, generating dependencies 38*6236dae4SAndroid Build Coastguard Workeras side-effects. 39*6236dae4SAndroid Build Coastguard Worker 40*6236dae4SAndroid Build Coastguard WorkerEnvironment variables: 41*6236dae4SAndroid Build Coastguard Worker depmode Dependency tracking mode. 42*6236dae4SAndroid Build Coastguard Worker source Source file read by 'PROGRAMS ARGS'. 43*6236dae4SAndroid Build Coastguard Worker object Object file output by 'PROGRAMS ARGS'. 44*6236dae4SAndroid Build Coastguard Worker DEPDIR directory where to store dependencies. 45*6236dae4SAndroid Build Coastguard Worker depfile Dependency file to output. 46*6236dae4SAndroid Build Coastguard Worker tmpdepfile Temporary file to use when outputting dependencies. 47*6236dae4SAndroid Build Coastguard Worker libtool Whether libtool is used (yes/no). 48*6236dae4SAndroid Build Coastguard Worker 49*6236dae4SAndroid Build Coastguard WorkerReport bugs to <bug-automake@gnu.org>. 50*6236dae4SAndroid Build Coastguard WorkerEOF 51*6236dae4SAndroid Build Coastguard Worker exit $? 52*6236dae4SAndroid Build Coastguard Worker ;; 53*6236dae4SAndroid Build Coastguard Worker -v | --v*) 54*6236dae4SAndroid Build Coastguard Worker echo "depcomp $scriptversion" 55*6236dae4SAndroid Build Coastguard Worker exit $? 56*6236dae4SAndroid Build Coastguard Worker ;; 57*6236dae4SAndroid Build Coastguard Workeresac 58*6236dae4SAndroid Build Coastguard Worker 59*6236dae4SAndroid Build Coastguard Worker# Get the directory component of the given path, and save it in the 60*6236dae4SAndroid Build Coastguard Worker# global variables '$dir'. Note that this directory component will 61*6236dae4SAndroid Build Coastguard Worker# be either empty or ending with a '/' character. This is deliberate. 62*6236dae4SAndroid Build Coastguard Workerset_dir_from () 63*6236dae4SAndroid Build Coastguard Worker{ 64*6236dae4SAndroid Build Coastguard Worker case $1 in 65*6236dae4SAndroid Build Coastguard Worker */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; 66*6236dae4SAndroid Build Coastguard Worker *) dir=;; 67*6236dae4SAndroid Build Coastguard Worker esac 68*6236dae4SAndroid Build Coastguard Worker} 69*6236dae4SAndroid Build Coastguard Worker 70*6236dae4SAndroid Build Coastguard Worker# Get the suffix-stripped basename of the given path, and save it the 71*6236dae4SAndroid Build Coastguard Worker# global variable '$base'. 72*6236dae4SAndroid Build Coastguard Workerset_base_from () 73*6236dae4SAndroid Build Coastguard Worker{ 74*6236dae4SAndroid Build Coastguard Worker base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` 75*6236dae4SAndroid Build Coastguard Worker} 76*6236dae4SAndroid Build Coastguard Worker 77*6236dae4SAndroid Build Coastguard Worker# If no dependency file was actually created by the compiler invocation, 78*6236dae4SAndroid Build Coastguard Worker# we still have to create a dummy depfile, to avoid errors with the 79*6236dae4SAndroid Build Coastguard Worker# Makefile "include basename.Plo" scheme. 80*6236dae4SAndroid Build Coastguard Workermake_dummy_depfile () 81*6236dae4SAndroid Build Coastguard Worker{ 82*6236dae4SAndroid Build Coastguard Worker echo "#dummy" > "$depfile" 83*6236dae4SAndroid Build Coastguard Worker} 84*6236dae4SAndroid Build Coastguard Worker 85*6236dae4SAndroid Build Coastguard Worker# Factor out some common post-processing of the generated depfile. 86*6236dae4SAndroid Build Coastguard Worker# Requires the auxiliary global variable '$tmpdepfile' to be set. 87*6236dae4SAndroid Build Coastguard Workeraix_post_process_depfile () 88*6236dae4SAndroid Build Coastguard Worker{ 89*6236dae4SAndroid Build Coastguard Worker # If the compiler actually managed to produce a dependency file, 90*6236dae4SAndroid Build Coastguard Worker # post-process it. 91*6236dae4SAndroid Build Coastguard Worker if test -f "$tmpdepfile"; then 92*6236dae4SAndroid Build Coastguard Worker # Each line is of the form 'foo.o: dependency.h'. 93*6236dae4SAndroid Build Coastguard Worker # Do two passes, one to just change these to 94*6236dae4SAndroid Build Coastguard Worker # $object: dependency.h 95*6236dae4SAndroid Build Coastguard Worker # and one to simply output 96*6236dae4SAndroid Build Coastguard Worker # dependency.h: 97*6236dae4SAndroid Build Coastguard Worker # which is needed to avoid the deleted-header problem. 98*6236dae4SAndroid Build Coastguard Worker { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" 99*6236dae4SAndroid Build Coastguard Worker sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" 100*6236dae4SAndroid Build Coastguard Worker } > "$depfile" 101*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 102*6236dae4SAndroid Build Coastguard Worker else 103*6236dae4SAndroid Build Coastguard Worker make_dummy_depfile 104*6236dae4SAndroid Build Coastguard Worker fi 105*6236dae4SAndroid Build Coastguard Worker} 106*6236dae4SAndroid Build Coastguard Worker 107*6236dae4SAndroid Build Coastguard Worker# A tabulation character. 108*6236dae4SAndroid Build Coastguard Workertab=' ' 109*6236dae4SAndroid Build Coastguard Worker# A newline character. 110*6236dae4SAndroid Build Coastguard Workernl=' 111*6236dae4SAndroid Build Coastguard Worker' 112*6236dae4SAndroid Build Coastguard Worker# Character ranges might be problematic outside the C locale. 113*6236dae4SAndroid Build Coastguard Worker# These definitions help. 114*6236dae4SAndroid Build Coastguard Workerupper=ABCDEFGHIJKLMNOPQRSTUVWXYZ 115*6236dae4SAndroid Build Coastguard Workerlower=abcdefghijklmnopqrstuvwxyz 116*6236dae4SAndroid Build Coastguard Workerdigits=0123456789 117*6236dae4SAndroid Build Coastguard Workeralpha=${upper}${lower} 118*6236dae4SAndroid Build Coastguard Worker 119*6236dae4SAndroid Build Coastguard Workerif test -z "$depmode" || test -z "$source" || test -z "$object"; then 120*6236dae4SAndroid Build Coastguard Worker echo "depcomp: Variables source, object and depmode must be set" 1>&2 121*6236dae4SAndroid Build Coastguard Worker exit 1 122*6236dae4SAndroid Build Coastguard Workerfi 123*6236dae4SAndroid Build Coastguard Worker 124*6236dae4SAndroid Build Coastguard Worker# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. 125*6236dae4SAndroid Build Coastguard Workerdepfile=${depfile-`echo "$object" | 126*6236dae4SAndroid Build Coastguard Worker sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} 127*6236dae4SAndroid Build Coastguard Workertmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} 128*6236dae4SAndroid Build Coastguard Worker 129*6236dae4SAndroid Build Coastguard Workerrm -f "$tmpdepfile" 130*6236dae4SAndroid Build Coastguard Worker 131*6236dae4SAndroid Build Coastguard Worker# Avoid interferences from the environment. 132*6236dae4SAndroid Build Coastguard Workergccflag= dashmflag= 133*6236dae4SAndroid Build Coastguard Worker 134*6236dae4SAndroid Build Coastguard Worker# Some modes work just like other modes, but use different flags. We 135*6236dae4SAndroid Build Coastguard Worker# parameterize here, but still list the modes in the big case below, 136*6236dae4SAndroid Build Coastguard Worker# to make depend.m4 easier to write. Note that we *cannot* use a case 137*6236dae4SAndroid Build Coastguard Worker# here, because this file can only contain one case statement. 138*6236dae4SAndroid Build Coastguard Workerif test "$depmode" = hp; then 139*6236dae4SAndroid Build Coastguard Worker # HP compiler uses -M and no extra arg. 140*6236dae4SAndroid Build Coastguard Worker gccflag=-M 141*6236dae4SAndroid Build Coastguard Worker depmode=gcc 142*6236dae4SAndroid Build Coastguard Workerfi 143*6236dae4SAndroid Build Coastguard Worker 144*6236dae4SAndroid Build Coastguard Workerif test "$depmode" = dashXmstdout; then 145*6236dae4SAndroid Build Coastguard Worker # This is just like dashmstdout with a different argument. 146*6236dae4SAndroid Build Coastguard Worker dashmflag=-xM 147*6236dae4SAndroid Build Coastguard Worker depmode=dashmstdout 148*6236dae4SAndroid Build Coastguard Workerfi 149*6236dae4SAndroid Build Coastguard Worker 150*6236dae4SAndroid Build Coastguard Workercygpath_u="cygpath -u -f -" 151*6236dae4SAndroid Build Coastguard Workerif test "$depmode" = msvcmsys; then 152*6236dae4SAndroid Build Coastguard Worker # This is just like msvisualcpp but w/o cygpath translation. 153*6236dae4SAndroid Build Coastguard Worker # Just convert the backslash-escaped backslashes to single forward 154*6236dae4SAndroid Build Coastguard Worker # slashes to satisfy depend.m4 155*6236dae4SAndroid Build Coastguard Worker cygpath_u='sed s,\\\\,/,g' 156*6236dae4SAndroid Build Coastguard Worker depmode=msvisualcpp 157*6236dae4SAndroid Build Coastguard Workerfi 158*6236dae4SAndroid Build Coastguard Worker 159*6236dae4SAndroid Build Coastguard Workerif test "$depmode" = msvc7msys; then 160*6236dae4SAndroid Build Coastguard Worker # This is just like msvc7 but w/o cygpath translation. 161*6236dae4SAndroid Build Coastguard Worker # Just convert the backslash-escaped backslashes to single forward 162*6236dae4SAndroid Build Coastguard Worker # slashes to satisfy depend.m4 163*6236dae4SAndroid Build Coastguard Worker cygpath_u='sed s,\\\\,/,g' 164*6236dae4SAndroid Build Coastguard Worker depmode=msvc7 165*6236dae4SAndroid Build Coastguard Workerfi 166*6236dae4SAndroid Build Coastguard Worker 167*6236dae4SAndroid Build Coastguard Workerif test "$depmode" = xlc; then 168*6236dae4SAndroid Build Coastguard Worker # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. 169*6236dae4SAndroid Build Coastguard Worker gccflag=-qmakedep=gcc,-MF 170*6236dae4SAndroid Build Coastguard Worker depmode=gcc 171*6236dae4SAndroid Build Coastguard Workerfi 172*6236dae4SAndroid Build Coastguard Worker 173*6236dae4SAndroid Build Coastguard Workercase "$depmode" in 174*6236dae4SAndroid Build Coastguard Workergcc3) 175*6236dae4SAndroid Build Coastguard Worker## gcc 3 implements dependency tracking that does exactly what 176*6236dae4SAndroid Build Coastguard Worker## we want. Yay! Note: for some reason libtool 1.4 doesn't like 177*6236dae4SAndroid Build Coastguard Worker## it if -MD -MP comes after the -MF stuff. Hmm. 178*6236dae4SAndroid Build Coastguard Worker## Unfortunately, FreeBSD c89 acceptance of flags depends upon 179*6236dae4SAndroid Build Coastguard Worker## the command line argument order; so add the flags where they 180*6236dae4SAndroid Build Coastguard Worker## appear in depend2.am. Note that the slowdown incurred here 181*6236dae4SAndroid Build Coastguard Worker## affects only configure: in makefiles, %FASTDEP% shortcuts this. 182*6236dae4SAndroid Build Coastguard Worker for arg 183*6236dae4SAndroid Build Coastguard Worker do 184*6236dae4SAndroid Build Coastguard Worker case $arg in 185*6236dae4SAndroid Build Coastguard Worker -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; 186*6236dae4SAndroid Build Coastguard Worker *) set fnord "$@" "$arg" ;; 187*6236dae4SAndroid Build Coastguard Worker esac 188*6236dae4SAndroid Build Coastguard Worker shift # fnord 189*6236dae4SAndroid Build Coastguard Worker shift # $arg 190*6236dae4SAndroid Build Coastguard Worker done 191*6236dae4SAndroid Build Coastguard Worker "$@" 192*6236dae4SAndroid Build Coastguard Worker stat=$? 193*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 194*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 195*6236dae4SAndroid Build Coastguard Worker exit $stat 196*6236dae4SAndroid Build Coastguard Worker fi 197*6236dae4SAndroid Build Coastguard Worker mv "$tmpdepfile" "$depfile" 198*6236dae4SAndroid Build Coastguard Worker ;; 199*6236dae4SAndroid Build Coastguard Worker 200*6236dae4SAndroid Build Coastguard Workergcc) 201*6236dae4SAndroid Build Coastguard Worker## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. 202*6236dae4SAndroid Build Coastguard Worker## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. 203*6236dae4SAndroid Build Coastguard Worker## (see the conditional assignment to $gccflag above). 204*6236dae4SAndroid Build Coastguard Worker## There are various ways to get dependency output from gcc. Here's 205*6236dae4SAndroid Build Coastguard Worker## why we pick this rather obscure method: 206*6236dae4SAndroid Build Coastguard Worker## - Don't want to use -MD because we'd like the dependencies to end 207*6236dae4SAndroid Build Coastguard Worker## up in a subdir. Having to rename by hand is ugly. 208*6236dae4SAndroid Build Coastguard Worker## (We might end up doing this anyway to support other compilers.) 209*6236dae4SAndroid Build Coastguard Worker## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like 210*6236dae4SAndroid Build Coastguard Worker## -MM, not -M (despite what the docs say). Also, it might not be 211*6236dae4SAndroid Build Coastguard Worker## supported by the other compilers which use the 'gcc' depmode. 212*6236dae4SAndroid Build Coastguard Worker## - Using -M directly means running the compiler twice (even worse 213*6236dae4SAndroid Build Coastguard Worker## than renaming). 214*6236dae4SAndroid Build Coastguard Worker if test -z "$gccflag"; then 215*6236dae4SAndroid Build Coastguard Worker gccflag=-MD, 216*6236dae4SAndroid Build Coastguard Worker fi 217*6236dae4SAndroid Build Coastguard Worker "$@" -Wp,"$gccflag$tmpdepfile" 218*6236dae4SAndroid Build Coastguard Worker stat=$? 219*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 220*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 221*6236dae4SAndroid Build Coastguard Worker exit $stat 222*6236dae4SAndroid Build Coastguard Worker fi 223*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 224*6236dae4SAndroid Build Coastguard Worker echo "$object : \\" > "$depfile" 225*6236dae4SAndroid Build Coastguard Worker # The second -e expression handles DOS-style file names with drive 226*6236dae4SAndroid Build Coastguard Worker # letters. 227*6236dae4SAndroid Build Coastguard Worker sed -e 's/^[^:]*: / /' \ 228*6236dae4SAndroid Build Coastguard Worker -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" 229*6236dae4SAndroid Build Coastguard Worker## This next piece of magic avoids the "deleted header file" problem. 230*6236dae4SAndroid Build Coastguard Worker## The problem is that when a header file which appears in a .P file 231*6236dae4SAndroid Build Coastguard Worker## is deleted, the dependency causes make to die (because there is 232*6236dae4SAndroid Build Coastguard Worker## typically no way to rebuild the header). We avoid this by adding 233*6236dae4SAndroid Build Coastguard Worker## dummy dependencies for each header file. Too bad gcc doesn't do 234*6236dae4SAndroid Build Coastguard Worker## this for us directly. 235*6236dae4SAndroid Build Coastguard Worker## Some versions of gcc put a space before the ':'. On the theory 236*6236dae4SAndroid Build Coastguard Worker## that the space means something, we add a space to the output as 237*6236dae4SAndroid Build Coastguard Worker## well. hp depmode also adds that space, but also prefixes the VPATH 238*6236dae4SAndroid Build Coastguard Worker## to the object. Take care to not repeat it in the output. 239*6236dae4SAndroid Build Coastguard Worker## Some versions of the HPUX 10.20 sed can't process this invocation 240*6236dae4SAndroid Build Coastguard Worker## correctly. Breaking it into two sed invocations is a workaround. 241*6236dae4SAndroid Build Coastguard Worker tr ' ' "$nl" < "$tmpdepfile" \ 242*6236dae4SAndroid Build Coastguard Worker | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ 243*6236dae4SAndroid Build Coastguard Worker | sed -e 's/$/ :/' >> "$depfile" 244*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 245*6236dae4SAndroid Build Coastguard Worker ;; 246*6236dae4SAndroid Build Coastguard Worker 247*6236dae4SAndroid Build Coastguard Workerhp) 248*6236dae4SAndroid Build Coastguard Worker # This case exists only to let depend.m4 do its work. It works by 249*6236dae4SAndroid Build Coastguard Worker # looking at the text of this script. This case will never be run, 250*6236dae4SAndroid Build Coastguard Worker # since it is checked for above. 251*6236dae4SAndroid Build Coastguard Worker exit 1 252*6236dae4SAndroid Build Coastguard Worker ;; 253*6236dae4SAndroid Build Coastguard Worker 254*6236dae4SAndroid Build Coastguard Workersgi) 255*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 256*6236dae4SAndroid Build Coastguard Worker "$@" "-Wp,-MDupdate,$tmpdepfile" 257*6236dae4SAndroid Build Coastguard Worker else 258*6236dae4SAndroid Build Coastguard Worker "$@" -MDupdate "$tmpdepfile" 259*6236dae4SAndroid Build Coastguard Worker fi 260*6236dae4SAndroid Build Coastguard Worker stat=$? 261*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 262*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 263*6236dae4SAndroid Build Coastguard Worker exit $stat 264*6236dae4SAndroid Build Coastguard Worker fi 265*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 266*6236dae4SAndroid Build Coastguard Worker 267*6236dae4SAndroid Build Coastguard Worker if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files 268*6236dae4SAndroid Build Coastguard Worker echo "$object : \\" > "$depfile" 269*6236dae4SAndroid Build Coastguard Worker # Clip off the initial element (the dependent). Don't try to be 270*6236dae4SAndroid Build Coastguard Worker # clever and replace this with sed code, as IRIX sed won't handle 271*6236dae4SAndroid Build Coastguard Worker # lines with more than a fixed number of characters (4096 in 272*6236dae4SAndroid Build Coastguard Worker # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; 273*6236dae4SAndroid Build Coastguard Worker # the IRIX cc adds comments like '#:fec' to the end of the 274*6236dae4SAndroid Build Coastguard Worker # dependency line. 275*6236dae4SAndroid Build Coastguard Worker tr ' ' "$nl" < "$tmpdepfile" \ 276*6236dae4SAndroid Build Coastguard Worker | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ 277*6236dae4SAndroid Build Coastguard Worker | tr "$nl" ' ' >> "$depfile" 278*6236dae4SAndroid Build Coastguard Worker echo >> "$depfile" 279*6236dae4SAndroid Build Coastguard Worker # The second pass generates a dummy entry for each header file. 280*6236dae4SAndroid Build Coastguard Worker tr ' ' "$nl" < "$tmpdepfile" \ 281*6236dae4SAndroid Build Coastguard Worker | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ 282*6236dae4SAndroid Build Coastguard Worker >> "$depfile" 283*6236dae4SAndroid Build Coastguard Worker else 284*6236dae4SAndroid Build Coastguard Worker make_dummy_depfile 285*6236dae4SAndroid Build Coastguard Worker fi 286*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 287*6236dae4SAndroid Build Coastguard Worker ;; 288*6236dae4SAndroid Build Coastguard Worker 289*6236dae4SAndroid Build Coastguard Workerxlc) 290*6236dae4SAndroid Build Coastguard Worker # This case exists only to let depend.m4 do its work. It works by 291*6236dae4SAndroid Build Coastguard Worker # looking at the text of this script. This case will never be run, 292*6236dae4SAndroid Build Coastguard Worker # since it is checked for above. 293*6236dae4SAndroid Build Coastguard Worker exit 1 294*6236dae4SAndroid Build Coastguard Worker ;; 295*6236dae4SAndroid Build Coastguard Worker 296*6236dae4SAndroid Build Coastguard Workeraix) 297*6236dae4SAndroid Build Coastguard Worker # The C for AIX Compiler uses -M and outputs the dependencies 298*6236dae4SAndroid Build Coastguard Worker # in a .u file. In older versions, this file always lives in the 299*6236dae4SAndroid Build Coastguard Worker # current directory. Also, the AIX compiler puts '$object:' at the 300*6236dae4SAndroid Build Coastguard Worker # start of each line; $object doesn't have directory information. 301*6236dae4SAndroid Build Coastguard Worker # Version 6 uses the directory in both cases. 302*6236dae4SAndroid Build Coastguard Worker set_dir_from "$object" 303*6236dae4SAndroid Build Coastguard Worker set_base_from "$object" 304*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 305*6236dae4SAndroid Build Coastguard Worker tmpdepfile1=$dir$base.u 306*6236dae4SAndroid Build Coastguard Worker tmpdepfile2=$base.u 307*6236dae4SAndroid Build Coastguard Worker tmpdepfile3=$dir.libs/$base.u 308*6236dae4SAndroid Build Coastguard Worker "$@" -Wc,-M 309*6236dae4SAndroid Build Coastguard Worker else 310*6236dae4SAndroid Build Coastguard Worker tmpdepfile1=$dir$base.u 311*6236dae4SAndroid Build Coastguard Worker tmpdepfile2=$dir$base.u 312*6236dae4SAndroid Build Coastguard Worker tmpdepfile3=$dir$base.u 313*6236dae4SAndroid Build Coastguard Worker "$@" -M 314*6236dae4SAndroid Build Coastguard Worker fi 315*6236dae4SAndroid Build Coastguard Worker stat=$? 316*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 317*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" 318*6236dae4SAndroid Build Coastguard Worker exit $stat 319*6236dae4SAndroid Build Coastguard Worker fi 320*6236dae4SAndroid Build Coastguard Worker 321*6236dae4SAndroid Build Coastguard Worker for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" 322*6236dae4SAndroid Build Coastguard Worker do 323*6236dae4SAndroid Build Coastguard Worker test -f "$tmpdepfile" && break 324*6236dae4SAndroid Build Coastguard Worker done 325*6236dae4SAndroid Build Coastguard Worker aix_post_process_depfile 326*6236dae4SAndroid Build Coastguard Worker ;; 327*6236dae4SAndroid Build Coastguard Worker 328*6236dae4SAndroid Build Coastguard Workertcc) 329*6236dae4SAndroid Build Coastguard Worker # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 330*6236dae4SAndroid Build Coastguard Worker # FIXME: That version still under development at the moment of writing. 331*6236dae4SAndroid Build Coastguard Worker # Make that this statement remains true also for stable, released 332*6236dae4SAndroid Build Coastguard Worker # versions. 333*6236dae4SAndroid Build Coastguard Worker # It will wrap lines (doesn't matter whether long or short) with a 334*6236dae4SAndroid Build Coastguard Worker # trailing '\', as in: 335*6236dae4SAndroid Build Coastguard Worker # 336*6236dae4SAndroid Build Coastguard Worker # foo.o : \ 337*6236dae4SAndroid Build Coastguard Worker # foo.c \ 338*6236dae4SAndroid Build Coastguard Worker # foo.h \ 339*6236dae4SAndroid Build Coastguard Worker # 340*6236dae4SAndroid Build Coastguard Worker # It will put a trailing '\' even on the last line, and will use leading 341*6236dae4SAndroid Build Coastguard Worker # spaces rather than leading tabs (at least since its commit 0394caf7 342*6236dae4SAndroid Build Coastguard Worker # "Emit spaces for -MD"). 343*6236dae4SAndroid Build Coastguard Worker "$@" -MD -MF "$tmpdepfile" 344*6236dae4SAndroid Build Coastguard Worker stat=$? 345*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 346*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 347*6236dae4SAndroid Build Coastguard Worker exit $stat 348*6236dae4SAndroid Build Coastguard Worker fi 349*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 350*6236dae4SAndroid Build Coastguard Worker # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. 351*6236dae4SAndroid Build Coastguard Worker # We have to change lines of the first kind to '$object: \'. 352*6236dae4SAndroid Build Coastguard Worker sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" 353*6236dae4SAndroid Build Coastguard Worker # And for each line of the second kind, we have to emit a 'dep.h:' 354*6236dae4SAndroid Build Coastguard Worker # dummy dependency, to avoid the deleted-header problem. 355*6236dae4SAndroid Build Coastguard Worker sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" 356*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 357*6236dae4SAndroid Build Coastguard Worker ;; 358*6236dae4SAndroid Build Coastguard Worker 359*6236dae4SAndroid Build Coastguard Worker## The order of this option in the case statement is important, since the 360*6236dae4SAndroid Build Coastguard Worker## shell code in configure will try each of these formats in the order 361*6236dae4SAndroid Build Coastguard Worker## listed in this file. A plain '-MD' option would be understood by many 362*6236dae4SAndroid Build Coastguard Worker## compilers, so we must ensure this comes after the gcc and icc options. 363*6236dae4SAndroid Build Coastguard Workerpgcc) 364*6236dae4SAndroid Build Coastguard Worker # Portland's C compiler understands '-MD'. 365*6236dae4SAndroid Build Coastguard Worker # Will always output deps to 'file.d' where file is the root name of the 366*6236dae4SAndroid Build Coastguard Worker # source file under compilation, even if file resides in a subdirectory. 367*6236dae4SAndroid Build Coastguard Worker # The object file name does not affect the name of the '.d' file. 368*6236dae4SAndroid Build Coastguard Worker # pgcc 10.2 will output 369*6236dae4SAndroid Build Coastguard Worker # foo.o: sub/foo.c sub/foo.h 370*6236dae4SAndroid Build Coastguard Worker # and will wrap long lines using '\' : 371*6236dae4SAndroid Build Coastguard Worker # foo.o: sub/foo.c ... \ 372*6236dae4SAndroid Build Coastguard Worker # sub/foo.h ... \ 373*6236dae4SAndroid Build Coastguard Worker # ... 374*6236dae4SAndroid Build Coastguard Worker set_dir_from "$object" 375*6236dae4SAndroid Build Coastguard Worker # Use the source, not the object, to determine the base name, since 376*6236dae4SAndroid Build Coastguard Worker # that's sadly what pgcc will do too. 377*6236dae4SAndroid Build Coastguard Worker set_base_from "$source" 378*6236dae4SAndroid Build Coastguard Worker tmpdepfile=$base.d 379*6236dae4SAndroid Build Coastguard Worker 380*6236dae4SAndroid Build Coastguard Worker # For projects that build the same source file twice into different object 381*6236dae4SAndroid Build Coastguard Worker # files, the pgcc approach of using the *source* file root name can cause 382*6236dae4SAndroid Build Coastguard Worker # problems in parallel builds. Use a locking strategy to avoid stomping on 383*6236dae4SAndroid Build Coastguard Worker # the same $tmpdepfile. 384*6236dae4SAndroid Build Coastguard Worker lockdir=$base.d-lock 385*6236dae4SAndroid Build Coastguard Worker trap " 386*6236dae4SAndroid Build Coastguard Worker echo '$0: caught signal, cleaning up...' >&2 387*6236dae4SAndroid Build Coastguard Worker rmdir '$lockdir' 388*6236dae4SAndroid Build Coastguard Worker exit 1 389*6236dae4SAndroid Build Coastguard Worker " 1 2 13 15 390*6236dae4SAndroid Build Coastguard Worker numtries=100 391*6236dae4SAndroid Build Coastguard Worker i=$numtries 392*6236dae4SAndroid Build Coastguard Worker while test $i -gt 0; do 393*6236dae4SAndroid Build Coastguard Worker # mkdir is a portable test-and-set. 394*6236dae4SAndroid Build Coastguard Worker if mkdir "$lockdir" 2>/dev/null; then 395*6236dae4SAndroid Build Coastguard Worker # This process acquired the lock. 396*6236dae4SAndroid Build Coastguard Worker "$@" -MD 397*6236dae4SAndroid Build Coastguard Worker stat=$? 398*6236dae4SAndroid Build Coastguard Worker # Release the lock. 399*6236dae4SAndroid Build Coastguard Worker rmdir "$lockdir" 400*6236dae4SAndroid Build Coastguard Worker break 401*6236dae4SAndroid Build Coastguard Worker else 402*6236dae4SAndroid Build Coastguard Worker # If the lock is being held by a different process, wait 403*6236dae4SAndroid Build Coastguard Worker # until the winning process is done or we timeout. 404*6236dae4SAndroid Build Coastguard Worker while test -d "$lockdir" && test $i -gt 0; do 405*6236dae4SAndroid Build Coastguard Worker sleep 1 406*6236dae4SAndroid Build Coastguard Worker i=`expr $i - 1` 407*6236dae4SAndroid Build Coastguard Worker done 408*6236dae4SAndroid Build Coastguard Worker fi 409*6236dae4SAndroid Build Coastguard Worker i=`expr $i - 1` 410*6236dae4SAndroid Build Coastguard Worker done 411*6236dae4SAndroid Build Coastguard Worker trap - 1 2 13 15 412*6236dae4SAndroid Build Coastguard Worker if test $i -le 0; then 413*6236dae4SAndroid Build Coastguard Worker echo "$0: failed to acquire lock after $numtries attempts" >&2 414*6236dae4SAndroid Build Coastguard Worker echo "$0: check lockdir '$lockdir'" >&2 415*6236dae4SAndroid Build Coastguard Worker exit 1 416*6236dae4SAndroid Build Coastguard Worker fi 417*6236dae4SAndroid Build Coastguard Worker 418*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 419*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 420*6236dae4SAndroid Build Coastguard Worker exit $stat 421*6236dae4SAndroid Build Coastguard Worker fi 422*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 423*6236dae4SAndroid Build Coastguard Worker # Each line is of the form `foo.o: dependent.h', 424*6236dae4SAndroid Build Coastguard Worker # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. 425*6236dae4SAndroid Build Coastguard Worker # Do two passes, one to just change these to 426*6236dae4SAndroid Build Coastguard Worker # `$object: dependent.h' and one to simply `dependent.h:'. 427*6236dae4SAndroid Build Coastguard Worker sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" 428*6236dae4SAndroid Build Coastguard Worker # Some versions of the HPUX 10.20 sed can't process this invocation 429*6236dae4SAndroid Build Coastguard Worker # correctly. Breaking it into two sed invocations is a workaround. 430*6236dae4SAndroid Build Coastguard Worker sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ 431*6236dae4SAndroid Build Coastguard Worker | sed -e 's/$/ :/' >> "$depfile" 432*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 433*6236dae4SAndroid Build Coastguard Worker ;; 434*6236dae4SAndroid Build Coastguard Worker 435*6236dae4SAndroid Build Coastguard Workerhp2) 436*6236dae4SAndroid Build Coastguard Worker # The "hp" stanza above does not work with aCC (C++) and HP's ia64 437*6236dae4SAndroid Build Coastguard Worker # compilers, which have integrated preprocessors. The correct option 438*6236dae4SAndroid Build Coastguard Worker # to use with these is +Maked; it writes dependencies to a file named 439*6236dae4SAndroid Build Coastguard Worker # 'foo.d', which lands next to the object file, wherever that 440*6236dae4SAndroid Build Coastguard Worker # happens to be. 441*6236dae4SAndroid Build Coastguard Worker # Much of this is similar to the tru64 case; see comments there. 442*6236dae4SAndroid Build Coastguard Worker set_dir_from "$object" 443*6236dae4SAndroid Build Coastguard Worker set_base_from "$object" 444*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 445*6236dae4SAndroid Build Coastguard Worker tmpdepfile1=$dir$base.d 446*6236dae4SAndroid Build Coastguard Worker tmpdepfile2=$dir.libs/$base.d 447*6236dae4SAndroid Build Coastguard Worker "$@" -Wc,+Maked 448*6236dae4SAndroid Build Coastguard Worker else 449*6236dae4SAndroid Build Coastguard Worker tmpdepfile1=$dir$base.d 450*6236dae4SAndroid Build Coastguard Worker tmpdepfile2=$dir$base.d 451*6236dae4SAndroid Build Coastguard Worker "$@" +Maked 452*6236dae4SAndroid Build Coastguard Worker fi 453*6236dae4SAndroid Build Coastguard Worker stat=$? 454*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 455*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile1" "$tmpdepfile2" 456*6236dae4SAndroid Build Coastguard Worker exit $stat 457*6236dae4SAndroid Build Coastguard Worker fi 458*6236dae4SAndroid Build Coastguard Worker 459*6236dae4SAndroid Build Coastguard Worker for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" 460*6236dae4SAndroid Build Coastguard Worker do 461*6236dae4SAndroid Build Coastguard Worker test -f "$tmpdepfile" && break 462*6236dae4SAndroid Build Coastguard Worker done 463*6236dae4SAndroid Build Coastguard Worker if test -f "$tmpdepfile"; then 464*6236dae4SAndroid Build Coastguard Worker sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" 465*6236dae4SAndroid Build Coastguard Worker # Add 'dependent.h:' lines. 466*6236dae4SAndroid Build Coastguard Worker sed -ne '2,${ 467*6236dae4SAndroid Build Coastguard Worker s/^ *// 468*6236dae4SAndroid Build Coastguard Worker s/ \\*$// 469*6236dae4SAndroid Build Coastguard Worker s/$/:/ 470*6236dae4SAndroid Build Coastguard Worker p 471*6236dae4SAndroid Build Coastguard Worker }' "$tmpdepfile" >> "$depfile" 472*6236dae4SAndroid Build Coastguard Worker else 473*6236dae4SAndroid Build Coastguard Worker make_dummy_depfile 474*6236dae4SAndroid Build Coastguard Worker fi 475*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" "$tmpdepfile2" 476*6236dae4SAndroid Build Coastguard Worker ;; 477*6236dae4SAndroid Build Coastguard Worker 478*6236dae4SAndroid Build Coastguard Workertru64) 479*6236dae4SAndroid Build Coastguard Worker # The Tru64 compiler uses -MD to generate dependencies as a side 480*6236dae4SAndroid Build Coastguard Worker # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. 481*6236dae4SAndroid Build Coastguard Worker # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put 482*6236dae4SAndroid Build Coastguard Worker # dependencies in 'foo.d' instead, so we check for that too. 483*6236dae4SAndroid Build Coastguard Worker # Subdirectories are respected. 484*6236dae4SAndroid Build Coastguard Worker set_dir_from "$object" 485*6236dae4SAndroid Build Coastguard Worker set_base_from "$object" 486*6236dae4SAndroid Build Coastguard Worker 487*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 488*6236dae4SAndroid Build Coastguard Worker # Libtool generates 2 separate objects for the 2 libraries. These 489*6236dae4SAndroid Build Coastguard Worker # two compilations output dependencies in $dir.libs/$base.o.d and 490*6236dae4SAndroid Build Coastguard Worker # in $dir$base.o.d. We have to check for both files, because 491*6236dae4SAndroid Build Coastguard Worker # one of the two compilations can be disabled. We should prefer 492*6236dae4SAndroid Build Coastguard Worker # $dir$base.o.d over $dir.libs/$base.o.d because the latter is 493*6236dae4SAndroid Build Coastguard Worker # automatically cleaned when .libs/ is deleted, while ignoring 494*6236dae4SAndroid Build Coastguard Worker # the former would cause a distcleancheck panic. 495*6236dae4SAndroid Build Coastguard Worker tmpdepfile1=$dir$base.o.d # libtool 1.5 496*6236dae4SAndroid Build Coastguard Worker tmpdepfile2=$dir.libs/$base.o.d # Likewise. 497*6236dae4SAndroid Build Coastguard Worker tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 498*6236dae4SAndroid Build Coastguard Worker "$@" -Wc,-MD 499*6236dae4SAndroid Build Coastguard Worker else 500*6236dae4SAndroid Build Coastguard Worker tmpdepfile1=$dir$base.d 501*6236dae4SAndroid Build Coastguard Worker tmpdepfile2=$dir$base.d 502*6236dae4SAndroid Build Coastguard Worker tmpdepfile3=$dir$base.d 503*6236dae4SAndroid Build Coastguard Worker "$@" -MD 504*6236dae4SAndroid Build Coastguard Worker fi 505*6236dae4SAndroid Build Coastguard Worker 506*6236dae4SAndroid Build Coastguard Worker stat=$? 507*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 508*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" 509*6236dae4SAndroid Build Coastguard Worker exit $stat 510*6236dae4SAndroid Build Coastguard Worker fi 511*6236dae4SAndroid Build Coastguard Worker 512*6236dae4SAndroid Build Coastguard Worker for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" 513*6236dae4SAndroid Build Coastguard Worker do 514*6236dae4SAndroid Build Coastguard Worker test -f "$tmpdepfile" && break 515*6236dae4SAndroid Build Coastguard Worker done 516*6236dae4SAndroid Build Coastguard Worker # Same post-processing that is required for AIX mode. 517*6236dae4SAndroid Build Coastguard Worker aix_post_process_depfile 518*6236dae4SAndroid Build Coastguard Worker ;; 519*6236dae4SAndroid Build Coastguard Worker 520*6236dae4SAndroid Build Coastguard Workermsvc7) 521*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 522*6236dae4SAndroid Build Coastguard Worker showIncludes=-Wc,-showIncludes 523*6236dae4SAndroid Build Coastguard Worker else 524*6236dae4SAndroid Build Coastguard Worker showIncludes=-showIncludes 525*6236dae4SAndroid Build Coastguard Worker fi 526*6236dae4SAndroid Build Coastguard Worker "$@" $showIncludes > "$tmpdepfile" 527*6236dae4SAndroid Build Coastguard Worker stat=$? 528*6236dae4SAndroid Build Coastguard Worker grep -v '^Note: including file: ' "$tmpdepfile" 529*6236dae4SAndroid Build Coastguard Worker if test $stat -ne 0; then 530*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 531*6236dae4SAndroid Build Coastguard Worker exit $stat 532*6236dae4SAndroid Build Coastguard Worker fi 533*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 534*6236dae4SAndroid Build Coastguard Worker echo "$object : \\" > "$depfile" 535*6236dae4SAndroid Build Coastguard Worker # The first sed program below extracts the file names and escapes 536*6236dae4SAndroid Build Coastguard Worker # backslashes for cygpath. The second sed program outputs the file 537*6236dae4SAndroid Build Coastguard Worker # name when reading, but also accumulates all include files in the 538*6236dae4SAndroid Build Coastguard Worker # hold buffer in order to output them again at the end. This only 539*6236dae4SAndroid Build Coastguard Worker # works with sed implementations that can handle large buffers. 540*6236dae4SAndroid Build Coastguard Worker sed < "$tmpdepfile" -n ' 541*6236dae4SAndroid Build Coastguard Worker/^Note: including file: *\(.*\)/ { 542*6236dae4SAndroid Build Coastguard Worker s//\1/ 543*6236dae4SAndroid Build Coastguard Worker s/\\/\\\\/g 544*6236dae4SAndroid Build Coastguard Worker p 545*6236dae4SAndroid Build Coastguard Worker}' | $cygpath_u | sort -u | sed -n ' 546*6236dae4SAndroid Build Coastguard Workers/ /\\ /g 547*6236dae4SAndroid Build Coastguard Workers/\(.*\)/'"$tab"'\1 \\/p 548*6236dae4SAndroid Build Coastguard Workers/.\(.*\) \\/\1:/ 549*6236dae4SAndroid Build Coastguard WorkerH 550*6236dae4SAndroid Build Coastguard Worker$ { 551*6236dae4SAndroid Build Coastguard Worker s/.*/'"$tab"'/ 552*6236dae4SAndroid Build Coastguard Worker G 553*6236dae4SAndroid Build Coastguard Worker p 554*6236dae4SAndroid Build Coastguard Worker}' >> "$depfile" 555*6236dae4SAndroid Build Coastguard Worker echo >> "$depfile" # make sure the fragment doesn't end with a backslash 556*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 557*6236dae4SAndroid Build Coastguard Worker ;; 558*6236dae4SAndroid Build Coastguard Worker 559*6236dae4SAndroid Build Coastguard Workermsvc7msys) 560*6236dae4SAndroid Build Coastguard Worker # This case exists only to let depend.m4 do its work. It works by 561*6236dae4SAndroid Build Coastguard Worker # looking at the text of this script. This case will never be run, 562*6236dae4SAndroid Build Coastguard Worker # since it is checked for above. 563*6236dae4SAndroid Build Coastguard Worker exit 1 564*6236dae4SAndroid Build Coastguard Worker ;; 565*6236dae4SAndroid Build Coastguard Worker 566*6236dae4SAndroid Build Coastguard Worker#nosideeffect) 567*6236dae4SAndroid Build Coastguard Worker # This comment above is used by automake to tell side-effect 568*6236dae4SAndroid Build Coastguard Worker # dependency tracking mechanisms from slower ones. 569*6236dae4SAndroid Build Coastguard Worker 570*6236dae4SAndroid Build Coastguard Workerdashmstdout) 571*6236dae4SAndroid Build Coastguard Worker # Important note: in order to support this mode, a compiler *must* 572*6236dae4SAndroid Build Coastguard Worker # always write the preprocessed file to stdout, regardless of -o. 573*6236dae4SAndroid Build Coastguard Worker "$@" || exit $? 574*6236dae4SAndroid Build Coastguard Worker 575*6236dae4SAndroid Build Coastguard Worker # Remove the call to Libtool. 576*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 577*6236dae4SAndroid Build Coastguard Worker while test "X$1" != 'X--mode=compile'; do 578*6236dae4SAndroid Build Coastguard Worker shift 579*6236dae4SAndroid Build Coastguard Worker done 580*6236dae4SAndroid Build Coastguard Worker shift 581*6236dae4SAndroid Build Coastguard Worker fi 582*6236dae4SAndroid Build Coastguard Worker 583*6236dae4SAndroid Build Coastguard Worker # Remove '-o $object'. 584*6236dae4SAndroid Build Coastguard Worker IFS=" " 585*6236dae4SAndroid Build Coastguard Worker for arg 586*6236dae4SAndroid Build Coastguard Worker do 587*6236dae4SAndroid Build Coastguard Worker case $arg in 588*6236dae4SAndroid Build Coastguard Worker -o) 589*6236dae4SAndroid Build Coastguard Worker shift 590*6236dae4SAndroid Build Coastguard Worker ;; 591*6236dae4SAndroid Build Coastguard Worker $object) 592*6236dae4SAndroid Build Coastguard Worker shift 593*6236dae4SAndroid Build Coastguard Worker ;; 594*6236dae4SAndroid Build Coastguard Worker *) 595*6236dae4SAndroid Build Coastguard Worker set fnord "$@" "$arg" 596*6236dae4SAndroid Build Coastguard Worker shift # fnord 597*6236dae4SAndroid Build Coastguard Worker shift # $arg 598*6236dae4SAndroid Build Coastguard Worker ;; 599*6236dae4SAndroid Build Coastguard Worker esac 600*6236dae4SAndroid Build Coastguard Worker done 601*6236dae4SAndroid Build Coastguard Worker 602*6236dae4SAndroid Build Coastguard Worker test -z "$dashmflag" && dashmflag=-M 603*6236dae4SAndroid Build Coastguard Worker # Require at least two characters before searching for ':' 604*6236dae4SAndroid Build Coastguard Worker # in the target name. This is to cope with DOS-style filenames: 605*6236dae4SAndroid Build Coastguard Worker # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. 606*6236dae4SAndroid Build Coastguard Worker "$@" $dashmflag | 607*6236dae4SAndroid Build Coastguard Worker sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" 608*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 609*6236dae4SAndroid Build Coastguard Worker cat < "$tmpdepfile" > "$depfile" 610*6236dae4SAndroid Build Coastguard Worker # Some versions of the HPUX 10.20 sed can't process this sed invocation 611*6236dae4SAndroid Build Coastguard Worker # correctly. Breaking it into two sed invocations is a workaround. 612*6236dae4SAndroid Build Coastguard Worker tr ' ' "$nl" < "$tmpdepfile" \ 613*6236dae4SAndroid Build Coastguard Worker | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ 614*6236dae4SAndroid Build Coastguard Worker | sed -e 's/$/ :/' >> "$depfile" 615*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 616*6236dae4SAndroid Build Coastguard Worker ;; 617*6236dae4SAndroid Build Coastguard Worker 618*6236dae4SAndroid Build Coastguard WorkerdashXmstdout) 619*6236dae4SAndroid Build Coastguard Worker # This case only exists to satisfy depend.m4. It is never actually 620*6236dae4SAndroid Build Coastguard Worker # run, as this mode is specially recognized in the preamble. 621*6236dae4SAndroid Build Coastguard Worker exit 1 622*6236dae4SAndroid Build Coastguard Worker ;; 623*6236dae4SAndroid Build Coastguard Worker 624*6236dae4SAndroid Build Coastguard Workermakedepend) 625*6236dae4SAndroid Build Coastguard Worker "$@" || exit $? 626*6236dae4SAndroid Build Coastguard Worker # Remove any Libtool call 627*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 628*6236dae4SAndroid Build Coastguard Worker while test "X$1" != 'X--mode=compile'; do 629*6236dae4SAndroid Build Coastguard Worker shift 630*6236dae4SAndroid Build Coastguard Worker done 631*6236dae4SAndroid Build Coastguard Worker shift 632*6236dae4SAndroid Build Coastguard Worker fi 633*6236dae4SAndroid Build Coastguard Worker # X makedepend 634*6236dae4SAndroid Build Coastguard Worker shift 635*6236dae4SAndroid Build Coastguard Worker cleared=no eat=no 636*6236dae4SAndroid Build Coastguard Worker for arg 637*6236dae4SAndroid Build Coastguard Worker do 638*6236dae4SAndroid Build Coastguard Worker case $cleared in 639*6236dae4SAndroid Build Coastguard Worker no) 640*6236dae4SAndroid Build Coastguard Worker set ""; shift 641*6236dae4SAndroid Build Coastguard Worker cleared=yes ;; 642*6236dae4SAndroid Build Coastguard Worker esac 643*6236dae4SAndroid Build Coastguard Worker if test $eat = yes; then 644*6236dae4SAndroid Build Coastguard Worker eat=no 645*6236dae4SAndroid Build Coastguard Worker continue 646*6236dae4SAndroid Build Coastguard Worker fi 647*6236dae4SAndroid Build Coastguard Worker case "$arg" in 648*6236dae4SAndroid Build Coastguard Worker -D*|-I*) 649*6236dae4SAndroid Build Coastguard Worker set fnord "$@" "$arg"; shift ;; 650*6236dae4SAndroid Build Coastguard Worker # Strip any option that makedepend may not understand. Remove 651*6236dae4SAndroid Build Coastguard Worker # the object too, otherwise makedepend will parse it as a source file. 652*6236dae4SAndroid Build Coastguard Worker -arch) 653*6236dae4SAndroid Build Coastguard Worker eat=yes ;; 654*6236dae4SAndroid Build Coastguard Worker -*|$object) 655*6236dae4SAndroid Build Coastguard Worker ;; 656*6236dae4SAndroid Build Coastguard Worker *) 657*6236dae4SAndroid Build Coastguard Worker set fnord "$@" "$arg"; shift ;; 658*6236dae4SAndroid Build Coastguard Worker esac 659*6236dae4SAndroid Build Coastguard Worker done 660*6236dae4SAndroid Build Coastguard Worker obj_suffix=`echo "$object" | sed 's/^.*\././'` 661*6236dae4SAndroid Build Coastguard Worker touch "$tmpdepfile" 662*6236dae4SAndroid Build Coastguard Worker ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" 663*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 664*6236dae4SAndroid Build Coastguard Worker # makedepend may prepend the VPATH from the source file name to the object. 665*6236dae4SAndroid Build Coastguard Worker # No need to regex-escape $object, excess matching of '.' is harmless. 666*6236dae4SAndroid Build Coastguard Worker sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" 667*6236dae4SAndroid Build Coastguard Worker # Some versions of the HPUX 10.20 sed can't process the last invocation 668*6236dae4SAndroid Build Coastguard Worker # correctly. Breaking it into two sed invocations is a workaround. 669*6236dae4SAndroid Build Coastguard Worker sed '1,2d' "$tmpdepfile" \ 670*6236dae4SAndroid Build Coastguard Worker | tr ' ' "$nl" \ 671*6236dae4SAndroid Build Coastguard Worker | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ 672*6236dae4SAndroid Build Coastguard Worker | sed -e 's/$/ :/' >> "$depfile" 673*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" "$tmpdepfile".bak 674*6236dae4SAndroid Build Coastguard Worker ;; 675*6236dae4SAndroid Build Coastguard Worker 676*6236dae4SAndroid Build Coastguard Workercpp) 677*6236dae4SAndroid Build Coastguard Worker # Important note: in order to support this mode, a compiler *must* 678*6236dae4SAndroid Build Coastguard Worker # always write the preprocessed file to stdout. 679*6236dae4SAndroid Build Coastguard Worker "$@" || exit $? 680*6236dae4SAndroid Build Coastguard Worker 681*6236dae4SAndroid Build Coastguard Worker # Remove the call to Libtool. 682*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 683*6236dae4SAndroid Build Coastguard Worker while test "X$1" != 'X--mode=compile'; do 684*6236dae4SAndroid Build Coastguard Worker shift 685*6236dae4SAndroid Build Coastguard Worker done 686*6236dae4SAndroid Build Coastguard Worker shift 687*6236dae4SAndroid Build Coastguard Worker fi 688*6236dae4SAndroid Build Coastguard Worker 689*6236dae4SAndroid Build Coastguard Worker # Remove '-o $object'. 690*6236dae4SAndroid Build Coastguard Worker IFS=" " 691*6236dae4SAndroid Build Coastguard Worker for arg 692*6236dae4SAndroid Build Coastguard Worker do 693*6236dae4SAndroid Build Coastguard Worker case $arg in 694*6236dae4SAndroid Build Coastguard Worker -o) 695*6236dae4SAndroid Build Coastguard Worker shift 696*6236dae4SAndroid Build Coastguard Worker ;; 697*6236dae4SAndroid Build Coastguard Worker $object) 698*6236dae4SAndroid Build Coastguard Worker shift 699*6236dae4SAndroid Build Coastguard Worker ;; 700*6236dae4SAndroid Build Coastguard Worker *) 701*6236dae4SAndroid Build Coastguard Worker set fnord "$@" "$arg" 702*6236dae4SAndroid Build Coastguard Worker shift # fnord 703*6236dae4SAndroid Build Coastguard Worker shift # $arg 704*6236dae4SAndroid Build Coastguard Worker ;; 705*6236dae4SAndroid Build Coastguard Worker esac 706*6236dae4SAndroid Build Coastguard Worker done 707*6236dae4SAndroid Build Coastguard Worker 708*6236dae4SAndroid Build Coastguard Worker "$@" -E \ 709*6236dae4SAndroid Build Coastguard Worker | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ 710*6236dae4SAndroid Build Coastguard Worker -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ 711*6236dae4SAndroid Build Coastguard Worker | sed '$ s: \\$::' > "$tmpdepfile" 712*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 713*6236dae4SAndroid Build Coastguard Worker echo "$object : \\" > "$depfile" 714*6236dae4SAndroid Build Coastguard Worker cat < "$tmpdepfile" >> "$depfile" 715*6236dae4SAndroid Build Coastguard Worker sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" 716*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 717*6236dae4SAndroid Build Coastguard Worker ;; 718*6236dae4SAndroid Build Coastguard Worker 719*6236dae4SAndroid Build Coastguard Workermsvisualcpp) 720*6236dae4SAndroid Build Coastguard Worker # Important note: in order to support this mode, a compiler *must* 721*6236dae4SAndroid Build Coastguard Worker # always write the preprocessed file to stdout. 722*6236dae4SAndroid Build Coastguard Worker "$@" || exit $? 723*6236dae4SAndroid Build Coastguard Worker 724*6236dae4SAndroid Build Coastguard Worker # Remove the call to Libtool. 725*6236dae4SAndroid Build Coastguard Worker if test "$libtool" = yes; then 726*6236dae4SAndroid Build Coastguard Worker while test "X$1" != 'X--mode=compile'; do 727*6236dae4SAndroid Build Coastguard Worker shift 728*6236dae4SAndroid Build Coastguard Worker done 729*6236dae4SAndroid Build Coastguard Worker shift 730*6236dae4SAndroid Build Coastguard Worker fi 731*6236dae4SAndroid Build Coastguard Worker 732*6236dae4SAndroid Build Coastguard Worker IFS=" " 733*6236dae4SAndroid Build Coastguard Worker for arg 734*6236dae4SAndroid Build Coastguard Worker do 735*6236dae4SAndroid Build Coastguard Worker case "$arg" in 736*6236dae4SAndroid Build Coastguard Worker -o) 737*6236dae4SAndroid Build Coastguard Worker shift 738*6236dae4SAndroid Build Coastguard Worker ;; 739*6236dae4SAndroid Build Coastguard Worker $object) 740*6236dae4SAndroid Build Coastguard Worker shift 741*6236dae4SAndroid Build Coastguard Worker ;; 742*6236dae4SAndroid Build Coastguard Worker "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") 743*6236dae4SAndroid Build Coastguard Worker set fnord "$@" 744*6236dae4SAndroid Build Coastguard Worker shift 745*6236dae4SAndroid Build Coastguard Worker shift 746*6236dae4SAndroid Build Coastguard Worker ;; 747*6236dae4SAndroid Build Coastguard Worker *) 748*6236dae4SAndroid Build Coastguard Worker set fnord "$@" "$arg" 749*6236dae4SAndroid Build Coastguard Worker shift 750*6236dae4SAndroid Build Coastguard Worker shift 751*6236dae4SAndroid Build Coastguard Worker ;; 752*6236dae4SAndroid Build Coastguard Worker esac 753*6236dae4SAndroid Build Coastguard Worker done 754*6236dae4SAndroid Build Coastguard Worker "$@" -E 2>/dev/null | 755*6236dae4SAndroid Build Coastguard Worker sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" 756*6236dae4SAndroid Build Coastguard Worker rm -f "$depfile" 757*6236dae4SAndroid Build Coastguard Worker echo "$object : \\" > "$depfile" 758*6236dae4SAndroid Build Coastguard Worker sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" 759*6236dae4SAndroid Build Coastguard Worker echo "$tab" >> "$depfile" 760*6236dae4SAndroid Build Coastguard Worker sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" 761*6236dae4SAndroid Build Coastguard Worker rm -f "$tmpdepfile" 762*6236dae4SAndroid Build Coastguard Worker ;; 763*6236dae4SAndroid Build Coastguard Worker 764*6236dae4SAndroid Build Coastguard Workermsvcmsys) 765*6236dae4SAndroid Build Coastguard Worker # This case exists only to let depend.m4 do its work. It works by 766*6236dae4SAndroid Build Coastguard Worker # looking at the text of this script. This case will never be run, 767*6236dae4SAndroid Build Coastguard Worker # since it is checked for above. 768*6236dae4SAndroid Build Coastguard Worker exit 1 769*6236dae4SAndroid Build Coastguard Worker ;; 770*6236dae4SAndroid Build Coastguard Worker 771*6236dae4SAndroid Build Coastguard Workernone) 772*6236dae4SAndroid Build Coastguard Worker exec "$@" 773*6236dae4SAndroid Build Coastguard Worker ;; 774*6236dae4SAndroid Build Coastguard Worker 775*6236dae4SAndroid Build Coastguard Worker*) 776*6236dae4SAndroid Build Coastguard Worker echo "Unknown depmode $depmode" 1>&2 777*6236dae4SAndroid Build Coastguard Worker exit 1 778*6236dae4SAndroid Build Coastguard Worker ;; 779*6236dae4SAndroid Build Coastguard Workeresac 780*6236dae4SAndroid Build Coastguard Worker 781*6236dae4SAndroid Build Coastguard Workerexit 0 782*6236dae4SAndroid Build Coastguard Worker 783*6236dae4SAndroid Build Coastguard Worker# Local Variables: 784*6236dae4SAndroid Build Coastguard Worker# mode: shell-script 785*6236dae4SAndroid Build Coastguard Worker# sh-indentation: 2 786*6236dae4SAndroid Build Coastguard Worker# eval: (add-hook 'before-save-hook 'time-stamp) 787*6236dae4SAndroid Build Coastguard Worker# time-stamp-start: "scriptversion=" 788*6236dae4SAndroid Build Coastguard Worker# time-stamp-format: "%:y-%02m-%02d.%02H" 789*6236dae4SAndroid Build Coastguard Worker# time-stamp-time-zone: "UTC0" 790*6236dae4SAndroid Build Coastguard Worker# time-stamp-end: "; # UTC" 791*6236dae4SAndroid Build Coastguard Worker# End: 792