X-Git-Url: https://git.ucc.asn.au/?p=ipdf%2Fcode.git;a=blobdiff_plain;f=src%2FMakefile;h=ec8789ace3a368d5884f65df73a485ec532bbaf7;hp=90adae96241e954289b95c4afadeb0e423144712;hb=e297312c8c82e52abd3507c861e85db497ca7e81;hpb=aaa65d90ac812f924cbbc39bef7a5f8b6cad2da3 diff --git a/src/Makefile b/src/Makefile index 90adae9..ec8789a 100644 --- a/src/Makefile +++ b/src/Makefile @@ -1,10 +1,9 @@ #Makefile 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 +CXX = g++ -std=gnu++0x -g -Wall -Werror -Wshadow -pedantic -rdynamic MAIN = main.o -OBJ = log.o real.o document.o view.o screen.o vfpu.o stb_truetype.o +OBJ = log.o real.o bezier.o document.o objectrenderer.o view.o screen.o vfpu.o graphicsbuffer.o framebuffer.o shaderprogram.o stb_truetype.o gl_core44.o add_digits_asm.o sub_digits_asm.o mul_digits_asm.o div_digits_asm.o arbint.o LIB_x86_64 = ../contrib/lib/libSDL2-2.0.so.0 -lGL LIB_i386 = ../contrib/lib32/libSDL2-2.0.so.0 -lGL @@ -31,6 +30,7 @@ RM = rm -f BIN = ../bin/ipdf +all : DEF = -DREAL=1 all : $(BIN) single : DEF = -DREAL=0 @@ -39,24 +39,44 @@ single : $(BIN) double : DEF = -DREAL=1 double : $(BIN) +demo : $(BIN) ../tools/stream_plot.py + mkdir -p ../data/ + $(RM) ../data/performance.dat + ./ipdf | tee ../data/performance.dat | ../tools/stream_plot.py 2>/dev/null + +movie : $(BIN) ../tools/stream_plot.py + mkdir -p ../data/ + $(RM) ../data/performance.dat + $(RM) ../data/movie.ogv + ./ipdf | tee ../data/performance.dat | ../tools/stream_plot.py 2>/dev/null & recordmydesktop --fps 10 --on-the-fly-encoding -o ../data/movie.ogv + # 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) +-include $(DEPS) + runtests : tests/runtests.sh cd tests; ./runtests.sh $(BIN) : $(LINKOBJ) ../obj/$(MAIN) + echo $(LINKOBJ) @mkdir -p $(dir $@) $(CXX) -o $(BIN) $(LINKOBJ) ../obj/$(MAIN) $(LIB) $(MAINRPATH) -../obj/%.o : %.cpp +-include $(DEPS) + +../obj/%.o : %.cpp main.h @mkdir -p $(dir $@) $(CXX) $(CFLAGS) $(DEF) -c -MMD -o $@ $< +../obj/%_asm.o : %_asm.s main.h + @mkdir -p $(dir $@) + $(CXX) -c -o $@ $< + -include $(DEPS) clean_bin : @@ -68,7 +88,6 @@ clean : $(RM) tests/*.test $(RM) tests/*.out $(RM) tests/*.err - clean_full: clean $(RM) *.*~