OSDN Git Service

Add updates.
authorBruce Momjian <bruce@momjian.us>
Thu, 15 Jul 1999 16:55:32 +0000 (16:55 +0000)
committerBruce Momjian <bruce@momjian.us>
Thu, 15 Jul 1999 16:55:32 +0000 (16:55 +0000)
src/tools/pginclude/pginclude
src/tools/pginclude/pgnoinclude

index afaa6ad..c0b6795 100755 (executable)
@@ -5,7 +5,7 @@ do
        sed 's/->[a-zA-Z0-9_\.]*//g' "$FILE" >/tmp/$$a
        echo "#include \"postgres.h\"" >/tmp/$$.c
        echo "#include \"/tmp/$$a\"" >>/tmp/$$.c
-       echo "void main() {" >>/tmp/$$.c
+       echo "void include_test() {" >>/tmp/$$.c
        pgdefine "$FILE" >>/tmp/$$.c
        echo "}" >>/tmp/$$.c
        cc -Werror -Wall -I/pg/include -I/pg/backend -c /tmp/$$.c -o /tmp/$$.o >/tmp/$$ 2>&1
index 41c3159..c7825a0 100755 (executable)
@@ -1,9 +1,18 @@
 :
 trap "rm -f /tmp/$$.c /tmp/$$.o /tmp/$$ /tmp/$$a /tmp/$$b" 0 1 2 3 15
-find . \( -name CVS -a -prune \) -o -type f -print | while read FILE
+find . \( -name CVS -a -prune \) -o -type f -print | grep -v postgres.h |
+while read FILE
 do
-       cat "$FILE" | grep -v "^#if" | grep -v "^#else" | 
+       if [ "`echo $FILE | sed -n 's/^.*\.\([^\.]*\)$/\1/p'`" = "h" ]
+       then    IS_INCLUDE="Y"
+       else    IS_INCLUDE="N"
+       fi
+
+       if [ "$IS_INCLUDE" = "Y" ]
+       then    cat "$FILE" | grep -v "^#if" | grep -v "^#else" | 
                grep -v "^#endif" | sed 's/->[a-zA-Z0-9_\.]*//g' >/tmp/$$a
+       else    cat "$FILE" >/tmp/$$a
+       fi
        cat /tmp/$$a | grep "^#include" |
        sed 's/#include[        ]*[<"]\([^>"]*\).*$/\1/g' |
        while read INCLUDE
@@ -11,14 +20,23 @@ do
                [ -s /usr/include/$INCLUDE ] && continue
                cat /tmp/$$a |
                grep -v '^#include[     ]*[<"]'"$INCLUDE"'[>"]' >/tmp/$$b
-               echo "#include \"postgres.h\"" >/tmp/$$.c
+               if [ "$IS_INCLUDE" = "Y" ]
+               then    echo "#include \"postgres.h\"" >/tmp/$$.c
+               else    >/tmp/$$.c
+               fi
                echo "#include \"/tmp/$$b\"" >>/tmp/$$.c
-               echo "void main() {" >>/tmp/$$.c
-               pgdefine "$FILE" >>/tmp/$$.c
+               echo "void include_test() {" >>/tmp/$$.c
+               if [ "$IS_INCLUDE" = "Y" ]
+               then    pgdefine "$FILE" >>/tmp/$$.c
+               fi
                echo "}" >>/tmp/$$.c
                cc -Werror -Wall -I/pg/include -I/pg/backend -c /tmp/$$.c -o /tmp/$$.o >/tmp/$$ 2>&1
                if [ "$?" -eq 0 ]
                then    echo "$FILE $INCLUDE"
+                       if [ "$IS_INCLUDE" = "N" ]
+                       then    grep -v '#include[      ]*[<"]$FILE[>"]' >/tmp/$$a
+                               mv /tmp/$$a "$FILE"
+                       fi
                        if [ "$1" = "-v" ]
                        then    cat /tmp/$$
                                cat /tmp/$$.c