对 makefile 中 eval 函数的学习体会

上例子

define func
foo:
    @echo "at foo"
endef

all: foo
    @echo "final"

$(eval $(call func, foo,abc.c))

先不整那些函数参数传递之类的幺蛾子,做一个个简单的例子,

运行 make

结果是:

at foo

final

然后再变化下:

define func
$1:
    @echo "at foo"
endef

all: foo
    @echo "final"

$(eval $(call func, foo,abc.c))

这次,传递 foo 作为 $1,得到结果相同。

基本上可以看到,eval 函数是具备一定的运行时刻改变makefile 能力。

结束

原文地址:https://www.cnblogs.com/gaojian/p/2711494.html