Make this support the same new options as recently added to the mkdep program.
This commit is contained in:
parent
cffe183eef
commit
198a6cd602
|
@ -1,6 +1,6 @@
|
||||||
#!@BSHELL@ -
|
#!@BSHELL@ -
|
||||||
#
|
#
|
||||||
# $NetBSD: host-mkdep.in,v 1.10 2003/06/11 13:20:38 christos Exp $
|
# $NetBSD: host-mkdep.in,v 1.11 2003/11/10 17:57:43 dsl Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 1991, 1993
|
# Copyright (c) 1991, 1993
|
||||||
# The Regents of the University of California. All rights reserved.
|
# The Regents of the University of California. All rights reserved.
|
||||||
|
@ -37,11 +37,31 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
APPEND=false
|
APPEND=false
|
||||||
|
MERGE=false
|
||||||
|
OPTIONAL=false
|
||||||
|
AWK_OPTIONAL=
|
||||||
|
QUIET=false
|
||||||
CPPFLAGS=
|
CPPFLAGS=
|
||||||
NEWEXT=.o
|
NEWEXT=.o
|
||||||
OUTFILE=.depend
|
OUTFILE=.depend
|
||||||
SRCS=
|
SRCS=
|
||||||
USAGE="Usage: $0 [-a] [-p] [-f makefile] [flags] file ..."
|
USAGE="Usage: $0 [-a] [-d] [-o] [-p] [-q] [-s suffix] [-f makefile] [flags] file ..."
|
||||||
|
|
||||||
|
set_objlist()
|
||||||
|
{
|
||||||
|
if [ -n "$NEWEXT" ]; then
|
||||||
|
oifs="$IFS"
|
||||||
|
IFS=" ,"
|
||||||
|
set -- $NEWEXT
|
||||||
|
IFS="$oifs"
|
||||||
|
objlist=
|
||||||
|
for suf in $*; do
|
||||||
|
objlist="$objlist${objlist:+ }$file$suf"
|
||||||
|
done
|
||||||
|
else
|
||||||
|
objlist="$file"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
|
@ -49,14 +69,36 @@ while [ $# -gt 0 ]; do
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
-d) MERGE=true
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
-f) OUTFILE=$2
|
-f) OUTFILE=$2
|
||||||
shift 2
|
shift 2
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
-o) OPTIONAL=true
|
||||||
|
AWK_OPTIONAL='print ".OPTIONAL:" $0'
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
-p) NEWEXT=
|
-p) NEWEXT=
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
-q) QUIET=true
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
-s) NEWEXT="$2"
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
|
||||||
|
-*) $MERGE || break;
|
||||||
|
echo "$USAGE" >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
|
||||||
*) break
|
*) break
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
@ -67,7 +109,10 @@ if [ $# = 0 ]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
if $MERGE; then
|
||||||
|
SRCS="$*"
|
||||||
|
else
|
||||||
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
-L) # takes an arg, but ignored
|
-L) # takes an arg, but ignored
|
||||||
shift 2
|
shift 2
|
||||||
|
@ -111,7 +156,8 @@ while [ $# -gt 0 ]; do
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -z "$SRCS" ]; then
|
if [ -z "$SRCS" ]; then
|
||||||
echo "$USAGE" 1>&2
|
echo "$USAGE" 1>&2
|
||||||
|
@ -123,13 +169,33 @@ rm -f $TMP
|
||||||
|
|
||||||
trap 'rm -f $TMP; exit 1' 1 2 3 13 15
|
trap 'rm -f $TMP; exit 1' 1 2 3 13 15
|
||||||
|
|
||||||
for f in $SRCS; do
|
if $MERGE; then
|
||||||
|
for f in $SRCS; do
|
||||||
|
if [ ! -f "$f" ]; then
|
||||||
|
if ! $QUIET; then echo "$0: Ignoring $f" >&2; fi
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
while IFS=':'; read target dependants; do
|
||||||
|
IFS=
|
||||||
|
t1="${target#* }"
|
||||||
|
file="${target%.o}"
|
||||||
|
if [ "$t" = "$target" -a "$file" != "$target" ]; then
|
||||||
|
set_objlist $file
|
||||||
|
target="$objlist"
|
||||||
|
fi
|
||||||
|
echo "$target:$dependants"
|
||||||
|
if "$OPTIONAL"; then
|
||||||
|
echo ".OPTIONAL:$dependants"
|
||||||
|
fi
|
||||||
|
done <$f
|
||||||
|
done >$TMP
|
||||||
|
else
|
||||||
|
for f in $SRCS; do
|
||||||
|
file=${f##*/}
|
||||||
|
file=${file%.*}
|
||||||
|
set_objlist $file
|
||||||
|
|
||||||
@CPP@ $CPPFLAGS $f | @AWK@ '
|
@CPP@ $CPPFLAGS $f | @AWK@ '
|
||||||
BEGIN {
|
|
||||||
objfile = "'$f'"
|
|
||||||
sub(/^.*\//, "", objfile)
|
|
||||||
sub(/\.(c|cc|m)$/, "'$NEWEXT'", objfile)
|
|
||||||
}
|
|
||||||
/^#/ {
|
/^#/ {
|
||||||
# Be as tolerant as possible.
|
# Be as tolerant as possible.
|
||||||
sub(/^#(line)? [ 0-9]*\"?/, "")
|
sub(/^#(line)? [ 0-9]*\"?/, "")
|
||||||
|
@ -142,10 +208,12 @@ for f in $SRCS; do
|
||||||
if ($0 ~ /y.tab.c/) next
|
if ($0 ~ /y.tab.c/) next
|
||||||
|
|
||||||
seenfiles[$0] = 1
|
seenfiles[$0] = 1
|
||||||
print objfile ": " $0
|
print "'"$objlist"'" ": " $0
|
||||||
|
'"$AWK_OPTIONAL"'
|
||||||
}
|
}
|
||||||
' >> $TMP
|
' >> $TMP
|
||||||
done
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
if $APPEND; then
|
if $APPEND; then
|
||||||
cat $TMP >> $OUTFILE
|
cat $TMP >> $OUTFILE
|
||||||
|
|
Loading…
Reference in New Issue