]> git.xonotic.org Git - xonotic/gmqcc.git/blobdiff - Makefile
renaming some ast_node members before making ast_expression an ast_node to use the...
[xonotic/gmqcc.git] / Makefile
index ad8c9411c7467b647c7e3ad2cb14de64bf07e0ff..c6a6327ed02269a35d0146662a6edac6007ccbbc 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,68 +1,74 @@
-DESTDIR :=
-PREFIX := /usr/local
-BINDIR := $(PREFIX)/bin
+CXX ?= clang++
+CXXFLAGS = \
+       -std=c++11 \
+       -Wall \
+       -Wextra \
+       -fno-exceptions \
+       -fno-rtti \
+       -MD \
+       -g3
 
-CC     ?= clang
-CFLAGS += -Wall -I. -fomit-frame-pointer -fno-stack-protector -fno-common
-#turn on tons of warnings if clang is present
-ifeq ($(CC), clang)
-       CFLAGS +=                  \
-               -Weverything                  \
-               -Wno-missing-prototypes       \
-               -Wno-unused-parameter         \
-               -Wno-sign-compare             \
-               -Wno-implicit-fallthrough     \
-               -Wno-sign-conversion          \
-               -Wno-conversion               \
-               -Wno-disabled-macro-expansion \
-               -Wno-padded                   \
-               -Wno-format-nonliteral
+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
 
-endif
-ifeq ($(track), no)
-    CFLAGS += -DNOTRACK
-endif
+TSRCS = \
+       conout.cpp \
+       opts.cpp \
+       stat.cpp \
+       test.cpp \
+       util.cpp
 
-OBJ     = \
-          util.o      \
-          code.o      \
-          ast.o       \
-          ir.o        \
-          con.o       \
-          ftepp.o
-OBJ_C = main.o lexer.o parser.o
-OBJ_X = exec-standalone.o util.o con.o
+VSRCS = \
+       exec.cpp \
+       stat.cpp \
+       util.cpp
 
-#default is compiler only
-default: gmqcc
-%.o: %.c
-       $(CC) -c $< -o $@ $(CFLAGS)
+COBJS = $(CSRCS:.cpp=.o)
+TOBJS = $(TSRCS:.cpp=.o)
+VOBJS = $(VSRCS:.cpp=.o)
 
-exec-standalone.o: exec.c
-       $(CC) -c $< -o $@ $(CFLAGS) -DQCVM_EXECUTOR=1
+CDEPS = $(CSRCS:.cpp=.d)
+TDEPS = $(TSRCS:.cpp=.d)
+VDEPS = $(VSRCS:.cpp=.d)
 
-qcvm:     $(OBJ_X)
-       $(CC) -o $@ $^ $(CFLAGS) -lm
+CBIN = gmqcc
+TBIN = testsuite
+VBIN = qcvm
 
-# compiler target
-gmqcc: $(OBJ_C) $(OBJ)
-       $(CC) -o $@ $^ $(CFLAGS)
+all: $(CBIN) $(TBIN) $(VBIN)
 
-all: gmqcc qcvm
+$(CBIN): $(COBJS)
+       $(CXX) $(COBJS) -o $@
 
-clean:
-       rm -f *.o gmqcc qcvm
+$(TBIN): $(TOBJS)
+       $(CXX) $(TOBJS) -o $@
+
+$(VBIN): $(VOBJS)
+       $(CXX) $(VOBJS) -o $@
+
+.cpp.o:
+       $(CXX) -c $(CXXFLAGS) $< -o $@
 
-$(OBJ) $(OBJ_C) $(OBJ_X): gmqcc.h
-main.o: lexer.h
-parser.o: ast.h lexer.h
-ast.o: ast.h ir.h
-ir.o: ir.h
+test: $(CBIN) $(TBIN) $(VBIN)
+       @./$(TBIN)
+
+clean:
+       rm -f *.d
+       rm -f $(COBJS) $(CDEPS) $(CBIN)
+       rm -f $(TOBJS) $(TDEPS) $(TBIN)
+       rm -f $(VOBJS) $(VDEPS) $(VBIN)
 
-install: install-gmqcc install-qcvm
-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
+-include *.d