X-Git-Url: https://git.ucc.asn.au/?p=ipdf%2Fcode.git;a=blobdiff_plain;f=src%2FMakefile;h=95ff5be0f8576d057458fbf8fbc4312f5bf3c35f;hp=39f09ef510ac8befbdedc31cd6db86ac7329814e;hb=a851cf197844a2eb15fd5ee2c350ee296e415dca;hpb=f8de7d373ff0a5d977adee1d1a464401ece60550 diff --git a/src/Makefile b/src/Makefile index 39f09ef..95ff5be 100644 --- a/src/Makefile +++ b/src/Makefile @@ -1,35 +1,85 @@ #Makefile -CXX = g++ -std=gnu++0x -Wall -Werror -Wshadow -pedantic -g -OBJ = log.o -LIB = #-lSDL2 -DEPS := $(OBJ:%.o=%.d) +ARCH := $(shell uname -m) +# TODO: stb_truetype doesn't compile with some of these warnings. +CXX = g++ -std=gnu++0x -g +# -Wall -Werror -Wshadow -pedantic +MAIN = main.o +OBJ = log.o real.o document.o view.o screen.o vfpu.o graphicsbuffer.o framebuffer.o shaderprogram.o stb_truetype.o gl_core44.o +LIB_x86_64 = ../contrib/lib/libSDL2-2.0.so.0 -lGL +LIB_i386 = ../contrib/lib32/libSDL2-2.0.so.0 -lGL -LINKOBJ = $(OBJ) +MAINRPATH_x86_64 = -Wl,-rpath,'$$ORIGIN/../contrib/lib' +MAINRPATH_i386 = -Wl,-rpath,'$$ORIGIN/../contrib/lib32' +TESTRPATH_x86_64 = -Wl,-rpath,'$$ORIGIN/../../contrib/lib' +TESTRPATH_i386 = -Wl,-rpath,'$$ORIGIN/../../contrib/lib32' +OBJPATHS = $(OBJ:%=../obj/%) +DEPS := $(OBJPATHS:%.o=%.d) +CFLAGS_x86_64 := -I../contrib/include/SDL2 -I`pwd` +CFLAGS_i386 := -I../contrib/include32/SDL2 -I`pwd` + + +LIB := $(LIB_$(ARCH)) +MAINRPATH := $(MAINRPATH_$(ARCH)) +TESTRPATH := $(TESTRPATH_$(ARCH)) +CFLAGS := $(CFLAGS_$(ARCH)) + +DEF = -DREAL=1 + +LINKOBJ = $(OBJPATHS) RM = rm -f -BIN = ipdf +BIN = ../bin/ipdf + + all : $(BIN) -$(BIN) : $(LINKOBJ) main.o - $(CXX) -o $(BIN) main.o $(LINKOBJ) $(LIB) +single : DEF = -DREAL=0 +single : $(BIN) + +double : DEF = -DREAL=1 +double : $(BIN) + +# The tests will compile with the default REAL definition +# To change that you can run as `make DEFS="REAL=X" tests/` where X is your chosen type +# But remember to make clean first. +tests/% : tests/%.cpp ../obj/tests/%.o $(LINKOBJ) + $(CXX) -o $@.test $(LINKOBJ) ../obj/$@.o $(LIB) $(TESTRPATH) -%.o : %.cpp - $(CXX) -c -MMD -o $@ $< +-include $(DEPS) -no_main : $(OBJ) +runtests : tests/runtests.sh + cd tests; ./runtests.sh -main.o : main.cpp - $(CXX) -c main.cpp + +$(BIN) : $(LINKOBJ) ../obj/$(MAIN) + echo $(LINKOBJ) + @mkdir -p $(dir $@) + $(CXX) -o $(BIN) $(LINKOBJ) ../obj/$(MAIN) $(LIB) $(MAINRPATH) + +-include $(DEPS) + +../obj/%.o : %.cpp + @mkdir -p $(dir $@) + $(CXX) $(CFLAGS) $(DEF) -c -MMD -o $@ $< + +-include $(DEPS) + +clean_bin : + $(RM) $(BIN) clean : - $(RM) $(BIN) $(OBJ) $(LINKOBJ) main.o + $(RM) $(BIN) $(DEPS) $(LINKOBJ) ../obj/$(MAIN) + $(RM) tests/*~ + $(RM) tests/*.test + $(RM) tests/*.out + $(RM) tests/*.err + -clean_full: #cleans up all backup files - $(RM) $(BIN) $(OBJ) $(LINKOBJ) +clean_full: clean $(RM) *.*~ $(RM) *~ - $(RM) *.o +