]> git.sur5r.net Git - openldap/blobdiff - build/mkdep
forced change for testing
[openldap] / build / mkdep
index 420657ccceb9b2f134fedf6079b78c052163d0c5..4384b2853f57e1abf2dd3d052d98305c7e8a7fd7 100755 (executable)
@@ -1,7 +1,8 @@
 #! /bin/sh -
-# Copyright 1998,1999 The OpenLDAP Foundation
-# COPYING RESTRICTIONS APPLY.  See COPYRIGHT File in top level directory
-# of this package for details.
+# $OpenLDAP$
+## Copyright 1998-2002 The OpenLDAP Foundation
+## COPYING RESTRICTIONS APPLY.  See COPYRIGHT File in top level directory
+## of this package for details.
 #
 # Portions
 # Copyright (c) 1987 Regents of the University of California.
@@ -32,9 +33,11 @@ NOSLASH="no"                 # by default, / dependencies are included
 SRCDIR=""
 SED=cat
 
-: ${CC=cc}
-: ${CC_MKDEP=$CC}
-: ${CC_MKDEP_FLAGS="-M"}       # cc -M usually produces dependencies
+: ${CC=cc}                                     # use cc by default
+
+# We generally set these via the command line options
+: ${MKDEP_CC=$CC}                      # select default compiler to generate dependencies
+: ${MKDEP_CFLAGS="-M"} # cc -M usually produces dependencies
 
 while :
        do case "$1" in
@@ -53,9 +56,15 @@ while :
                        SRCDIR=$2
                        shift; shift ;;
 
-               # -c allows you to select a compiler to use (default is cc)
+               # -c allows you to override the compiler used to generate dependencies
                -c)
-                       test -z "$CC_MKDEP" && CC_MKDEP=$2
+                       MKDEP_CC=$2
+                       shift; shift ;;
+
+               # -m allows you to override the compiler flags used to generate
+               # dependencies.
+               -m)
+                       MKDEP_CFLAGS=$2
                        shift; shift ;;
 
                # the -p flag produces "program: program.c" style dependencies
@@ -64,7 +73,6 @@ while :
                        SED='sed -e s;\.o;;'
                        shift ;;
 
-
                # the -l flag produces libtool compatible dependencies
                -l)
                        SED='sed -e s;\.o:;.lo:;'
@@ -78,7 +86,7 @@ while :
 done
 
 if test $# = 0 ; then
-       echo 'usage: mkdep [-p] [-s] [-c cc] [-f makefile] [-d srcdir] [flags] file ...'
+       echo 'usage: mkdep [-p] [-s] [-c cc] [-m flags] [-f makefile] [-d srcdir] [cppflags] file ...'
        exit 1
 fi
 
@@ -101,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=$*
@@ -122,42 +128,80 @@ else
                        files="$files $i"
                fi
        done
-       CC="$CC -I$SRCDIR"
+
+       MKDEP_CFLAGS="$MKDEP_CFLAGS -I$SRCDIR"
 fi
 
 cat << _EOF_ >> $TMP
 
 #
 # files: $*
-# command: $CC $CC_MKDEP_FLAGS $files
+# command: $MKDEP_CC $MKDEP_CFLAGS $files
 #
 
 _EOF_
 
-$CC_MKDEP $CC_MKDEP_FLAGS $files | \
-       sed -e 's; \./; ;g' | \
+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
-# dont pipe to awk.  SGI awk wants a filename as argument.
+# do not pipe to awk.  SGI awk wants a filename as argument.
 # (or '-', but I do not know if all other awks support that.)
 awk '
-$1 ~ /:/ {
-       filenm=$1;
-       dep=substr($0, length(filenm)+1);
+$1 ~ /:$/ {
+       filenm=$1
+       dep=substr($0, length(filenm)+1)
 }
-$1 !~ /:/ {
-       dep=$0;
+$1 !~ /:$/ {
+       dep=$0
 }
 /.*/ {
-       split(dep, depends, " ");
+       if ( length(filenm) < 2 ) next
+       if ( filenm ~ /:.*:$/ ) next
+       split(dep, depends, " ")
        for(d in depends) {
-               dfile = depends[d];
-               if (( noslash == "yes") && (dfile ~ /^\// )) next
+               dfile = depends[d]
                if ( length(dfile) < 2 ) continue
-               rec = filenm " " dfile;
-               print rec;
+               if ( dfile ~ /:/ ) continue
+               if (( noslash == "yes") && (dfile ~ /^\// )) continue
+               rec = filenm " " dfile
+               print rec
        }
-    }
+}
 ' noslash="$NOSLASH" $TMP.sed >> $TMP
+       ;;
+esac
 
 
 cat << _EOF_ >> $TMP