X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=Makefile;h=530bd4cd4ea42249b3315b14951ec65724b3e56a;hb=41a76ab91dc6f872b03cd64f51aba86578f330c0;hp=63b41c629bfae99d7c0c8ace28a1a63bfba1ae8d;hpb=2e57a952a702a2b591cabc9fb857d4cf0811e3a7;p=xonotic%2Fgmqcc.git diff --git a/Makefile b/Makefile index 63b41c6..530bd4c 100644 --- a/Makefile +++ b/Makefile @@ -1,34 +1,55 @@ -DESTDIR := -PREFIX := /usr/local -BINDIR := $(PREFIX)/bin -DATADIR := $(PREFIX)/share -MANDIR := $(DATADIR)/man +include include.mk UNAME ?= $(shell uname) -CYGWIN = $(findstring CYGWIN, $(UNAME)) -MINGW = $(findstring MINGW32, $(UNAME)) +CYGWIN = $(findstring CYGWIN, $(UNAME)) +MINGW = $(findstring MINGW, $(UNAME)) -CC ?= clang -CFLAGS += -Wall -Wextra -I. -pedantic-errors -#turn on tons of warnings if clang is present +# 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 + CFLAGS += \ + -Weverything \ + -Wno-padded \ + -Wno-format-nonliteral \ + -Wno-disabled-macro-expansion \ + -Wno-conversion \ + -Wno-float-equal \ + -Wno-unknown-warning-option \ + -Wno-cast-align \ + -Wno-assign-enum \ + -Wno-empty-body \ + -Wno-date-time \ + -pedantic-errors +else + ifneq ($(CC), g++) + CFLAGS += -Wmissing-prototypes -Wstrict-prototypes + endif + + ifneq ($(CC), tcc) + CFLAGS += -pedantic-errors + else + CFLAGS += -Wno-pointer-sign -fno-common + endif +endif + +ifneq ($(shell git describe --always 2>/dev/null),) + CFLAGS += -DGMQCC_GITINFO="\"$(shell git describe --always)\"" endif -ifeq ($(track), no) - CFLAGS += -DNOTRACK + +ifeq ($(shell valgrind --version 2>/dev/null),) + CFLAGS += -DNVALGRIND endif -OBJ_D = util.o code.o ast.o ir.o con.o ftepp.o opts.o -OBJ_T = test.o util.o con.o -OBJ_C = main.o lexer.o parser.o -OBJ_X = exec-standalone.o util.o con.o +# do this last otherwise there is whitespace in the command output and +# it makes my OCD act up +CFLAGS += $(OPTIONAL_CFLAGS) +LDFLAGS += $(OPTIONAL_LDFLAGS) + +#we have duplicate object files when dealing with creating a simple list +#for dependinces. To combat this we use some clever recrusive-make to +#filter the list and remove duplicates which we use for make depend +RMDUP = $(if $1,$(firstword $1) $(call RMDUP,$(filter-out $(firstword $1),$1))) +DEPS := $(call RMDUP, $(OBJ_P) $(OBJ_T) $(OBJ_C) $(OBJ_X)) ifneq ("$(CYGWIN)", "") #nullify the common variables that @@ -40,6 +61,8 @@ ifneq ("$(CYGWIN)", "") QCVM = qcvm.exe GMQCC = gmqcc.exe TESTSUITE = testsuite.exe + PAK = gmqpak.exe + CFLAGS += -DNVALGRIND else ifneq ("$(MINGW)", "") #nullify the common variables that @@ -51,54 +74,94 @@ ifneq ("$(MINGW)", "") QCVM = qcvm.exe GMQCC = gmqcc.exe TESTSUITE = testsuite.exe + PAK = gmqpak.exe + CFLAGS += -DNVALGRIND else QCVM = qcvm GMQCC = gmqcc TESTSUITE = testsuite + PAK = gmqpak endif endif #standard rules -default: all -%.o: %.c - $(CC) -c $< -o $@ $(CFLAGS) - -exec-standalone.o: exec.c - $(CC) -c $< -o $@ $(CFLAGS) -DQCVM_EXECUTOR=1 +c.o: + $(CC) -c $< -o $@ $(CFLAGS) $(CPPFLAGS) $(QCVM): $(OBJ_X) - $(CC) -o $@ $^ $(CFLAGS) -lm + $(CC) -o $@ $^ $(LDFLAGS) $(LIBS) $(GMQCC): $(OBJ_C) $(OBJ_D) - $(CC) -o $@ $^ $(CFLAGS) + $(CC) -o $@ $^ $(LDFLAGS) $(LIBS) $(TESTSUITE): $(OBJ_T) - $(CC) -o $@ $^ $(CFLAGS) + $(CC) -o $@ $^ $(LDFLAGS) $(LIBS) + +$(PAK): $(OBJ_P) + $(CC) -o $@ $^ $(LDFLAGS) -all: $(GMQCC) $(QCVM) $(TESTSUITE) +all: $(GMQCC) $(QCVM) $(TESTSUITE) $(PAK) check: all @ ./$(TESTSUITE) +test: all + @ ./$(TESTSUITE) + +strip: $(GMQCC) $(QCVM) $(TESTSUITE) + strip $(GMQCC) + strip $(QCVM) + strip $(TESTSUITE) clean: - rm -f *.o $(GMQCC) $(QCVM) $(TESTSUITE) *.dat + rm -rf *.o $(GMQCC) $(QCVM) $(TESTSUITE) $(PAK) *.dat gource.mp4 *.exe gm-qcc.tgz ./cov-int + +depend: + @ makedepend -Y -w 65536 2> /dev/null $(subst .o,.c,$(DEPS)) + -# deps -$(OBJ) $(OBJ_C) $(OBJ_X): gmqcc.h opts.def -main.o: lexer.h -parser.o: ast.h lexer.h -ast.o: ast.h ir.h -ir.o: ir.h +coverity: + @cov-build --dir cov-int $(MAKE) + @tar czf gm-qcc.tgz cov-int + @rm -rf cov-int + @echo gm-qcc.tgz generated, submit for analysis #install rules -install: install-gmqcc install-qcvm install-doc +install: install-gmqcc install-qcvm install-gmqpak install-doc install-gmqcc: $(GMQCC) install -d -m755 $(DESTDIR)$(BINDIR) - install -m755 $(GMQCC) $(DESTDIR)$(BINDIR)/gmqcc + install -m755 $(GMQCC) $(DESTDIR)$(BINDIR)/$(GMQCC) install-qcvm: $(QCVM) install -d -m755 $(DESTDIR)$(BINDIR) - install -m755 $(QCVM) $(DESTDIR)$(BINDIR)/qcvm + install -m755 $(QCVM) $(DESTDIR)$(BINDIR)/$(QCVM) +install-gmqpak: $(PAK) + install -d -m755 $(DESTDIR)$(BINDIR) + install -m755 $(PAK) $(DESTDIR)$(BINDIR)/$(PAK) install-doc: install -d -m755 $(DESTDIR)$(MANDIR)/man1 - install -m755 doc/gmqcc.1 $(DESTDIR)$(MANDIR)/man1/ - install -m755 doc/qcvm.1 $(DESTDIR)$(MANDIR)/man1/ + install -m644 doc/gmqcc.1 $(DESTDIR)$(MANDIR)/man1/ + install -m644 doc/qcvm.1 $(DESTDIR)$(MANDIR)/man1/ + install -m644 doc/gmqpak.1 $(DESTDIR)$(MANDIR)/man1/ + +# DO NOT DELETE + +ansi.o: platform.h gmqcc.h opts.def +util.o: gmqcc.h opts.def platform.h +hash.o: gmqcc.h opts.def +stat.o: gmqcc.h opts.def +fs.o: gmqcc.h opts.def platform.h +opts.o: gmqcc.h opts.def +conout.o: gmqcc.h opts.def +pak.o: gmqcc.h opts.def +test.o: gmqcc.h opts.def platform.h +main.o: gmqcc.h opts.def lexer.h +lexer.o: gmqcc.h opts.def lexer.h +parser.o: parser.h gmqcc.h opts.def lexer.h ast.h ir.h +code.o: gmqcc.h opts.def +ast.o: gmqcc.h opts.def ast.h ir.h parser.h lexer.h +ir.o: gmqcc.h opts.def ir.h +ftepp.o: gmqcc.h opts.def lexer.h +utf8.o: gmqcc.h opts.def +correct.o: gmqcc.h opts.def +fold.o: ast.h ir.h gmqcc.h opts.def parser.h lexer.h +intrin.o: parser.h gmqcc.h opts.def lexer.h ast.h ir.h +exec.o: gmqcc.h opts.def