码迷,mamicode.com
首页 > 其他好文 > 详细

Makefile函数eval理解

时间:2015-07-24 14:15:29      阅读:444      评论:0      收藏:0      [点我收藏+]

标签:

  1. Makefile函数eval理解

    函数"eval"是一个比较特殊的函数。使用它我们可以在我们的Makefile中构造一个可变的规则结构关系(依赖关系链),其中可以使用其它变量和函数。函数"eval"对它的参数进行展开,展开的结果作为Makefile的一部分,make可以对展开内容进行语法解析。展开的结果可以包含一个新变量、目标、隐含规则或者是明确规则等。也就是说此函数的功能主要是:根据其参数的关系、结构,对它们进行替换展开。

     

    函数"eval"的返回值时空,也可以说没有返回值。

    函数说明:"eval"函数执行时会对它的参数进行两次展开。第一次展开过程发是由函数本身完成的,第二次是函数展开后的结果被作为Makefile内容时由make解析时展开的。明确这一点对于使用"eval"函数非常重要。在理解了函数"eval"二次展开的过程后。实际使用时,当函数的展开结果中存在引用(格式为:$(x))时,那么在函数的参数中应该使用"$$"来代替"$"。因为这一点,所以通常它的参数中会使用函数"value"来取一个变量的文本值

  2. Eval例子

    #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函数应该有了一个真实的了解

Makefile函数eval理解

标签:

原文地址:http://www.cnblogs.com/sudochen/p/4673318.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!