X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=Makefile;h=f227d36cd4c08df63b55d245ce0314417929d287;hb=9c81ff263aa3f38252bdfe704e5051431e30aefa;hp=da9d0e65b669b0aaa8fc1bfb0ed3456db0acab1b;hpb=639fc8a32b35174fc4c2347fd38f76147093d6f4;p=xonotic%2Fgmqcc.git diff --git a/Makefile b/Makefile index da9d0e6..f227d36 100644 --- a/Makefile +++ b/Makefile @@ -1,17 +1,100 @@ -CC = gcc -CFLAGS = -O3 -Wall -OBJ = main.o \ - lex.o \ - error.o \ - parse.o \ - typedef.o \ - util.o - -%.o: %.c - $(CC) -c $< -o $@ $(CFLAGS) - -gmqcc: $(OBJ) - $(CC) -o $@ $^ $(CFLAGS) - +UNAME ?= $(shell uname) +CYGWIN = $(findstring CYGWIN, $(UNAME)) +MINGW = $(findstring MINGW, $(UNAME)) + +ifneq ("$(CYGWIN)", "") +WINDOWS=1 +endif +ifneq ("$(MINGW)", "") +WINDOWS=1 +endif + +CXX ?= clang++ +CXXFLAGS = \ + -std=c++11 \ + -Wall \ + -Wextra \ + -Wno-parentheses \ + -Wno-class-memaccess \ + -fno-exceptions \ + -fno-rtti \ + -MD \ + -g3 + +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 +CBIN = gmqcc.exe +VBIN = qcvm.exe +endif + +ifndef WINDOWS +all: $(CBIN) $(QCVM) $(TBIN) +else +all: $(CBIN) $(QCVM) +endif + +$(CBIN): $(COBJS) + $(CXX) $(COBJS) -o $@ + +$(VBIN): $(VOBJS) + $(CXX) $(VOBJS) -o $@ + +ifndef WINDOWS +$(TBIN): $(TOBJS) + $(CXX) $(TOBJS) -o $@ + +test: $(CBIN) $(VBIN) $(TBIN) + @./$(TBIN) +endif + +.cpp.o: + $(CXX) -c $(CXXFLAGS) $< -o $@ + clean: - rm -f *.o gmqcc + rm -f *.d + rm -f $(COBJS) $(CDEPS) $(CBIN) + rm -f $(VOBJS) $(VDEPS) $(VBIN) +ifndef WINDOWS + rm -f $(TOBJS) $(TDEPS) $(TOBJS) +endif + +-include *.d