summaryrefslogtreecommitdiff
path: root/src/backend/bootstrap/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'src/backend/bootstrap/Makefile')
-rw-r--r--src/backend/bootstrap/Makefile71
1 files changed, 71 insertions, 0 deletions
diff --git a/src/backend/bootstrap/Makefile b/src/backend/bootstrap/Makefile
new file mode 100644
index 0000000000..66ed86f3c5
--- /dev/null
+++ b/src/backend/bootstrap/Makefile
@@ -0,0 +1,71 @@
+#-------------------------------------------------------------------------
+#
+# Makefile--
+# Makefile for the bootstrap module
+#
+# IDENTIFICATION
+# $Header: /cvsroot/pgsql/src/backend/bootstrap/Makefile,v 1.1 1996/10/27 09:46:59 bryanh Exp $
+#
+#
+# We must build bootparse.c and bootscanner.c with yacc and lex and sed,
+# but bootstrap.c is part of the distribution.
+#
+# Another kinda weird Makefile cause we need two
+# scanner/parsers in the backend and most yaccs and lexs
+# don't have the prefix option.
+#
+# sed files are HACK CITY! - redo...
+#
+#-------------------------------------------------------------------------
+
+SRCDIR = ../..
+include ../../Makefile.global
+
+INCLUDE_OPT = -I.. \
+ -I../port/$(PORTNAME) \
+ -I../include \
+ -I../../include
+
+CFLAGS += $(INCLUDE_OPT)
+
+BOOTYACCS = bootstrap_tokens.h bootparse.c
+
+OBJS = bootparse.o bootscanner.o bootstrap.o
+
+all: SUBSYS.o
+
+SUBSYS.o: $(OBJS)
+ ld -r -o SUBSYS.o $(OBJS)
+
+# bootstrap.o's dependency on bootstrap_tokens.h is computed by the
+# make depend, but we state it here explicitly anyway because
+# bootstrap_tokens.h doesn't even exist at first and if user fails to
+# do make depend, we still want the build to succeed.
+
+bootstrap.o: bootstrap_tokens.h
+
+bootstrap_tokens.h bootparse.c: bootparse.y
+ $(YACC) $(YFLAGS) $<
+ sed -f boot.sed < y.tab.c > bootparse.c
+ mv y.tab.h bootstrap_tokens.h
+ rm -f y.tab.c
+
+bootscanner.c: bootscanner.l
+ $(LEX) $<
+ sed -f boot.sed < lex.yy.c > bootscanner.c
+ rm -f lex.yy.c
+
+clean:
+ rm -f SUBSYS.o $(OBJS) bootparse.c bootstrap_tokens.h bootscanner.c
+# And the garbage that might have been left behind by partial build:
+ rm -f y.tab.h y.tab.c y.output lex.yy.c
+
+# This is unusual: We actually have to build some of the parts before
+# we know what the header file dependencies are.
+dep: bootparse.c bootscanner.c bootstrap_tokens.h
+ $(CC) -MM $(INCLUDE_OPT) *.c >depend
+
+ifeq (depend,$(wildcard depend))
+include depend
+endif
+