5 INCLUDES = -I../debug -D__MEMORY_ALLOCATION__
7 #OFLAGS = -O4 -ffast-math -finline-functions
8 #OFLAGS = -O4 -finline-functions
9 #OFLAGS += -mtune=pentium3 -mmmx -msse -msse2 -m3dnow
10 #OFLAGS += -minline-all-stringops -fsingle-precision-constant
11 #OFLAGS += -malign-double
12 CFLAGS += -W -Wall -Wextra -g
13 CFLAGS += -std=c99 -D_XOPEN_SOURCE=500
14 CFLAGS += $(OFLAGS) $(INCLUDES) $(GCOVER)
30 TITLE = echo -en "\033[0;1m$(strip $(1))\033[0;0m:\t"
31 PASS = echo -e "\033[1;32m$(strip $(1))\033[0;0m"
32 WARN = echo -e "\033[1;33m$(strip $(1))\033[0;0m"
33 FAIL = echo -e "\033[1;31m$(strip $(1))\033[0;0m"
35 MKDIR = mkdir -p $(1) && chmod a+rx,go-w $(1)
37 INSTALL = test -d `dirname $(2)` || $(call MKDIR, `dirname $(2)`) && cp -pa $(1) $(2) && chmod a+rX,go-w $(2)
39 VALID = $(call TITLE, $(1)) && $(2) && $(call PASS, SUCCESS) || { $(call FAIL, FAILED); test; }
44 $(MAKE) $(ALLEXE:%=%.exe)
47 wc $(wildcard *.c *.h) $(MAKEFILE_LIST)
50 $(call TITLE, "Cleaning")
52 rm -f clean $(wildcard *.d *.ld *.log *.o *.test *~ .exec_*)
55 depends: $(patsubst %.c, %.d, $(wildcard *.c)) $(patsubst %, %.ld, $(ALLEXE))
58 $(MAKE) $(addprefix gcov_,$(ALLEXE))
61 $(call TITLE, "Purging")
63 rm -f purge $(ALLEXE:%=%.exe)
67 $(MAKE) $(addprefix valgrind_,$(ALLEXE))
70 $(call TITLE, "Wiping")
72 rm -f wipe $(wildcard *.gcda *.gcno)
76 $(MAKE) $(addprefix test_,$(ALLEXE))
80 include $(wildcard *.d)
81 include $(wildcard *.ld)
85 CFLAGS="-fprofile-arcs -ftest-coverage" LDFLAGS="-fprofile-arcs -ftest-coverage" $(MAKE)
86 $(MAKE) test_$(@:gcov_%=%)
87 gcov `sed -e 's/\.exe:/.c/;s/\.o/.c/g' $(@:gcov_%=%.ld)`
89 rm -f gcov $(wildcard *.gcda *.gcno)
93 $(call TITLE, "Building $@")
94 # awk '/\/\* *test:.*\*\// { sub(/^.*\/\* *test: */, ""); sub(/ *\*\/.*$$/, ""); print }' $< > $@
95 ./getcomments.pl -p='test:\s' -f='%' $< > $@
100 for test in `cat $< | sed 's,${<:.test=.exe},./${<:.test=.exe},g'`; do \
101 echo "=== $$test ==="; \
102 eval $(VALGRIND) $$test; \
103 [ $$? -eq 0 ] && echo -e "\033[1;32mSUCCESS\033[0;0m" \
104 || { echo -e "\033[1;31mFAILED\033[0;0m"; RC=1; }; \
109 VALGRIND="valgrind -v --leak-check=full --show-reachable=yes --log-fd=2"; \
111 $(MAKE) $(@:valgrind_%=test_%)
114 $(call TITLE, "Building $@")
115 $(CC) $(INCLUDES) -MM $< -o $@~
116 echo ${<:.c=.o}: $(shell ./getcomments.pl -p='depend:\s' -f='%' $<) >> $@~
118 $(call PASS, SUCCESS)
121 $(call TITLE, "Building $@")
122 echo ${<:.c=.exe}: $(shell ./getcomments.pl -p='linker:\s' -f='%' $< | awk '{for (i=1;i<=NF;i++) if ($$(i) ~ /.o$$/) printf " %s", $$(i)}') > $@
123 $(call PASS, SUCCESS)
126 $(call TITLE, "Building $@")
127 $(CC) $(CFLAGS) $(INCLUDES) $(shell ./getcomments.pl -p='cflags:\s' -f='%' $<) -c $< -o $@
128 $(call PASS, SUCCESS)
132 $(call TITLE, "Building $@")
133 $(CC) $(LDFLAGS) $(shell ./getcomments.pl -p='linker:\s' -f='%' ${<:.o=.c}) $< -o $@
134 $(call PASS, SUCCESS)
138 .PHONY: all clean count depends gcovs purge tests