X-Git-Url: https://git.xonotic.org/?p=xonotic%2Fgmqcc.git;a=blobdiff_plain;f=Makefile;h=3566bdc99d15c1d12c1f12ec5eaf82b801c49706;hp=a66b8116ffe39a648399cda5f91beb7d89718f4c;hb=63c679ee81081de27783d30f9af0692a3d484904;hpb=064883506137a0c91863c35c655ee7f066d32daf diff --git a/Makefile b/Makefile index a66b811..3566bdc 100644 --- a/Makefile +++ b/Makefile @@ -1,104 +1,98 @@ -DESTDIR := -PREFIX := /usr/local -BINDIR := $(PREFIX)/bin -DATADIR := $(PREFIX)/share -MANDIR := $(DATADIR)/man - -UNAME = $(shell uname) -CYGWIN = $(findstring CYGWIN, $(UNAME)) -MINGW = $(findstring MINGW32, $(UNAME)) - -CC ?= clang -CFLAGS += -Wall -Wextra -I. -pedantic-errors -#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 +UNAME ?= $(shell uname) +CYGWIN = $(findstring CYGWIN, $(UNAME)) +MINGW = $(findstring MINGW, $(UNAME)) + +ifneq ("$(CYGWIN)", "") +WINDOWS=1 endif -ifeq ($(track), no) - CFLAGS += -DNOTRACK +ifneq ("$(MINGW)", "") +WINDOWS=1 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 +CXX ?= clang++ +CXXFLAGS = \ + -std=c++11 \ + -Wall \ + -Wextra \ + -fno-exceptions \ + -fno-rtti \ + -MD \ + -g3 -ifneq ("$(CYGWIN)", "") - #nullify the common variables that - #most *nix systems have (for windows) - PREFIX := - BINDIR := - DATADIR := - MANDIR := - QCVM = qcvm.exe - GMQCC = gmqcc.exe - TESTSUITE = testsuite.exe -else -ifneq ("$(MINGW32)", "") - #nullify the common variables that - #most *nix systems have (for windows) - PREFIX := - BINDIR := - DATADIR := - MANDIR := - QCVM = qcvm.exe - GMQCC = gmqcc.exe - TESTSUITE = testsuite.exe +CSRCS = \ + ast.cpp \ + code.cpp \ + conout.cpp \ + fold.cpp \ + ftepp.cpp \ + intrin.cpp \ + ir.cpp \ + lexer.cpp \ + main.cpp \ + opts.cpp \ + parser.cpp \ + stat.cpp \ + utf8.cpp \ + util.cpp + +TSRCS = \ + conout.cpp \ + opts.cpp \ + stat.cpp \ + test.cpp \ + util.cpp + +VSRCS = \ + exec.cpp \ + stat.cpp \ + util.cpp + +COBJS = $(CSRCS:.cpp=.o) +TOBJS = $(TSRCS:.cpp=.o) +VOBJS = $(VSRCS:.cpp=.o) + +CDEPS = $(CSRCS:.cpp=.d) +TDEPS = $(TSRCS:.cpp=.d) +VDEPS = $(VSRCS:.cpp=.d) + +ifndef WINDOWS +CBIN = gmqcc +VBIN = qcvm +TBIN = testsuite else - QCVM = qcvm - GMQCC = gmqcc - TESTSUITE = testsuite -endif +CBIN = gmqcc.exe +VBIN = qcvm.exe endif -#standard rules -default: all -%.o: %.c - $(CC) -c $< -o $@ $(CFLAGS) - -exec-standalone.o: exec.c - $(CC) -c $< -o $@ $(CFLAGS) -DQCVM_EXECUTOR=1 +ifndef WINDOWS +all: $(CBIN) $(QCVM) $(TBIN) +else +all: $(CBIN) $(QCVM) +endif -$(QCVM): $(OBJ_X) - $(CC) -o $@ $^ $(CFLAGS) -lm +$(CBIN): $(COBJS) + $(CXX) $(COBJS) -o $@ -$(GMQCC): $(OBJ_C) $(OBJ_D) - $(CC) -o $@ $^ $(CFLAGS) +$(VBIN): $(VOBJS) + $(CXX) $(VOBJS) -o $@ -$(TESTSUITE): $(OBJ_T) - $(CC) -o $@ $^ $(CFLAGS) +ifndef WINDOWS +$(TBIN): $(TOBJS) + $(CXX) $(TOBJS) -o $@ -all: $(GMQCC) $(QCVM) $(TESTSUITE) +test: $(CBIN) $(VBIN) $(TBIN) + @./$(TBIN) +endif -check: all - @ ./$(TESTSUITE) +.cpp.o: + $(CXX) -c $(CXXFLAGS) $< -o $@ clean: - rm -f *.o $(GMQCC) $(QCVM) $(TESTSUITE) *.dat - -# 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 - -#install rules -install: install-gmqcc install-qcvm install-doc -install-gmqcc: $(GMQCC) - install -d -m755 $(DESTDIR)$(BINDIR) - install -m755 $(GMQCC) $(DESTDIR)$(BINDIR)/gmqcc -install-qcvm: $(QCVM) - install -d -m755 $(DESTDIR)$(BINDIR) - install -m755 $(QCVM) $(DESTDIR)$(BINDIR)/qcvm -install-doc: - install -d -m755 $(DESTDIR)$(MANDIR)/man1 - install -m755 doc/gmqcc.1 $(DESTDIR)$(MANDIR)/man1/ - install -m755 doc/qcvm.1 $(DESTDIR)$(MANDIR)/man1/ + rm -f *.d + rm -f $(COBJS) $(CDEPS) $(CBIN) + rm -f $(VOBJS) $(VDEPS) $(VBIN) +ifndef WINDOWS + rm -f $(TOBJS) $(TDEPS) $(TOBJS) +endif + +-include *.d