Makefile eval

这样一个makefile:

define MA
aa:aa.c
gcc -g -o aa aa.c
endef

$(eval $(call MA) )

会产生一个这样的编译:
gcc -g -o aa aa.c

这样的makefile:

OBJ=a.o b.o main.o
define MA
main:$(OBJ)
gcc -g -o main $$(OBJ)
endef

$(eval $(call MA) )

第一次展开

$(eval main:a.o b.o main.o \n\t gcc -g -o main $(OBJ))

第二次展开

main:a.o b.o man.o

  gcc -g -o main  main a.o b.o main.o


会产生这样的编译过程:
cc -c -o a.o a.c
cc -c -o b.o b.c
cc -c -o main.o main.c
gcc -g -o main a.o b.o main.o

请注意到$$(OBJ) ,因为make要把这个作为makefile的一行,要让这个地方出现$,就要用两个$,因为两个$,make才把把作为$字符。
首先eval会将后面的参数展开,在展开的过程中,因为$在makefile里面有特殊的用法,因此在需要$的时候应该使用$$,最后在makefile对此执行,遇到$(OBJ),读取变量

翻查某makefile中文手册,里面这样讲:

函数功能:函数“eval”是一个比较特殊的函数。使用它可以在Makefile中构造一个可变的规则结构关系(依赖关系链),其中可以使用其它变量和函数。
函数“eval”对它的参数进行展开,展开的结果作为Makefile的一部分,make可以对展开内容进行语法解析。展开的结果可以包含一个新变量、目标、隐含规则或者是明确规则等。
也就是说此函数的功能主要是:根据其参数的关系、结构,对它们进行替换展开。
返回值:函数“eval”的返回值时空,也可以说没有返回值。
函数说明:“eval”函数执行时会对它的参数进行两次展开。第一次展开过程发是由函数本身完成的,第二次是函数展开后的结果被作为Makefile内容时由make解析时展开的。
明确这一过程对于使用“eval”函数非常重要。理解了函数“eval”二次展开的过程后。
实际使用时,如果在函数的展开结果中存在引用(格式为:$(x)),那么在函数的参数中应该使用“$$”来代替“$”。因为这一点,所以通常它的参数中会使用函数“value”来取一个变量的文本值。

 

posted on   sudochen  阅读(246)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示