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
|
# 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))) \
)
# Suffix rules
%.a:
@echo ' AR $@'
@${AR} ${ARFLAGS} $@ $(filter %.o,$^)
.SUFFIXES: .s .S .c .o
.s.o:
@echo ' AS $^'
@$(AS) $(ASFLAGS) -c -o $@ $^
.S.o:
@echo ' CC $^'
@$(CC) $(CCFLAGS) -c -o $@ $^
.c.o:
@echo ' CC $^'
@$(CC) $(CCFLAGS) -c -o $@ $^
# clean target
.PHONY: clean
clean:
@$(foreach V,$(filter %$(,)OBJS, ${.VARIABLES}), rm -rf $($(V)))
|