常用函数
字符串处理函数
字符串替换函数——subst
$(subst <from>;,<to>;,<text>;)
功能:把字串
返回:函数返回被替换过后的字符串。
示例:
comma:= ,
empty:=
space:= $(empty) $(empty)
foo:= a b c
bar:= $(subst $(space),$(comma),$(foo))
这个函数也就是把$(foo)中的空格替换成逗号,所以$(bar)的值是“a,b,c”
模式字符串替换函数——patsubst
$(patsubst <pattern>;,<replacement>;,<text>)
功能:查找<text>;中的单词(单词以“空格”、“Tab”或“回车”“换行”分隔)是否符合模式<pattern>;,如果匹配的话,则以<replacement>;替换。这里,<pattern>;可以包括通配符“%”,表示任意长度的字串。如果<replacement>;中也包含“%”,那么,<replacement>;中的这个“%”将是<pattern>;中的那个“%”所代表的字串。(可以用“\”来转义,以“%”来表示真实含义的“%”字符)
返回:函数返回被替换过后的字符串。
示例:
$(patsubst %.c,%.o,x.c.c bar.c)
把字串“x.c.c bar.c”符合模式[%.c]的单词替换成[%.o],返回结果是“x.c.o bar.o”
去空格函数——strip
$(strip <string>)
功能:去掉<string>;字串中开头和结尾的空字符。
返回:返回被去掉空格的字符串值。
示例:
$(strip a b c )
把字串“a b c ”去到开头和结尾的空格,结果是“a b c”。
查找字符串函数——findstring
$(findstring <find>;,<in>)
功能:在字串<in>;中查找<find>;字串。
返回:如果找到,那么返回;,否则返回空字符串。
示例:
$(findstring a,a b c)
$(findstring a,b c)
第一个函数返回“a”字符串,第二个返回“”字符串(空字符串)
过滤函数——filter
$(filter <pattern…>;,<text>)
功能:以<pattern>;模式过滤<text>;字符串中的单词,保留符合模式<pattern>;的单词。可以有多个模式。
返回:返回符合模式<pattern>;的字串。
示例:
sources := foo.c bar.c baz.s ugh.h
foo: $(sources)
cc $(filter %.c %.s,$(sources)) -o foo
$(filter %.c %.s,$(sources))返回的值是“foo.c bar.c baz.s”。
反过滤函数——filter-out
$(filter-out <pattern…>;,<text>)
功能:以<pattern>;模式过滤<text>;字符串中的单词,去除符合模式<pattern>;的单词。可以有多个模式。
返回:返回不符合模式<pattern>;的字串。
示例:
objects=main1.o foo.o main2.o bar.o
mains=main1.o main2.o
$(filter-out $(mains),$(objects)) 返回值是“foo.o bar.o”。
排序函数——sort
$(sort <list>)
功能:给字符串;中的单词排序(升序)。
返回:返回排序后的字符串。
示例:
$(sort foo bar lose)
返回“bar foo lose” 。
备注:sort函数会去掉<list>;中相同的单词。
取单词函数——word
$(word <n>;,<text>;)
功能:取字符串<text>;中第<n>;个单词。(从一开始)
返回:返回字符串<text>;中第<n>;个单词。如果<n>;比<text>;中的单词数要大,那么返回空字符串。
示例:
$(word 2, foo bar baz)
返回值是“bar”
取单词串函数——wordlist
$(wordlist <s>;,<e>;,<text>;)
功能:从字符串<text>;中取从<s>;开始到<e>;的单词串。<s>;和<e>;是一个数字。
返回:返回字符串<text>;中从<s>;到<e>;的单词字串。如果<s>;比<text>;中的单词数要大,那么返回空字符串。如果<e>;大于<text>;的单词数,那么返回从<s>;开始,到<text>;结束的单词串。
示例:
$(wordlist 2, 3, foo bar baz)
返回值是“bar baz”
单词个数统计函数——words
$(words <text>;)
功能:统计<text>;中字符串中的单词个数。
返回:返回<text>;中的单词数。
示例:
$(words, foo bar baz)
返回值是“3”。
备注:如果我们要取<text>;中最后的一个单词,我们可以这样:$(word $(words <text>;),<text>;)。
首单词函数——firstword
$(firstword <text>;)
功能:取字符串<text>;中的第一个单词。
返回:返回字符串<text>;的第一个单词。
示例:
$(firstword foo bar)
返回值是“foo”
备注:这个函数可以用word函数来实现:$(word 1,<text>;)。
以上,是所有的字符串操作函数,如果搭配混合使用,可以完成比较复杂的功能。这里,举一个现实中应用的例子。我们知道,make使用“VPATH”变量来指定“依赖文件”的搜索路径。于是,我们可以利用这个搜索路径来指定编译器对头文件的搜索路径参数CFLAGS,如:
文件名操作函数
下面我们要介绍的函数主要是处理文件名的。每个函数的参数字符串都会被当做一个或是一系列的文件名来对待。
取目录函数——dir
$(dir <names…>;)
功能:从文件名序列<names>;中取出目录部分。目录部分是指最后一个反斜杠(“/”)之前的部分。如果没有反斜杠,那么返回“./”。
返回:返回文件名序列;的目录部分。
示例:
$(dir src/foo.c hacks)
返回值是“src/ ./”。
取文件函数——notdir
$(notdir <names…>;)
功能:从文件名序列<names>;中取出非目录部分。非目录部分是指最后一个反斜杠(“/”)之后的部分。
返回:返回文件名序列<names>;的非目录部分。
示例:
$(notdir src/foo.c hacks)
返回值是“foo.c hacks”
取后缀函数——suffix
$(suffix <names…>;)
功能:从文件名序列;中取出各个文件名的后缀。
返回:返回文件名序列;的后缀序列,如果文件没有后缀,则返回空字串。
示例:
$(suffix src/foo.c src-1.0/bar.c hacks)
返回值是“.c .c”
取前缀函数——basename
$(basename <names…>;)
功能:从文件名序列<names>;中取出各个文件名的前缀部分。
返回:返回文件名序列<names>;的前缀序列,如果文件没有前缀,则返回空字串。
示例:
$(basename src/foo.c src-1.0/bar.c hacks)
返回值是“src/foo src-1.0/bar hacks”
加后缀函数——addsuffix
$(addsuffix <suffix>;,<names…>;)
功能:把后缀<suffix>;加到<names>;中的每个单词后面。
返回:返回加过后缀的文件名序列。
示例:
$(addsuffix .c,foo bar)
返回值是“foo.c bar.c”
加前缀函数——addprefix
$(addprefix <prefix>;,<names…>;)
功能:把前缀<prefix>;加到<names>;中的每个单词后面。
返回:返回加过前缀的文件名序列。
示例:
$(addprefix src/,foo bar)
返回值是“src/foo src/bar”
连接函数——join
$(join <list1>;,<list2>;)
功能:把;中的单词对应地加到<list1>;的单词后面。如果<list1>;的单词个数要比<list2>;的多,那么,<list1>;中的多出来的单词将保持原样。如果<list2>;的单词个数要比<list1>;多,那么,<list2>;多出来的单词将被复制到<list2>;中。
返回:返回连接过后的字符串。
示例:
$(join aaa bbb , 111 222 333)
返回值是“aaa111 bbb222 333”