-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile.clean
More file actions
61 lines (47 loc) · 1.27 KB
/
Makefile.clean
File metadata and controls
61 lines (47 loc) · 1.27 KB
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
target := $(obj)
.PHONY: __clean
__clean: clean-$(target)
srctree := .
objtree := .
rootdir := $(if $(dir),src/$(dir),src)
include $(srctree)/Makefile.lib
-include $(srctree)/auto.conf
#
# Compile template
#
define collect_files
$(1)-objs :=
$(1)-mods :=
$$(eval $$(call collect_target,$$(rootdir),$(1)))
endef
$(eval $(call collect_files,$(target)))
clean-objs := $($(target)-objs)
clean-objs += $(target).elf
clean-objs += $(target).bin
clean-deps := $($(target)-objs:.o=.o.d)
clean-deps += $($(target)-mods:.o=.o.d)
clean-mods := $($(target)-mods)
clean-mods += $($(target)-mods:.o=.ebm)
.PHONY: clean-$(target)-deps
clean-$(target)-deps:
@for objfile in $(subst ./,,$(clean-deps)); do \
if [ -e $$objfile ]; then \
$(RM) -f $$objfile; \
fi \
done
.PHONY: clean-$(target)-mods
clean-$(target)-mods:
@for objfile in $(subst ./,,$(clean-mods)); do \
if [ -e $$objfile ]; then \
echo " CLEAN $$objfile"; \
$(RM) -f $$objfile; \
fi \
done
.PHONY: clean-$(target)
clean-$(target): clean-$(target)-mods clean-$(target)-deps
@for objfile in $(subst ./,,$(clean-objs)); do \
if [ -e $$objfile ]; then \
echo " CLEAN $$objfile"; \
$(RM) -f $$objfile; \
fi \
done