Makefile基础——函数

说明

本节介绍Makefile中使用的函数。

函数的基础请参考Makefile基础。

 

字符串处理函数

$(subst ,,)

作用:将text中的from替换成to,并返回修改后的text(当然也有可能没有被修改)。

$(patsubst ,,)

作用:基本同subst,只是这里变成了对满足模式的字符串的替换。

$(strip )

作用:将string前后的空格去掉并返回修改后的string(当然也有可能没有被修改)。

$(findstring ,)

作用:在in中找字符串find,如果找到了就返回find,否则返回空。

$(filter ,)

作用:过滤text字符串,只保留符合模式的字符串,pattern可以有多个。

$(filter-out ,)

作用:同filter刚好相反,这里删除符合模式的字符串。

$(sort )

作用:升序排序list里面的单词。

$(word ,)

作用:取text中的第n个单词,从1开始算。

$(wordlist ,,)

作用:取text中第s个开始到第e个为止的单词,包括第e个单词。

$(words )

作用:返回text中的单词数。

$(firstword )

作用:返回text中的第一个单词。

 

文件名操作

$(dir )

作用:取names中的目录部分。

$(nodir )

作用:取names中的非目录部分。

$(suffix )

作用:取names中的后缀部分,比如main.c就取得.c部分。

$(basename )

作用:取names中的前面部分,比如main.c就取得main部分。

$(addsuffix ,)

作用:给names中的每一个成员加后缀suffix。

$(addprefix ,)

作用:给names中的每一个成员加前缀prefix。

$(join ,)

作用:将list1中的单词加到list2对应位置的单词之后。没有对应的就不管了。

$(abspath )

作用:返回绝对路径。

 

结构函数

$(foreach ,,)

作用:取出list中的每一个单词并赋值给var,再执行text语句。

$(if ,,)

作用:判断condition条件,满足条件就执行then-part,否则执行else-part。两个part都可以是空。

 

call函数

$(call ,,...)

作用:执行expression,后面的是参数,它们在expression中用$(1)$(2)...表示。

 

origin函数

$(origin )

作用:确定var的来源,是undefined?default?environment?file?command line?override?automatic?

 

shell函数

$(shell )

作用:执行cmd命令。相当于`cmd`。

 

eval函数

$(eval )

作用:不明。

似乎是展开text,作为Makefile的一部分。但是为什么要这么做,为什么不直接写text,不明白。。。

 

告警/错误函数

$(error )

作用:显示错误并停止执行。

$(warning )

作用:显示告警,但是会继续执行。

 

wildcard函数

$(wildcard pattern...)

作用:返回工作目录下满足pattern的所有文件名,多个文件名之间用空格隔开。
Makefile基础——函数_第1张图片

运行make之后的结果:

Makefile基础——函数_第2张图片

 

你可能感兴趣的:(Linux,编程基础)