Generate newdb.[ch] at build time, parallel with database.[ch].
[open-adventure.git] / Makefile
index 0b3e9a75e964fe6abe9715efebe4b2368fc77b20..08a0fbbd2b4ad3d6f7bc533f913f4aff9cb548de 100644 (file)
--- a/Makefile
+++ b/Makefile
 VERS=1.0
 
 CC?=gcc
-CCFLAGS+=-std=c99 -D _DEFAULT_SOURCE -g
+CCFLAGS+=-std=c99 -D _DEFAULT_SOURCE -Wall -Wpedantic -g
 LIBS=
 UNAME_S := $(shell uname -s)
 ifeq ($(UNAME_S),Linux)
        LIBS=-lrt
 endif
 
-OBJS=main.o init.o actions.o score.o misc.o saveresume.o common.o
-SOURCES=$(OBJS:.o=.c) dungeon.c advent.h common.h adventure.text Makefile control linenoise/linenoise.[ch]
+OBJS=main.o init.o actions.o score.o misc.o saveresume.o common.o newdb.o
+SOURCES=$(OBJS:.o=.c) dungeon.c advent.h common.h adventure.text Makefile control linenoise/linenoise.[ch] newdungeon.py
 
 .c.o:
        $(CC) $(CCFLAGS) $(DBX) -c $<
@@ -30,7 +30,7 @@ SOURCES=$(OBJS:.o=.c) dungeon.c advent.h common.h adventure.text Makefile contro
 advent:        $(OBJS) database.o linenoise.o
        $(CC) $(CCFLAGS) $(DBX) -o advent $(OBJS) database.o linenoise.o $(LDFLAGS) $(LIBS)
 
-main.o:                advent.h database.h database.c common.h
+main.o:                advent.h database.h database.c common.h newdb.h
 
 init.o:                advent.h database.h database.c common.h
 
@@ -38,7 +38,7 @@ actions.o:    advent.h database.h database.c common.h
 
 score.o:       advent.h database.h database.c common.h
 
-misc.o:                advent.h database.h database.c common.h
+misc.o:                advent.h database.h database.c common.h newdb.h
 
 saveresume.o:  advent.h database.h database.c common.h
 
@@ -47,17 +47,24 @@ common.o:   common.h
 database.o:     database.c database.h common.h
        $(CC) $(CCFLAGS) $(DBX) -c database.c
 
+newdb.o:       newdb.c newdb.h
+       $(CC) $(CCFLAGS) $(DBX) -c newdb.c
+
 database.c database.h: dungeon
        ./dungeon
 
+newdb.c newdb.h:
+       ./newdungeon.py
+
 linenoise.o:   linenoise/linenoise.h
-       $(CC) $(CCFLAGS) $(DBX) -c linenoise/linenoise.c
+       $(CC) -c linenoise/linenoise.c
 
 dungeon: dungeon.o common.o
        $(CC) $(CCFLAGS) -o $@ dungeon.o common.o
 
 clean:
        rm -f *.o advent *.html database.[ch] dungeon *.gcno *.gcda
+       rm -f newdb.c newdb.h
        rm -f README advent.6 MANIFEST *.tar.gz
        rm -f *~
        cd tests; $(MAKE) --quiet clean
@@ -78,7 +85,7 @@ check: advent
 html: advent.html history.html hints.html
 
 # README.adoc exists because that filename is magic on GitLab.
-DOCS=COPYING NEWS README.adoc TODO advent.adoc history.adoc hints.adoc advent.6
+DOCS=COPYING NEWS README.adoc TODO advent.adoc history.adoc notes.adoc hints.adoc advent.6
 TESTFILES=tests/*.log tests/*.chk tests/README tests/decheck tests/Makefile
 
 # Can't use GNU tar's --transform, needs to build under Alpine Linux.
@@ -89,7 +96,7 @@ advent-$(VERS).tar.gz: $(SOURCES) $(DOCS)
        (tar -T MANIFEST -czvf advent-$(VERS).tar.gz)
        @(rm advent-$(VERS))
 
-release: advent-$(VERS).tar.gz advent.html history.html hints.html
+release: advent-$(VERS).tar.gz advent.html history.html hints.html notes.html
        shipper version=$(VERS) | sh -e -x
 
 refresh: advent.html
@@ -97,5 +104,5 @@ refresh: advent.html
 
 dist: advent-$(VERS).tar.gz
 
-debug: CCFLAGS += -O0 --coverage
+debug: CCFLAGS += -O0 --coverage -g
 debug: advent