]> git.sur5r.net Git - c128-kasse/blobdiff - Makefile
Merge pull request #11 from 9b17fe/remove-dual-monitor
[c128-kasse] / Makefile
index 40ab3c06c40431d5421ae3b86c0fbaae1ce68719..812283a9f1d931e0ad5daabe41c2a8faf68df2a4 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,46 +1,51 @@
-src/%.o: src/%.c include/%.h
-       cc65 -O -I include -t c128 $<
-       ca65 -I include -t c128 src/$$(basename $< .c).s
+CC=cc65
+AS=ca65
+LD=cl65
+INCLUDES:=$(wildcard include/*.h) include/version.h
+GV:=$(shell git describe --tags --always)
+CFLAGS= -I include -t c128
 
-test/%.o: test/%.c
-       cc65 -O -I include -t c128 $<
-       ca65 -I include -t c128 test/$$(basename $< .c).s
+.PHONY: include/version.h clean dist-clean format
 
-kasse: src/config.o src/kasse.o src/general.o src/credit_manager.o src/c128time.o
-       cl65 -t c128 src/c128time.o src/config.o src/kasse.o src/general.o src/credit_manager.o -o kasse
+all: kasse itemz
 
-itemz: src/config.o src/itemz.o src/general.o src/credit_manager.o
-       cl65 -t c128 src/config.o src/itemz.o src/general.o src/credit_manager.o -o itemz
+%.o: %.c ${INCLUDES}
+       ${CC} ${CFLAGS} -O $<
+       ${AS} ${CFLAGS} $(addsuffix .s,$(basename $< ))
 
-cat: src/general.o src/cat.o
-       cl65 -t c128 src/general.o src/cat.o -o cat
+include/version.h:
+       echo "#define GV \"${GV}\"" > $@
 
-all: kasse itemz
+kasse: src/config.o src/kasse.o src/general.o src/credit_manager.o src/c128time.o src/print.o
+       ${LD} -t c128 $^ -o $@
+
+itemz: src/config.o src/itemz.o src/general.o src/credit_manager.o src/c128time.o src/print.o
+       ${LD} -t c128 $^ -o $@
+
+cat: src/general.o src/cat.o
+       ${LD} -t c128 $^ -o $@
 
 package: all
-       cp images/kasse.d64 .
-       c1541 -attach kasse.d64 -delete state || exit 0 
-       c1541 -attach kasse.d64 -delete items || exit 0
-       c1541 -attach kasse.d64 -delete kasse || exit 0
-       c1541 -attach kasse.d64 -delete itemz || exit 0
-       c1541 -attach kasse.d64 -write kasse || exit 0
-       c1541 -attach kasse.d64 -write itemz || exit 0
-#      c1541 -attach kasse.d64 -write state || exit 0 
-#      c1541 -attach kasse.d64 -write items || exit 0
+       c1541 -format "${GV}",KA d64 kasse.d64
+       c1541 -attach kasse.d64 -write kasse
+       c1541 -attach kasse.d64 -write itemz
+       [ -e state ] && c1541 -attach kasse.d64 -write state || exit 0
+       [ -e items ] && c1541 -attach kasse.d64 -write items || exit 0
 
 test: src/config.o test/test.o src/general.o
        cl65 -t c128 src/config.o test/test.o src/general.o -o test
 
 test-package: test
-       c1541 -attach test.d64 -delete state || exit 0 
-       c1541 -attach test.d64 -delete items || exit 0
-       c1541 -attach test.d64 -delete test || exit 0
+       c1541 -format "test",TE d64 test.d64
        c1541 -attach test.d64 -write test || exit 0
-       c1541 -attach test.d64 -write state || exit 0 
+       c1541 -attach test.d64 -write state || exit 0
        c1541 -attach test.d64 -write items || exit 0
 
 clean:
        rm -rf src/*.o src/*.s test/*.o test/*.s
-       
+
 dist-clean: clean
-       rm kasse itemz kasse.d64
+       rm -f kasse itemz kasse.d64
+
+format:
+       clang-format-3.9 -i **/*.[ch]