标签:
函数"eval"是一个比较特殊的函数。使用它我们可以在我们的Makefile中构造一个可变的规则结构关系(依赖关系链),其中可以使用其它变量和函数。函数"eval"对它的参数进行展开,展开的结果作为Makefile的一部分,make可以对展开内容进行语法解析。展开的结果可以包含一个新变量、目标、隐含规则或者是明确规则等。也就是说此函数的功能主要是:根据其参数的关系、结构,对它们进行替换展开。
函数"eval"的返回值时空,也可以说没有返回值。
函数说明:"eval"函数执行时会对它的参数进行两次展开。第一次展开过程发是由函数本身完成的,第二次是函数展开后的结果被作为Makefile内容时由make解析时展开的。明确这一点对于使用"eval"函数非常重要。在理解了函数"eval"二次展开的过程后。实际使用时,当函数的展开结果中存在引用(格式为:$(x))时,那么在函数的参数中应该使用"$$"来代替"$"。因为这一点,所以通常它的参数中会使用函数"value"来取一个变量的文本值
#example Makefile
OBJ=a.o b.o c.o d.o main.o
Define TEST
Main:$(OBJ)
Gcc –g –o main $$(OBJ)
Endef
$(eval $(call TEST))
根据上面的说明,evel 对 $(call TEST)进行展开,(第一次展开)展开结果为
Main:a.o b.o c.o d.o main.o
Gcc –g –o main $(OBJ)
大家可以看到$(OBJ)展开,而$$(OBJ)称为$(OBj)符合Makefile的展开规则
然后Makefile对上面的进行解析展开为
Main:a.o b.o c.o d.o main.o
Gcc –g –o main a.o b.o c.o d.o main.o
因此会产生以上黑体字的一个编译,至此,相信大家对Makefile的eval函数应该有了一个真实的了解
标签:
原文地址:http://www.cnblogs.com/sudochen/p/4673318.html