对 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 能力。
结束