add more test (3)
[cmore.git] / makefile
CommitLineData
ec215ba5
LM
1# Default flags
2
3CC = gcc
4
6b456e0c
LM
5#INCLUDES = -I../debug -D__MEMORY_ALLOCATION__
6INCLUDES =
ec215ba5
LM
7OFLAGS = -O4 -Os
8#OFLAGS = -O4 -ffast-math -finline-functions
9#OFLAGS = -O4 -finline-functions
10#OFLAGS += -mtune=pentium3 -mmmx -msse -msse2 -m3dnow
11#OFLAGS += -minline-all-stringops -fsingle-precision-constant
12#OFLAGS += -malign-double
13CFLAGS += -W -Wall -Wextra -g
6b456e0c
LM
14#CFLAGS += -std=c99 -D_XOPEN_SOURCE=500
15CFLAGS += $(OFLAGS) $(INCLUDES) $(OPTIONS)
16LDFLAGS += -g $(OPTIONS)
17
bfc65d24 18LDOPT = linker
6b456e0c
LM
19ifeq ($(OS),Windows_NT)
20#LDLIBS += -lws2_32
bfc65d24 21LDOPT = winlnk
6b456e0c
LM
22endif
23
ec215ba5
LM
24
25# Targets
26
27ALLEXE =
6b456e0c 28ALLEXE += cmore
ec215ba5
LM
29
30SHELL = bash
31
6b456e0c 32#MAKE = mingw32-make
ec215ba5 33MAKEFLAGS += -s
6b456e0c 34include $(wildcard .makefile)
ec215ba5
LM
35
36# Functions
37
38TITLE = echo -en "\033[0;1m$(strip $(1))\033[0;0m:\t"
39PASS = echo -e "\033[1;32m$(strip $(1))\033[0;0m"
40WARN = echo -e "\033[1;33m$(strip $(1))\033[0;0m"
41FAIL = echo -e "\033[1;31m$(strip $(1))\033[0;0m"
42
43MKDIR = mkdir -p $(1) && chmod a+rx,go-w $(1)
44
45INSTALL = test -d `dirname $(2)` || $(call MKDIR, `dirname $(2)`) && cp -pa $(1) $(2) && chmod a+rX,go-w $(2)
46
47VALID = $(call TITLE, $(1)) && $(2) && $(call PASS, SUCCESS) || { $(call FAIL, FAILED); test; }
48
49## Generic rules
50
51all: depends
52 $(MAKE) $(ALLEXE:%=%.exe)
53
54count:
55 wc $(wildcard *.c *.h) $(MAKEFILE_LIST)
56
57clean:
58 $(call TITLE, "Cleaning")
59 touch clean
6b456e0c 60 rm -f clean $(wildcard *.d *.ld *.log *.o *.test *~ .exec_* gmon.out)
ec215ba5
LM
61 $(call PASS, SUCCESS)
62
63depends: $(patsubst %.c, %.d, $(wildcard *.c)) $(patsubst %, %.ld, $(ALLEXE))
64
65gcovs:
66 $(MAKE) $(addprefix gcov_,$(ALLEXE))
67
6b456e0c
LM
68gprofs:
69 $(MAKE) $(addprefix gprof_,$(ALLEXE))
70
ec215ba5
LM
71purge: clean
72 $(call TITLE, "Purging")
73 touch purge
74 rm -f purge $(ALLEXE:%=%.exe)
75 $(call PASS, SUCCESS)
76
6b456e0c 77valgrinds: all
ec215ba5
LM
78 $(MAKE) $(addprefix valgrind_,$(ALLEXE))
79
80wipe: purge
81 $(call TITLE, "Wiping")
82 touch wipe
6b456e0c 83 rm -f wipe $(wildcard *.gcda *.gcno *.gcov *.glog)
ec215ba5
LM
84 $(call PASS, SUCCESS)
85
86tests: all
87 $(MAKE) $(addprefix test_,$(ALLEXE))
88
89## Main rules
90
91include $(wildcard *.d)
92include $(wildcard *.ld)
93
94gcov_%:
95 $(MAKE) purge
6b456e0c 96 OPTIONS="-coverage -O0" $(MAKE)
ec215ba5
LM
97 $(MAKE) test_$(@:gcov_%=%)
98 gcov `sed -e 's/\.exe:/.c/;s/\.o/.c/g' $(@:gcov_%=%.ld)`
99 touch gcov
100 rm -f gcov $(wildcard *.gcda *.gcno)
101 $(MAKE) purge
6b456e0c
LM
102 grep '#####' *.c.gcov || true
103
104gprof_%:
105 $(MAKE) purge
106 $(MAKE) depends
107 OPTIONS="-pg" $(MAKE) ${@:gprof_%=%}.exe
108 $(MAKE) ${@:gprof_%=%}.test
109 IFS=$$'\n'; id=1; \
110 for test in `cat ${@:gprof_%=%}.test | sed 's,${@:gprof_%=%}.exe,./${@:gprof_%=%}.exe,g'`; do \
111 log=${@:gprof_%=%}.prof-$$id.glog; \
112 $(call TITLE, test: $$test); \
113 echo $$test > $$log; \
114 eval $$test >> $$log; \
115 [ $$? -eq 0 ] \
116 && echo -e "\033[1;32mSUCCESS\033[0;0m" \
117 || echo -e "\033[1;31mFAILED\033[0;0m"; \
118 [ -f gmon.out ] && { gprof ${@:gprof_%=%}.exe gmon.out >> $$log; rm gmon.out; }; \
119 let id++; \
120 done;
121 $(MAKE) purge
ec215ba5
LM
122
123%.test: %.c
124 $(call TITLE, "Building $@")
125# awk '/\/\* *test:.*\*\// { sub(/^.*\/\* *test: */, ""); sub(/ *\*\/.*$$/, ""); print }' $< > $@
6b456e0c 126 perl -- getcomments.pl -p='test:\s' -f='%' $< > $@
ec215ba5
LM
127 $(call PASS, SUCCESS)
128
129test_%: %.test %.exe
130 IFS=$$'\n'; RC=0; \
6b456e0c 131 for test in `cat $< | sed 's,${<:.test=.exe},$(VALGRIND) ./${<:.test=.exe},g'`; do \
ec215ba5 132 echo "=== $$test ==="; \
6b456e0c 133 eval $$test; \
ec215ba5
LM
134 [ $$? -eq 0 ] && echo -e "\033[1;32mSUCCESS\033[0;0m" \
135 || { echo -e "\033[1;31mFAILED\033[0;0m"; RC=1; }; \
136 done; \
6b456e0c 137 test "$$RC" -ne 1
ec215ba5
LM
138
139valgrind_%: %.exe
6b456e0c 140 VALGRIND="valgrind -v --leak-check=full --log-fd=3"; \
ec215ba5 141 export VALGRIND; \
6b456e0c 142 $(MAKE) $(@:valgrind_%=test_%) 3>$@.log
ec215ba5
LM
143
144%.d: %.c
145 $(call TITLE, "Building $@")
146 $(CC) $(INCLUDES) -MM $< -o $@~
6b456e0c 147 echo ${<:.c=.o}: $(shell perl -- getcomments.pl -p='depend:\s' -f='%' $<) >> $@~
ec215ba5
LM
148 mv $@~ $@
149 $(call PASS, SUCCESS)
150
151%.ld: %.c
152 $(call TITLE, "Building $@")
bfc65d24 153 echo ${<:.c=.exe}: $(shell perl -- getcomments.pl -p='$(LDOPT):\s' -f='%' $< | awk '{for (i=1;i<=NF;i++) if ($$(i) ~ /.o$$/) printf " %s", $$(i)}') > $@
ec215ba5
LM
154 $(call PASS, SUCCESS)
155
156%.o: %.c
157 $(call TITLE, "Building $@")
6b456e0c 158 $(CC) $(CFLAGS) $(INCLUDES) $(shell perl -- getcomments.pl -p='cflags:\s' -f='%' $<) -c $< -o $@
ec215ba5
LM
159 $(call PASS, SUCCESS)
160
161
162%.exe: %.o %.d
163 $(call TITLE, "Building $@")
bfc65d24 164 $(CC) $(LDFLAGS) $< $(shell perl -- getcomments.pl -p='$(LDOPT):\s' -f='%' ${<:.o=.c}) $(LDLIBS) -o $@
ec215ba5
LM
165 $(call PASS, SUCCESS)
166
167## Phony
168
169.PHONY: all clean count depends gcovs purge tests
170
171## Precious
172
173.PRECIOUS: %.d %.o