参考 跟我一起写Makefile http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=408225&extra=&authorid=10610714&page=1
首先回顾《跟我一起写Makefile》里有一节 自动生成依赖性。利用gcc中的一个编译选项 -MM,得到源文件的依赖文件,然后将其写入一个.d文件,每次make命令执行时,利用include 命令将.d文件内的依赖关系包含进makefile里,这样每个源文件是否需要重新编译可根据.d依赖文件的情况判定。
%.d: %.c
set -e; rm -f $@; \
$(CC) -M $(CPPFLAGS) $< >; $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
这段是《跟我一起写Makefile》里生成依赖文件.d的代码。
set -e ; rm -f $@; 第一句将shell设置为当命令输出非0时则退出,第二句删除原有.d文件
$(CC) -M $(CPPFLAGS) $< >; $@.$$$$;
该命令对源文件生成 依赖文件,并将其保存为$@.$$$$,后面的一串$$$$表示文件的后缀是一个随机码(听说是表示进程号),反正是为了不可能与其