aboutsummaryrefslogtreecommitdiff
path: root/rules.mk
blob: bfaf2e1137b7b74118d4210f558ed3a10a69c837 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# for each target.SRCS, generate target.OBJS, target.a and add target.OBJS to all
$(foreach V,$(filter %.SRCS, ${.VARIABLES}),\
	$(eval $(V:%.SRCS=%.OBJS) += $(foreach f,$($(V)),$(addsuffix .o,$(basename $(f))))) \
	$(eval $(V:%.SRCS=%.a): $($(V:%.SRCS=%.OBJS))) \
	$(eval all: $($(V:%.SRCS=%.OBJS))) \
)

# extra flags
CFLAGS   += -I../lib \
	    -Werror=implicit-function-declaration
CXXFLAGS += -I../lib -Drestrict=__restrict__

# Suffix rules
.SUFFIXES: .s .S .c .cpp .o
%.a:
	@echo '  AR   $@'
	@${AR} ${ARFLAGS} $@ $(filter %.o,$^)

.s.o:
	@echo '  AS   $^'
	@$(AS) $(ASFLAGS) -c -o $@ $^

.S.o:
	@echo '  CC   $^'
	@$(CC) $(CFLAGS) -c -o $@ $^

.c.o:
	@echo '  CC   $^'
	@$(CC) $(CFLAGS) -c -o $@ $^

.cpp.o:
	@echo '  CXX  $^'
	@$(CXX) $(CXXFLAGS) -c -o $@ $^

%.elf:
	@echo '  LD   $@'
	@${LD} ${LDFLAGS} -o $@ $^
	@echo -n '  B2b  '
	@b2sum $@ | cut -d' ' -f1

# test rules
tst/test_%: tst/%.cc
	@echo '  CXX  TEST  $@'
	@$(TEST_CXX) $(TEST_CXXFLAGS) $< -o $@

.PHONY: test.base valgrind.base clean.base FORCE
test.base: $(TESTS)
	@echo " -> Running tests in $(shell pwd | xargs basename)"
	@$(foreach f,$^,echo " -> $f"; ./$f &&) echo "Done"

valgrind.base: $(TESTS)
	@echo " -> Running valgrind on tests in $(shell pwd | xargs basename)"
	@$(foreach f,$^,echo " -> $f"; valgrind --leak-check=full ./$f;)

clean.base: FORCE
	@echo " -> Cleaning $(shell pwd | xargs basename)"
	@$(foreach V,$(filter %.OBJS, ${.VARIABLES}), rm -rf $($(V)))
	@rm -rf *.a
	@rm -rf tst/test_*

%: %.base ;

FORCE: ;