xref: /aosp_15_r20/external/curl/depcomp (revision 6236dae45794135f37c4eb022389c904c8b0090d)
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