跟我学Makefile(五)
文件名操作函数
每个函数的参数字符串都会被当做一个或是一系列的文件名来对待。
$(dir <names...>) 名称:取目录函数——dir。 功能:从文件名序列<names>中取出目录部分。目录部分是指最后一个反斜杠(“/”)之前的部分。如果没有反斜杠,那么返回“./”。 返回:返回文件名序列<names>的目录部分。 示例: $(dir src/foo.c hacks)返回值是“src/ ./”。
$(notdir <names...>) 名称:取文件函数——notdir。 功能:从文件名序列<names>中取出非目录部分。非目录部分是指最后一个反斜杠(“/”)之后的部分。 返回:返回文件名序列<names>的非目录部分。 示例: $(notdir src/foo.c hacks)返回值是“foo.c hacks”。
$(suffix <names...>) 名称:取后缀函数——suffix。 功能:从文件名序列<names>中取出各个文件名的后缀。 返回:返回文件名序列<names>的后缀序列,如果文件没有后缀,则返回空字串。 示例: $(suffix src/foo.c src-1.0/bar.c hacks)返回值是“.c .c”。
$(basename <names...>) 名称:取前缀函数——basename。 功能:从文件名序列<names>中取出各个文件名的前缀部分。 返回:返回文件名序列<names>的前缀序列,如果文件没有前缀,则返回空字串。 示例: $(basename src/foo.c src-1.0/bar.c hacks)返回值是“src/foo src-1.0/bar hacks”。
$(addsuffix <suffix>,<names...>) 名称:加后缀函数——addsuffix。 功能:把后缀<suffix>加到<names>中的每个单词后面。 返回:返回加过后缀的文件名序列。 示例: $(addsuffix .c,foo bar)返回值是“foo.c bar.c”。
$(addprefix <prefix>,<names...>) 名称:加前缀函数——addprefix。 功能:把前缀<prefix>加到<names>中的每个单词后面。 返回:返回加过前缀的文件名序列。 示例: $(addprefix src/,foo bar)返回值是“src/foo src/bar”。
$(join <list1>,<list2>) 名称:连接函数——join。 功能:把<list2>中的单词对应地加到<list1>的单词后面。如果<list1>的单词个数要比<list2>的多,那么, <list1>中的多出来的单词将保持原样。如果<list2>的单词个数要比<list1>多,那么,
<list2>多出来的单词将被复制到<list2>中。 返回:返回连接过后的字符串。 示例: $(join aaa bbb , 111 222 333)返回值是“aaa111 bbb222 333”。
foreach 函数 :用来做循环用的
$(foreach <var>,<list>,<text>)
把参数<list>中的单词逐一取出放到参数<var>所指定的变量中,然后再执行<text>所包含的表达式。每一次<text>会返回一个字符串,循环过程中, <text>的所返回的每个字符串会以空格分隔,最后当整个循环结束时,
<text>所返回的每个字符串所组成的整个字符串(以空格分隔)将会是 foreach 函数的返回值。
<var>最好是一个变量名, <list>可以是一个表达式,而<text>中一般会使用<var>这个参数来依次枚举<list>中的单词。
names := a b c d
files := $(foreach n,$(names),$(n).o) //$(files)的值是“a.o b.o c.o d.o
注意, foreach 中的<var>参数是一个临时的局部变量, foreach 函数执行完后,参数<var>的变量将不在作用,其作用域只在 foreach 函数当中
if 函数 :跟ifeq很像
$(if <condition>,<then-part>) //<condition>参数是 if 的表达式,如果其返回的为非空字符串,那么这个表达式就相当于返回真,于是, <then-part>会被计算,否则<else-part>会被计算 或是 $(if <condition>,<then-part>,<else-part>)
call 函数 :唯一一个可以用来创建新的参数化的函数
$(call <expression>,<parm1>,<parm2>,<parm3>...)
当 make 执行这个函数时, <expression>参数中的变量,如$(1), $(2), $(3)等,会被参数<parm1>, <parm2>, <parm3>依次取代。而<expression>的返回值就是 call 函数的返回值。
eg:
reverse = $(1) $(2) foo = $(call reverse,a,b) 那么, foo 的值就是“a b”。当然,参数的次序是可以自定义的,不一定是顺序的,如: reverse = $(2) $(1) foo = $(call reverse,a,b) 此时的 foo 的值就是“b a”
origin 函数 :不操作变量的值,他只是告诉你你的这个变量是哪里来的 。
$(origin <variable>) 注意:<variable>是变量的名字,不应该是引用。所以你最好不要在<variable>中使用“$”字符。 Origin函数会以其返回值来告诉你这个变量的“出生情况”,origin函数的返回值:
“undefined” :如果<variable>从来没有定义过, origin 函数返回这个值“undefined”。
“default” :如果<variable>是一个默认的定义,比如“CC”这个变量
“environment” :如果<variable>是一个环境变量,并且当 Makefile 被执行时,“-e”参数没有被打开。
“file” :如果<variable>这个变量被定义在 Makefile 中。
“command line” :如果<variable>这个变量是被命令行定义的。
“override” :如果<variable>是被 override 指示符重新定义的。
“automatic” :如果<variable>是一个命令运行中的自动化变量。