一、使用变量
1、变量值的替换
其格式是“$(var:a=b)”或是“${var:a=b}”,其意思是,把变量“var”中所有以“a”字串“结尾
的“a”替换成“b”字串。
2、把变量的值再当成变量
x = y
y = z
a := $($(x))
3、override指示符
如果有变量是通常 make的命令行参数设置的,那么 Makefile中对这个变量的赋值会被忽略。如果你想在 Makefile 中设置这类参数的值,那么,你可以使用“override”指示符。其语法是:
override <variable> = <value>
override <variable> := <value>
4、环境变量 “CFLAGS”
如果 make 指定了“-e”参数,那么,系统环境变量将覆盖 Makefile 中定义的变量
5、目标变量
为某个目标设置局部变量,它可以和“全局变量”同名,因为它的作用范围只在这条规 则以及连带规则中,所以其值也只在作用范围内有效其语法是:
<target ...> : <variable-assignment>
<target ...> : overide <variable-assignment>
针对于系统环境传入的变量make 命令行 带入的变量
6、模式变量
模式变量的好处就是,我们可以给定一种“模式”,可以把变量定义在符合这种模式的 所有目标上。
同样,模式变量的语法和“目标变量”一样:
<pattern …> :
<pattern …> : override 针对于系统环境传入的变量,或是 make 命令行指定的变量。
例:%.o : CFLAGS = -O
二、使用条件判断
ifeq ($(CC),gcc)
libs=$(libs_for_gcc)
else
libs=$(normal_libs)
endif
三、字符函数
1、函数调用
函数调用很像变量的使用,也是以“$”来标识的,其语法如下:
$(<function> <arguments>)
2、字符处理函数 subst
$(subst <from>,<to>,<text>)
功能:把字串
返回:函数返回被替换过后的字符串。
例:
$(subst ee,EE,feet on the street)
返回fEEt on the strEEt
3、patsubst
$(patsubst <pattern>,<replacement>,<text>)
功能:查找
返回:函数返回被替换过后的字符串。
例:
$(patsubst %.c,%.o,x.c.c bar.c)
返回结果是“x.c.o bar.o”
4、 strip
$(strip <string>)
功能:去掉字串中开头和结尾的空字符。
返回:返回被去掉空格的字符串值。
5、findstring
$(findstring <find>,<in>)
功能:在字串中查找字串。
返回:如果找到,那么返回,否则返回空字符串。
6、filter
$(filter <pattern...>,<text>)
功能:以模式过滤
返回:返回符合模式的字串。
例:
$(filter %.c %.s,$(sources))
返回的值是“foo.c bar.c baz.s”。
7、filter-out
$(filter-out <pattern…>,
功能:以模式过滤
返回:返回不符合模式的字串。
8、sort
$(sort <list>)
功能:给字符串中的单词排序(升序)。
返回:返回排序后的字符串。
9、word
$(word <n>, <text>)
功能:取字符串
返回:返回字符串
10、Wordlist
$(wordlist <s>,<e>,<text>)
功能:从字符串
开始到的单词串。
和是一个数字。
11、Words
$(words <text>)
名称:单词个数统计函数——words。
功能:统计
返回:返回
12、fistrword
$(firstword <text>)
名称:首单词函数——firstword。
功能:取字符串
返回:返回字符串