newdungeon.py is now make_dungeon.py.
[open-adventure.git] / Makefile
index 11795079fab5059db4464689c51006a790280439..d16b12b8f0cfb36814af8d3d332b8d6a23da2835 100644 (file)
--- a/Makefile
+++ b/Makefile
 VERS=1.0
 
 CC?=gcc
-CCFLAGS+=-std=c99 -D _DEFAULT_SOURCE -Wpedantic -g
+CCFLAGS+=-std=c99 -D _DEFAULT_SOURCE -Wpedantic -O2
 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] newdungeon.py
+OBJS=main.o init.o actions.o score.o misc.o saveresume.o
+CHEAT_OBJS=cheat.o init.o actions.o score.o misc.o saveresume.o
+SOURCES=$(OBJS:.o=.c) advent.h adventure.text adventure.yaml Makefile control linenoise/linenoise.[ch] newdungeon.py
 
 .c.o:
        $(CC) $(CCFLAGS) $(DBX) -c $<
@@ -45,46 +46,48 @@ SOURCES=$(OBJS:.o=.c) dungeon.c advent.h common.h adventure.text Makefile contro
 advent:        $(OBJS) linenoise.o newdb.o
        $(CC) $(CCFLAGS) $(DBX) -o advent $(OBJS) newdb.o linenoise.o $(LDFLAGS) $(LIBS)
 
-main.o:                advent.h database.h common.h newdb.h
+main.o:                advent.h newdb.h
 
-init.o:                advent.h database.h common.h newdb.h
+init.o:                advent.h newdb.h
 
-actions.o:     advent.h database.h common.h newdb.h
+actions.o:     advent.h newdb.h
 
-score.o:       advent.h database.h common.h newdb.h
+score.o:       advent.h newdb.h
 
-misc.o:                advent.h database.h common.h newdb.h
+misc.o:                advent.h newdb.h
 
-saveresume.o:  advent.h database.h common.h newdb.h
+cheat.o:       advent.h newdb.h
 
-common.o:      common.h
+saveresume.o:  advent.h newdb.h
 
 newdb.o:       newdb.c newdb.h
        $(CC) $(CCFLAGS) $(DBX) -c newdb.c
 
-database.h: dungeon
-       ./dungeon
-
-newdb.c newdb.h:
+newdb.c newdb.h: newdungeon.py adventure.yaml
        python3 newdungeon.py
 
 linenoise.o:   linenoise/linenoise.h
-       $(CC) -c linenoise/linenoise.c
-
-dungeon: dungeon.o common.o
-       $(CC) $(CCFLAGS) -o $@ dungeon.o common.o
+       $(CC) $(CCFLAGS) -c linenoise/linenoise.c
 
 clean:
-       rm -f *.o advent *.html database.h dungeon *.gcno *.gcda
+       rm -f *.o advent cheat *.html *.gcno *.gcda
        rm -f newdb.c newdb.h
        rm -f README advent.6 MANIFEST *.tar.gz
        rm -f *~
        rm -f .*~
+       rm -rf coverage advent.info
        cd tests; $(MAKE) --quiet clean
 
-check: advent
+
+cheat: $(CHEAT_OBJS) linenoise.o newdb.o 
+       $(CC) $(CCFLAGS) $(DBX) -o cheat $(CHEAT_OBJS) linenoise.o newdb.o $(LDFLAGS) $(LIBS)
+
+check: advent cheat
        cd tests; $(MAKE) --quiet
 
+coverage: debug cheat
+       cd tests; $(MAKE) coverage --quiet
+
 .SUFFIXES: .adoc .html .6
 
 # Requires asciidoc and xsltproc/docbook stylesheets.
@@ -115,7 +118,7 @@ indent:
 release: advent-$(VERS).tar.gz advent.html history.html hints.html notes.html
        shipper version=$(VERS) | sh -e -x
 
-refresh: advent.html
+refresh: advent.html notes.html history.html
        shipper -N -w version=$(VERS) | sh -e -x
 
 dist: advent-$(VERS).tar.gz
@@ -138,8 +141,10 @@ linty: CCFLAGS += -Wwrite-strings
 linty: CCFLAGS += -Wunreachable-code
 linty: CCFLAGS += -Winit-self
 linty: CCFLAGS += -Wpointer-arith
-linty: CCFLAGS +=-O2 
 linty: advent
 
-debug: CCFLAGS += -O0 --coverage -g
-debug: advent
+debug: CCFLAGS += -O0 --coverage -ggdb
+debug: linty
+debug: cheat
+
+