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