参考资料:
<Makefile自动生成头文件依赖> http://www.cnblogs.com/lidabo/p/4928956.html
<跟我一起写Makefile> by 陈晧
初次编译时,.d 不存在:
包含 .d(注意:该文件定义 .d 依赖于 .cpp .h,由于 .d 是新建文件,肯定不过时)
从最终目标开始推导依赖关系链
后续编译时,.d 已存在:
包含 .d(注意:该文件定义 .d 依赖于 .cpp .h)
如果 .d 过时,再次调用隐含规则重新生成 .d,并重新包含
从最终目标开始推导依赖关系链
以下用一个简化后的例子进行说明。
Makefile文件内容:
final: abc.obj
@echo "【$@】V1=$(V1)"
%.d: %.cpp
@echo "【隐含规则1】$^ --> $@"
echo -e "V1=$$$$\n$*.obj $@: $*.cpp $*.h" > $@
%.obj: %.cpp
@echo "【隐含规则2】$^ --> $@"
include abc.d
输入下列命令准备测试环境:
touch abc.cpp abc.h
初始时abc.d不存在。输入命令:
make
处理流程:
- 调用“隐含规则1”生成abc.d。注意在此规则的执行过程中,abc.d的依赖文件($^)为abc.cpp。
- 包含abc.d,其中定义了abc.d依赖abc.cpp abc.h,由于abc.d是新建文件,肯定不过时。
- 从最终目标开始推导依赖关系链并处理。
更新abc.h,然后再次make。命令如下:
touch abc.h
make
处理流程:
- 包含abc.d,其中定义了abc.d依赖abc.cpp abc.h。
- 由于abc.h已更新,导致abc.d过时,因此调用“隐含规则1”重新生成abc.d。注意虽然规则只列出.cpp,但其依赖文件($^)仍然为abc.cpp abc.h。
- 重新包含abc.d,这一点可以从变量V1发生了改变得到证明。
- 从最终目标开始推导依赖关系链并处理。