在Makefile中可以使用函数来处理变量,从而让我们的命令或是规则更为的灵活和具有智能。make所支持的函数也不算很多,不过已经足够我们的操作了。函数调用后,函数的返回值可以当做变量来使用。
函数的调用语法
函数调用,很像变量的使用,也是以 $
来标识的,其语法如下:
-
$(<function> <arguments>)
或是:
-
${<function> <arguments>}
这里, <function>
就是函数名,make支持的函数不多。 <arguments>
为函数的参数,参数间以逗号 ,
分隔,而函数名和参数之间以“空格”分隔。函数调用以 $
开头,以圆括号或花括号把函数名和参数括起。感觉很像一个变量,是不是?函数中的参数可以使用变量,为了风格的统一,函数和变量的括号最好一样,如使用 $(subst a,b,$(x))
这样的形式,而不是$(subst a,b, ${x})
的形式。因为统一会更清楚,也会减少一些不必要的麻烦。
还是来看一个示例:
-
comma:= ,
-
empty:=
-
space:= $(empty) $(empty)
-
foo:= a b c
-
bar:= $(subst $(space),$(comma),$(foo))
在这个示例中, $(comma)
的值是一个逗号。 $(space)
使用了 $(empty)
定义了一个空格, $(foo)
的值是 a b c
, $(bar)
的定义用,调用了函数 subst
,这是一个替换函数,这个函数有三个参数,第一个参数是被替换字串,第二个参数是替换字串,第三个参数是替换操作作用的字串。这个函数也就是把 $(foo)
中的空格替换成逗号,所以 $(bar)
的值是 a,b,c
。
关于各种函数,直接参考:
https://www.bookstack.cn/read/how-to-write-makefile/af323efc24268473.md
本文不赘述。
makefile中指令基本都是使用gcc,其他基本都是为了构造gcc时的各种参数,有时,为了构造某些参数,需要使用到linux命令,此时,需要使用shell函数来执行,而不能直接执行。