1 foreach函数
语法: $(foreach var,list,text)
简单地说,就是 for each var in list, change it to text。
对list中的每一个元素,取出来赋给var,然后把var改为text所描述的形式。
例子:
objs := a.o b.o
dep_files := $(foreach f, $(objs), .$(f).d) // 最终 dep_files := .a.o.d .b.o.d
2 wildcard函数
语法: $(wildcard pattern)
pattern所列出的文件是否存在,把存在的文件都列出来。
例子:
src_files := $( wildcard *.c) // 最终 src_files中列出了当前目录下的所有.c文件
3 patsubst函数
语法: $(patsubst pattern,replacement,text)
寻找text中符合格式pattern的字,用replacement替换它们。pattern和replacement中可以使用通配符。
举例:
subdir-y := c/ d/
subdir-y := $(patsubst %/, %, $(subdir-y)) // 结果为:c d
4 filter 函数
语法: $(filter pattern…,text)
把text中符合pattern格式的内容,filter(过滤)出来、留下来。
举例:
obj-y := a.o b.o c/ d/
DIR := $(filter %/, $(obj-y)) //结果为:c/ d/
5 filter-out函数
语法: $(filter-out pattern…,text)
把text中符合pattern格式的内容,filter-out(过滤)出来、扔掉。
举例:
obj-y := a.o b.o c/ d/
DIR := $(filter-out %/, $(obj-y)) //结果为:a.o b.o
参考资料
本文深入讲解了Makefile中的五个关键函数:foreach、wildcard、patsubst、filter和filter-out。通过具体示例,详细解释了每个函数的语法、用途及应用场景,帮助读者掌握Makefile构建过程中的高级技巧。
1516

被折叠的 条评论
为什么被折叠?



