函数定义与调用
$(function arguments)
这是Makefile内建函数的调用方式。function为函数名,arguments为参数,如果有多个参数,以逗号","分隔。Makefile自定义函数
define funname
command1
command2
....
endef
它其实不叫函数,称为命令包,调用方式为 $(call funname,arg1,arg2,...argn);在命令包内部,通过$(1),$(2),...$(n)来代表对应的参数arg1,arg2,...argn
define funtest
$(1)-yes :=$(2)
endef
$(info $(call funtest,config,true))
最终config的值为config-yes的值为true。
Makefile其实没有自定义函数的概念,上面define关键字只是将多个命令组合在一起执行罢了,称为命令包,它的返回值是命令包内的所有语句组成的makefile代码字符串。比如对于上面(call funtest,config,true)),$(call funtest,config,true)的返回值就是 config-yes=true这一条代码字符串
define RESET
$(1) :=
$(1)-yes :=
endef
$(call RESET,config)
这个函数的功能就是将config和config-yes这两个变量赋值为空
常用函数
1、$(call expression,parm1,parm2,...,parmn)
执行表达式expression(由$(1),$(2),...$(n)组成,方式顺序不自由组合),该表达式的中的$(1),$(2),...$(n)则对应到parm1,parm2,...,parmn的值
reverse = $(2) $(1)
foo := $(call reverse,a,b)
最终foo的值为 b a
2、$(foreach var,list,text)
依次从list变量中取出每个字串(空格分开)赋值给var,然后执行text表达式,直到循环完毕将每次text表达式的值添加到一起作为foreach的返回值
names := a b c d
files := $(foreach n,$(names),$(n).o)
最终files的值为 a.o b.o c.o d.o
3、$(eval text)
将text 的内容作为makefile的一部分而被make解析和执行。
pointer := pointed_value
define foo
var := 123
arg := $1
$$($1) := ooooo
endef
$(info $(call foo,pointer))
$(eval $(call foo,pointer))
target:
@echo -----------------------------
@echo var: $(var), arg: $(arg)
@echo pointer: $(pointer), pointed_value: $(pointed_value)
@echo done.
@echo -----------------------------
最终执行结果为:
var := 123
arg := pointer
$(pointer) := ooooo
-----------------------------
var: 123, arg: pointer
pointer: pointed_value, pointed_value: ooooo
done.
eval 常常和call函数,自定义命令包一起使用,用来动态的执行命令包所定义的代码,如上例子。