参考自:http://blog.chinaunix.net/uid-20316928-id-3395996.html
《跟我一起学makedfile》 《GUN makefile……》
上一篇中发现修改了头文件,但是执行make后不会自动重新编译,
研究发现是因为没有头文件的依赖,最傻的加依赖方法就是在编译的时候头文件一块加进去。
那样子的话总不能每增加一个头文件都要去改一次makefile,上网一搜发现可以自动生成依赖文件,所以有了这篇文章。
有错的地方欢迎指出。互相交流,共同进步。
首先上编译前的源码树:
顶层makefile:
主要讲一下makefile中使用的几个函数:
第7行:wildcard,
返回的值是include目录下面的所有的.h文件
第11行:join ,
$(join aaa bbb , 111 222 333)返回值是“aaa111 bbb222 333”
第12行:patsubst:
$(patsubst %.c,%.o,x.c.c bar.c)
把字串“x.c.c bar.c”符合模式[%.c]的单词替换成[%.o],返回结果是“x.c.o bar.o”
第22行:foreach,
names := a b c d
files := $(foreach n,$(names),$(n).o)
上面的例子中,$(name)中的单词会被挨个取出,并存到变量“n”中,“$(n).o”每次
根据“$(n)”计算出一个值,这些值以空格分隔,最后作为 foreach 函数的返回,所以,
$(files)的值是“a.o b.o c.o d.o”。
shell,
它的参数应该就是操作系统 Shell 的命令,它和反引号“`”是相同的功能。
注意,这个函数会新生成一个 Shell 程序来执行命令,所以你要注意其运行性能,如果你的
Makefile 中有一些比较复杂的规则,并大量使用了这个函数,那么对于你的系统性能是有
害的。特别是 Makefile 的隐晦的规则可能会让你的 shell 函数执行的次数比你想像的多得
多。