Make this support the same new options as recently added to the mkdep program.

This commit is contained in:
dsl 2003-11-10 17:57:43 +00:00
parent cffe183eef
commit 198a6cd602
1 changed files with 133 additions and 65 deletions

View File

@ -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