]> granicus.if.org Git - postgresql/commitdiff
Enable script to generate preproc.y in build process.
authorMichael Meskes <meskes@postgresql.org>
Fri, 14 Nov 2008 17:11:40 +0000 (17:11 +0000)
committerMichael Meskes <meskes@postgresql.org>
Fri, 14 Nov 2008 17:11:40 +0000 (17:11 +0000)
src/interfaces/ecpg/preproc/.cvsignore
src/interfaces/ecpg/preproc/Makefile
src/tools/msvc/Solution.pm

index ae37387ece53b8fc19c2cc7860f01f883d9ad741..b89e31967286627ee5e81933496d134576f54084 100644 (file)
@@ -1,3 +1,4 @@
+preproc.y
 preproc.c
 preproc.h
 pgc.c
index 3cfd52cf0f59d6407ad48288fd4b26086bb65224..75fc31f2b95d48b44f4f1914fbad0ba34ebc85b9 100644 (file)
@@ -4,7 +4,7 @@
 #
 # Copyright (c) 1998-2008, PostgreSQL Global Development Group
 #
-# $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/Makefile,v 1.137 2008/10/14 09:31:04 meskes Exp $
+# $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/Makefile,v 1.138 2008/11/14 17:11:40 meskes Exp $
 #
 #-------------------------------------------------------------------------
 
@@ -38,27 +38,30 @@ preproc.o: $(srcdir)/pgc.c
 
 $(srcdir)/preproc.h: $(srcdir)/preproc.c ;
 
-$(srcdir)/preproc.c: preproc.y
+$(srcdir)/preproc.c: $(srcdir)/preproc.y
 ifdef BISON
        $(BISON) -d $(BISONFLAGS) -o $@ $<
 else
        @$(missing) bison $< $@
 endif
 
-$(srcdir)/pgc.c: pgc.l
+$(srcdir)/pgc.c: $(srcdir)/pgc.l
 ifdef FLEX
        $(FLEX) $(FLEXFLAGS) -o'$@' $<
 else
        @$(missing) flex $< $@
 endif
 
+$(srcdir)/preproc.y: $(top_srcdir)/src/backend/parser/gram.y
+       $(PERL) $(srcdir)/parse.pl $(srcdir) < $< > $@ 
+
 ecpg_keywords.o c_keywords.o keywords.o preproc.o parser.o: preproc.h
 
 # instead of maintaining our own list, take the one from the backend
 keywords.c: % : $(top_srcdir)/src/backend/parser/%
        rm -f $@ && $(LN_S) $< .
 
-distprep: $(srcdir)/preproc.c $(srcdir)/preproc.h $(srcdir)/pgc.c
+distprep: $(srcdir)/preproc.y $(srcdir)/preproc.c $(srcdir)/preproc.h $(srcdir)/pgc.c
 
 install: all installdirs
        $(INSTALL_PROGRAM) ecpg$(X) '$(DESTDIR)$(bindir)'
@@ -78,4 +81,4 @@ clean distclean:
 # want to ship those files in the distribution for people with
 # inadequate tools.
 maintainer-clean: distclean
-       rm -f $(srcdir)/preproc.c $(srcdir)/preproc.h $(srcdir)/pgc.c
+       rm -f $(srcdir)/preproc.y $(srcdir)/preproc.c $(srcdir)/preproc.h $(srcdir)/pgc.c
index 3c31c63359ebb9ece1ee387e3f9b1016ddb6c1dc..2fa7b20909c7f5dc6bd8275e9d472324f5c593c8 100644 (file)
@@ -3,7 +3,7 @@ package Solution;
 #
 # Package that encapsulates a Visual C++ solution file generation
 #
-# $PostgreSQL: pgsql/src/tools/msvc/Solution.pm,v 1.44 2008/08/16 12:42:27 mha Exp $
+# $PostgreSQL: pgsql/src/tools/msvc/Solution.pm,v 1.45 2008/11/14 17:11:40 meskes Exp $
 #
 use Carp;
 use strict;
@@ -237,6 +237,19 @@ s{PG_VERSION_STR "[^"]+"}{__STRINGIFY(x) #x\n#define __STRINGIFY2(z) __STRINGIFY
         chdir('..\..\..');
     }
 
+    if (
+        IsNewer(
+            'src\interfaces\ecpg\preproc\preproc.y',
+            'src\backend\parser\gram.y'
+        )
+      )
+    {
+        print "Generating preproc.y...\n";
+        chdir('src\interfaces\ecpg\preproc');
+        system('perl parse.pl < ..\..\..\backend\parser\gram.y > preproc.y');
+        chdir('..\..\..\..');
+    }
+
     if (
         IsNewer(
             'src\interfaces\ecpg\include\ecpg_config.h',