]> git.xonotic.org Git - xonotic/gmqcc.git/blobdiff - Makefile
Add CMakeLists.txt
[xonotic/gmqcc.git] / Makefile
index f804fd1cd028410cb9a5b92d6c2e2185ba0cf9f3..3566bdc99d15c1d12c1f12ec5eaf82b801c49706 100644 (file)
--- a/Makefile
+++ b/Makefile
-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. -fno-strict-aliasing -fsigned-char -O2
-CFLAGS += -DGMQCC_GITINFO="`git describe`"
-#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       \
-               -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 file.o utf8.o correct.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
+UNAME ?= $(shell uname)
+CYGWIN = $(findstring CYGWIN, $(UNAME))
+MINGW = $(findstring MINGW, $(UNAME))
 
 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 ("$(MINGW)", "")
-       #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
-       #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
+WINDOWS=1
 endif
+ifneq ("$(MINGW)", "")
+WINDOWS=1
 endif
 
-#standard rules
-default: all
-%.o: %.c
-       $(CC) -c $< -o $@ $(CFLAGS)
+CXX ?= clang++
+CXXFLAGS = \
+       -std=c++11 \
+       -Wall \
+       -Wextra \
+       -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
 
-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
-
-depend:
-       makedepend -Y -w 65536 \
-               $(subst .o,.c,$(OBJ_D))
-       makedepend -a -Y -w 65536 \
-               $(subst .o,.c,$(OBJ_T))
-       makedepend -a -Y -w 65536 \
-               $(subst .o,.c,$(OBJ_C))
-       makedepend -a -Y -w 65536 \
-               $(subst .o,.c,$(OBJ_X))
-
-#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/
-
-# DO NOT DELETE
-util.o: gmqcc.h opts.def
-code.o: gmqcc.h opts.def
-ast.o: gmqcc.h opts.def ast.h ir.h
-ir.o: gmqcc.h opts.def ir.h
-conout.o: gmqcc.h opts.def
-ftepp.o: gmqcc.h opts.def lexer.h
-opts.o: gmqcc.h opts.def
-file.o: gmqcc.h opts.def
-utf8.o: gmqcc.h opts.def
-correct.o: gmqcc.h opts.def
-
-test.o: gmqcc.h opts.def
-util.o: gmqcc.h opts.def
-conout.o: gmqcc.h opts.def
-file.o: gmqcc.h opts.def
-
-main.o: gmqcc.h opts.def lexer.h
-lexer.o: gmqcc.h opts.def lexer.h
-parser.o: gmqcc.h opts.def lexer.h ast.h ir.h
-file.o: gmqcc.h opts.def
-
-util.o: gmqcc.h opts.def
-conout.o: gmqcc.h opts.def
-file.o: gmqcc.h opts.def
+       rm -f *.d
+       rm -f $(COBJS) $(CDEPS) $(CBIN)
+       rm -f $(VOBJS) $(VDEPS) $(VBIN)
+ifndef WINDOWS
+       rm -f $(TOBJS) $(TDEPS) $(TOBJS)
+endif
+
+-include *.d