X-Git-Url: https://de.git.xonotic.org/?p=xonotic%2Fgmqcc.git;a=blobdiff_plain;f=Makefile;h=0e23a92a3b9b204ec4af272c6bbe20e1cc8f119d;hp=eae6f3e65860d859a1f9380119835ca2625d2347;hb=38a664ed7278182abee133cb477d6e594491c835;hpb=145c011247d08fff52d6adb74c6deb5d9c620e12 diff --git a/Makefile b/Makefile index eae6f3e..0e23a92 100644 --- a/Makefile +++ b/Makefile @@ -9,7 +9,8 @@ CYGWIN = $(findstring CYGWIN, $(UNAME)) MINGW = $(findstring MINGW32, $(UNAME)) CC ?= clang -CFLAGS += -Wall -Wextra -I. -pedantic-errors +CFLAGS += -Wall -Wextra -I. -fno-strict-aliasing -fsigned-char +CFLAGS += -DGMQCC_GITINFO="`git describe`" #turn on tons of warnings if clang is present # but also turn off the STUPID ONES ifeq ($(CC), clang) @@ -19,16 +20,27 @@ ifeq ($(CC), clang) -Wno-format-nonliteral \ -Wno-disabled-macro-expansion \ -Wno-conversion \ - -Wno-missing-prototypes + -Wno-missing-prototypes \ + -Wno-float-equal \ + -Wno-cast-align +else + #Tiny C Compiler doesn't know what -pedantic-errors is + # and instead of ignoring .. just errors. + ifneq ($(CC), tcc) + CFLAGS +=-pedantic-errors + else + CFLAGS += -Wno-pointer-sign -fno-common + endif endif + ifeq ($(track), no) CFLAGS += -DNOTRACK endif -OBJ_D = util.o code.o ast.o ir.o conout.o ftepp.o opts.o -OBJ_T = test.o util.o conout.o -OBJ_C = main.o lexer.o parser.o -OBJ_X = exec-standalone.o util.o conout.o +OBJ_D = util.o code.o ast.o ir.o conout.o ftepp.o opts.o file.o utf8.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 ifneq ("$(CYGWIN)", "") #nullify the common variables that @@ -52,6 +64,12 @@ ifneq ("$(MINGW)", "") GMQCC = gmqcc.exe TESTSUITE = testsuite.exe else + #arm support for linux .. we need to allow unaligned accesses + #to memory otherwise we just segfault everywhere + ifneq (, $(findstring arm, $(shell uname -m))) + CFLAGS += -munaligned-access + endif + QCVM = qcvm GMQCC = gmqcc TESTSUITE = testsuite @@ -87,6 +105,7 @@ clean: $(OBJ_D) $(OBJ_C) $(OBJ_X): gmqcc.h opts.def main.o: lexer.h parser.o: ast.h lexer.h +lexer.o: lexer.h ast.o: ast.h ir.h ir.o: ir.h