sources = hello.c
include $(sources:.c=.d)
%.d: %.c
@set -e; rm -f $@; \
$(CC) -MM $(CPPFLAGS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ :,g' < $@.$$$$ > $@; \
rm -f $@.$$$$@H_403_40@
sources变量包含了需要产生依赖关系的源文件。
需要注意的是,当第一次执行make工具的时候,在执行include命令时,因.d文件不存在,故会报错。但随即%.d: %.c
规则会创建.d文件,因此,此问题不算是真正的问题。