X-Git-Url: https://git.xonotic.org/?p=xonotic%2Fgmqcc.git;a=blobdiff_plain;f=Makefile;h=410a97d19c4c6d98c5c35662aa506581b0f06856;hp=6e6c9452ff8ce26b6e70f89442b0cb9feef17103;hb=f59d557dced178d1b8e6b748dc0d22600fd676db;hpb=480b2fc7b6e88a2ae92231af6bacc382908a4fe2 diff --git a/Makefile b/Makefile index 6e6c945..410a97d 100644 --- a/Makefile +++ b/Makefile @@ -9,22 +9,24 @@ CYGWIN = $(findstring CYGWIN, $(UNAME)) MINGW = $(findstring MINGW32, $(UNAME)) CC ?= clang -CFLAGS += -Wall -Wextra -I. -fno-strict-aliasing -fsigned-char -Wno-overlength-strings +CFLAGS += -Wall -Wextra -Werror -I. -fno-strict-aliasing -fsigned-char ifneq ($(shell git describe --always 2>/dev/null),) CFLAGS += -DGMQCC_GITINFO="\"$(shell git describe --always)\"" endif #turn on tons of warnings if clang is present # but also turn off the STUPID ONES ifeq ($(CC), clang) - CFLAGS += \ - -Weverything \ - -Wno-padded \ - -Wno-format-nonliteral \ - -Wno-disabled-macro-expansion \ - -Wno-conversion \ - -Wno-missing-prototypes \ - -Wno-float-equal \ - -Wno-cast-align + CFLAGS += \ + -Weverything \ + -Wno-padded \ + -Wno-format-nonliteral \ + -Wno-disabled-macro-expansion \ + -Wno-conversion \ + -Wno-missing-prototypes \ + -Wno-float-equal \ + -Wno-cast-align \ + -Wno-missing-variable-declarations \ + -Wno-unknown-warning-option else #Tiny C Compiler doesn't know what -pedantic-errors is # and instead of ignoring .. just errors. @@ -39,10 +41,11 @@ ifeq ($(track), no) CFLAGS += -DNOTRACK endif -OBJ_D = util.o code.o ast.o ir.o conout.o ftepp.o opts.o file.o utf8.o correct.o -OBJ_T = test.o util.o conout.o file.o -OBJ_C = main.o lexer.o parser.o file.o -OBJ_X = exec-standalone.o util.o conout.o file.o +OBJ_D = util.o code.o ast.o ir.o conout.o ftepp.o opts.o fs.o utf8.o correct.o +OBJ_P = util.o fs.o conout.o opts.o pak.o +OBJ_T = test.o util.o conout.o fs.o +OBJ_C = main.o lexer.o parser.o fs.o +OBJ_X = exec-standalone.o util.o conout.o fs.o ifneq ("$(CYGWIN)", "") #nullify the common variables that @@ -54,6 +57,7 @@ ifneq ("$(CYGWIN)", "") QCVM = qcvm.exe GMQCC = gmqcc.exe TESTSUITE = testsuite.exe + PAK = pak.exe else ifneq ("$(MINGW)", "") #nullify the common variables that @@ -65,6 +69,7 @@ ifneq ("$(MINGW)", "") QCVM = qcvm.exe GMQCC = gmqcc.exe TESTSUITE = testsuite.exe + PAK = pak.exe else #arm support for linux .. we need to allow unaligned accesses #to memory otherwise we just segfault everywhere @@ -75,6 +80,7 @@ else QCVM = qcvm GMQCC = gmqcc TESTSUITE = testsuite + PAK = pak endif endif @@ -144,17 +150,20 @@ $(GMQCC): $(OBJ_C) $(OBJ_D) $(CC) -o $@ $^ $(CFLAGS) $(TESTSUITE): $(OBJ_T) + $(CC) -o $@ $^ $(CFLAGS) -lm + +$(PAK): $(OBJ_P) $(CC) -o $@ $^ $(CFLAGS) -all: $(GMQCC) $(QCVM) $(TESTSUITE) +all: $(GMQCC) $(QCVM) $(TESTSUITE) $(PAK) check: all @ ./$(TESTSUITE) -test: check +test: all @ ./$(TESTSUITE) clean: - rm -f *.o $(GMQCC) $(QCVM) $(TESTSUITE) *.dat + rm -f *.o $(GMQCC) $(QCVM) $(TESTSUITE) $(PAK) *.dat splint: @ splint $(SPLINTFLAGS) *.c *.h @@ -168,6 +177,8 @@ depend: $(subst .o,.c,$(OBJ_C)) @makedepend -a -Y -w 65536 2> /dev/null \ $(subst .o,.c,$(OBJ_X)) + @makedepend -a -Y -w 65536 2> /dev/null \ + $(subst .o,.c,$(OBJ_P)) #install rules install: install-gmqcc install-qcvm install-doc @@ -197,20 +208,20 @@ ir.o: gmqcc.h opts.def ir.h conout.o: gmqcc.h opts.def ftepp.o: gmqcc.h opts.def lexer.h opts.o: gmqcc.h opts.def -file.o: gmqcc.h opts.def +fs.o: gmqcc.h opts.def utf8.o: gmqcc.h opts.def correct.o: gmqcc.h opts.def test.o: gmqcc.h opts.def util.o: gmqcc.h opts.def conout.o: gmqcc.h opts.def -file.o: gmqcc.h opts.def +fs.o: gmqcc.h opts.def main.o: gmqcc.h opts.def lexer.h lexer.o: gmqcc.h opts.def lexer.h parser.o: gmqcc.h opts.def lexer.h ast.h ir.h -file.o: gmqcc.h opts.def +fs.o: gmqcc.h opts.def util.o: gmqcc.h opts.def conout.o: gmqcc.h opts.def -file.o: gmqcc.h opts.def +fs.o: gmqcc.h opts.def