X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=Makefile;h=c78e4cdf2b19b480c6fa9b24f6a864a2aae5276e;hb=955032bd24b022664eb0dc67c2a66cc45fabb6fa;hp=62c333f75b94b0fde6404dacc24b66dd8b2eef30;hpb=495f4afbe02fe5b7dd37d5c654ec123a031cdf3e;p=open-adventure.git diff --git a/Makefile b/Makefile index 62c333f..c78e4cd 100644 --- a/Makefile +++ b/Makefile @@ -3,7 +3,7 @@ VERS=1.0 CC?=gcc -CCFLAGS+=-std=c99 +CCFLAGS+=-std=c99 -D _DEFAULT_SOURCE LIBS= UNAME_S := $(shell uname -s) ifeq ($(UNAME_S),Linux) @@ -11,42 +11,42 @@ ifeq ($(UNAME_S),Linux) endif OBJS=main.o init.o actions1.o actions2.o score.o misc.o -SOURCES=$(OBJS:.o=.c) compile.c advent.h funcs.h adventure.text Makefile control +SOURCES=$(OBJS:.o=.c) dungeon.c advent.h funcs.h sizes.h adventure.text Makefile control linenoise/linenoise.h .c.o: $(CC) $(CCFLAGS) $(DBX) -c $< -advent: $(OBJS) database.o - $(CC) $(CCFLAGS) $(DBX) -o advent $(OBJS) database.o $(LDFLAGS) $(LIBS) +advent: $(OBJS) database.o linenoise.o + $(CC) $(CCFLAGS) $(DBX) -o advent $(OBJS) database.o linenoise.o $(LDFLAGS) $(LIBS) -main.o: advent.h funcs.h database.h +main.o: advent.h funcs.h database.h database.c sizes.h -init.o: advent.h funcs.h database.h +init.o: advent.h funcs.h database.h database.c sizes.h -actions1.o: advent.h funcs.h database.h +actions1.o: advent.h funcs.h database.h database.c sizes.h -actions2.o: advent.h funcs.h +actions2.o: advent.h funcs.h database.h database.c sizes.h -score.o: advent.h database.h +score.o: advent.h database.h database.c sizes.h -misc.o: advent.h database.h +misc.o: advent.h database.h database.c sizes.h -database.o: database.h - -funcs.h: database.h +database.o: database.c database.h sizes.h + $(CC) $(CCFLAGS) $(DBX) -c database.c -compile: compile.c - $(CC) $(CCFLAGS) -o $@ $< +database.c database.h: dungeon + ./dungeon -database.c database.h: compile adventure.text - ./compile - $(CC) $(CCFLAGS) $(DBX) -c database.c +linenoise.o: linenoise/linenoise.h + $(CC) $(CCFLAGS) $(DBX) -c linenoise/linenoise.c -html: index.html advent.html history.html hints.html +dungeon: dungeon.c + $(CC) $(CCFLAGS) -o $@ $< clean: - rm -f *.o advent *.html database.[ch] compile *.gcno *.gcda - rm -f README advent.6 + rm -f *.o advent *.html database.[ch] dungeon *.gcno *.gcda + rm -f README advent.6 MANIFEST *.tar.gz + rm -f *~ cd tests; $(MAKE) --quiet clean check: advent @@ -62,12 +62,25 @@ check: advent .adoc: asciidoc $< +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 index.adoc hints.adoc advent.6 +DOCS=COPYING NEWS README.adoc TODO advent.adoc history.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. +# This is a requirement for testing dist in GitLab's CI pipeline advent-$(VERS).tar.gz: $(SOURCES) $(DOCS) - tar --transform='s:^:advent-$(VERS)/:' --show-transformed-names -cvzf advent-$(VERS).tar.gz $(SOURCES) $(DOCS) + @find $(SOURCES) $(DOCS) $(TESTFILES) -print | sed s:^:advent-$(VERS)/: >MANIFEST + @(ln -s . advent-$(VERS)) + (tar -T MANIFEST -czvf advent-$(VERS).tar.gz) + @(rm advent-$(VERS)) + +release: advent-$(VERS).tar.gz advent.html history.html hints.html + shipper version=$(VERS) | sh -e -x + +refresh: advent.html + shipper -N -w version=$(VERS) | sh -e -x dist: advent-$(VERS).tar.gz