sources = hello.c
include $(sources:.c=.d)
%.d: %.c
@set -e; rm -f $@; \
$(CC) -MM $(CPPFLAGS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
sources变量包含了需要产生依赖关系的源文件。
需要注意的是,当第一次执行make工具的时候,在执行include命令时,因.d文件不存在,故会报错。但随即%.d: %.c规则会创建.d文件,因此,此问题不算是真正的问题。
本文介绍了一种使用Makefile自动生成源文件依赖的方法。通过设置特定的规则和变量,可以为C源文件自动生成对应的依赖文件。这不仅简化了项目的构建流程,还提高了构建效率。

被折叠的 条评论
为什么被折叠?



