From: Howard Chu Date: Sun, 8 Sep 2002 12:36:25 +0000 (+0000) Subject: Added rules to use "cc -E" output to generate dependencies. X-Git-Tag: NO_SLAP_OP_BLOCKS~1006 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=49f7399e24a0f5a6d8fd6ce1a8914c56f56e167c;p=openldap Added rules to use "cc -E" output to generate dependencies. --- diff --git a/build/mkdep b/build/mkdep index b9df7060f3..4384b2853f 100755 --- a/build/mkdep +++ b/build/mkdep @@ -109,13 +109,11 @@ cat << _EOF_ >> $TMP _EOF_ -# If your compiler doesn't have -M, add it. If you can't, the next two -# lines will try and replace the "cc -M". The real problem is that this -# hack can't deal with anything that requires a search path, and doesn't -# even try for anything using bracket (<>) syntax. -# -# egrep '^#include[ ]*".*"' /dev/null $* | -# sed -e 's/:[^"]*"\([^"]*\)".*/: \1/' -e 's/\.c/.o/' | +# If your compiler doesn't have -M, you may be able to use -E instead. +# The preprocessor must generate lines of the form +# #.* [0-9]* "dependent file" .* +# This script will parse out the "dependent file"s to generate the +# dependency list. if test "x$SRCDIR" = "x" ; then files=$* @@ -143,6 +141,38 @@ cat << _EOF_ >> $TMP _EOF_ +case $MKDEP_CFLAGS in +# Using regular preprocessor output + -E*) +FLAGS="" +FILES="" +for i in $files; do + case $i in + -*) FLAGS="$FLAGS $i" ;; + *) FILES="$FILES $i" ;; + esac +done +for i in $FILES; do + $MKDEP_CC $MKDEP_CFLAGS $FLAGS $i | egrep '^#.*"' > $TMP.sed +awk ' +BEGIN { + file = "'$i'" + n = split(file, parts, "/") + filenm = substr(parts[n], 0, length(parts[n])-1) "o" +} +{ + dep = split($3, parts, "\"") + dep = parts[2] + if (dep ~ "^\./.*") dep = substr(dep, 3, length(dep)-2) + if (( noslash == "yes") && (dep ~ /^\// )) continue + if (deps[dep] == 0) printf "%s: %s\n", filenm, dep + deps[dep] = 1 +}' noslash="$NOSLASH" $TMP.sed >> $TMP +done + ;; + + *) +# Using -M or some other specific dependency-generating option $MKDEP_CC $MKDEP_CFLAGS $files | \ sed -e 's; \./; ;g' -e 's/ :/:/' | \ $SED > $TMP.sed @@ -170,6 +200,8 @@ $1 !~ /:$/ { } } ' noslash="$NOSLASH" $TMP.sed >> $TMP + ;; +esac cat << _EOF_ >> $TMP