【makefile笔记】patsubst和wildcard函数使用小结

0x00 前言

文章中的文字可能存在语法错误以及标点错误,请谅解;

如果在文章中发现代码错误或其它问题请告知,感谢!

0x01 makefile函数调用语法

makefile函数调用原型:

$(<function> <arguments>)
#或
${<function> <arguments>}

函数的调用以$开头,用{}或者()将函数名以及参数包含起来,<function>为函数名,<arguments>为参数,两者之间以空格分隔,若存在多个<arguments>参数,使用,分开。例如:

#subst函数作用是将字符串“maktfilt中”的't'替换为'e',其中函数名为subst ,参数为t,e,maktfilt
$(subst t,e,maktfilt) 

0x02 wildcard函数

wildcard函数调用原型:

$(wildcard <PATTERN...>)

wildcard函数是针对通配符在函数或变量定义中展开无效情况下使用的,用于获取匹配该模式下的所有文件列表,<PATTERN...>参数若有多个则用空格分隔。若没有找到指定的匹配模式则返回为空。
例如:

#返回make工作下的所有.cpp以及.c文件
$(wildcard *.cpp *.c)

0x03 patsubst函数

patsubst函数调用原型:

$(patsubst  <pattern>,<replacement>,<text>)

patsubst函数返回被替换过后的字符串。patsubst函数判断<text>中字符串(若多个字符串以空格分隔)是否匹配<pattern>模式,若匹配则使用<replacement>替换<text><pattern>可以包括通配符%表示任意长度的字串。如果<replacement>中也包含%,则<replacement>中的这个%将是<pattern>中的那个%所代表的字符串。若字符串中含有%则可以用反斜杠\来转义,即\%来表示真实含义的%字符。

示例:

#把字符串“x.c.c bar.c”符合模式%.c的单词替换成%.o,返回“x.c.o bar.o”。
$(patsubst %.c,%.o,x.c.c bar.c)

0x04 patsubst和wildcard举例

建立一个目录patsubst_wildcard_Demo,新建a.cb.cmakefile文件,并建立一个子目录src,在src中新建src_a.csrc_b.c文件:

$ mkdir patsubst_wildcard_Demo
$ cd ./patsubst_wildcard_Demo
$ touch a.c
$ touch b.c
$ mkdir src
$ touch src_a.c
$ touch src_b.c

patsubst_wildcard_Demo的tree目录如下:

.
├── a.c
├── b.c
├── makefile
└── src
    ├── src_a.c
    └── src_b.c

编写makefie文件内容如下:

DIR_SRC = ./src

SRC_NONE =$(DIR_SRC)/*.c *.c
SRC_WILDCARD = $(wildcard $(DIR_SRC)/*.c *.c)

OBJ_NONE_NONE = $(patsubst %.c,%.o,$(DIR_SRC)/*.c *.c) 
OBJ_WILDCARD_NONE = $(patsubst %.c,%.o,$(wildcard $(DIR_SRC)/*.c *.c))

OBJ_NONE = $(patsubst %.c,%.o,$(SRC_NONE)) 
OBJ_WILDCARD = $(patsubst %.c,%.o,$(wildcard $(SRC_WILDCARD)))

all:
	@echo $(SRC_NONE)
	@echo $(SRC_WILDCARD)
	@echo $(OBJ_NONE_NONE)
	@echo $(OBJ_WILDCARD_NONE)
	@echo $(OBJ_NONE)
	@echo $(OBJ_WILDCARD)

输出:

$ make
./src/src_a.c ./src/src_b.c a.c b.c
./src/src_a.c ./src/src_b.c a.c b.c
./src/*.o *.o
./src/src_a.o ./src/src_b.o a.o b.o
./src/*.o *.o
./src/src_a.o ./src/src_b.o a.o b.o

可以看出,由于通配符*在函数定义中展开无效,所以OBJ_NONE在使用patsubst函数后echo的输出为./src/*.o *.o。而在OBJ_WILDCARD中使用wildcard函数使得通配符正确展开,最后echo输出了正确结果。

该Demo项目已经上传至github:https://github.com/fyw4/patsubst_wildcard_Demo

在参考文档2中列出了make所支持的函数,在编写makefile文件时可以参考。

以上。

参考文档:
1.https://blog.csdn.net/iam_charlie/article/details/6915002
2.https://cloud.tencent.com/developer/article/1406069
3.https://blog.csdn.net/rudyn/article/details/7565390

  • 19
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Makefile 中的 wildcardpatsubst 是两种重要的函数,它们用于规则定义中的模式匹配。 - wildcard:这个函数用于扩展通配符,并返回与通配符匹配的文件列表。例如,`wildcard *.c` 将返回当前目录下所有以 .c 结尾的文件名列表。 - patsubst:这个函数用于模式匹配和替换,并返回匹配模式的字符串的列表,其中部分字符被替换为指定的字符串。例如,`patsubst %.c,%.o,$(wildcard *.c)` 将返回所有以 .c 结尾的文件名,并将 .c 替换为 .o。 这两个函数Makefile 中经常被用于自动生成依赖关系和生成规则。 ### 回答2: makefile 中的 wildcardpatsubst 是两个用于模式匹配的关键字。 1. wildcardwildcard 是通配符函数,用于查找指定目录下符合指定模式的文件名。使用的语法是$(wildcard pattern),其中 pattern 是文件名的模式,可以包含通配符字符 * 和 ?。wildcard 函数会返回符合模式的文件名列表。 例如,如果有一个目录下有三个文件:file1.txt、file2.txt 和 file3.csv,可以使用 wildcard 函数来查找所有以 .txt 结尾的文件名: ```makefile TXT_FILES := $(wildcard *.txt) ``` 上述代码会将符合模式的文件名列表赋值给变量 TXT_FILES,最终结果为 "file1.txt file2.txt"。 2. patsubstpatsubst 是模式替换函数,用于根据指定的模式匹配规则替换字符串。使用的语法是$(patsubst pattern,replacement,text),其中 pattern 是要匹配的模式,replacement 是替换的内容,text 是要进行替换的原始文本。 例如,如果有一个变量包含了文件名列表,可以使用 patsubst 函数将其中的 .txt 后缀替换成 .csv: ```makefile FILENAMES := file1.txt file2.txt file3.txt CSV_FILENAMES := $(patsubst %.txt,%.csv,$(FILENAMES)) ``` 上述代码会将 FILENAMES 中的每个文件名进行模式匹配,将其中 .txt 替换成 .csv,然后赋值给变量 CSV_FILENAMES,最终结果为 "file1.csv file2.csv file3.csv"。 通过使用 wildcardpatsubst,可以方便地在 makefile 中进行文件名的模式匹配和替换,从而实现更灵活的文件操作。 ### 回答3: 在makefile中,wildcardpatsubst是两个非常有用的函数,用于处理文件名模式匹配和字符串替换。 wildcard函数用于获取当前目录下符合特定模式的文件列表,其语法为:$(wildcard pattern),其中pattern是文件名匹配模式。 例如,假设当前目录下有三个文件:file1.txt、file2.txt和file3.txt。我们可以使用$(wildcard *.txt)来获取所有以.txt结尾的文件列表。返回的结果为:"file1.txt file2.txt file3.txt"。 patsubst函数用于进行字符串的模式替换,其语法为:$(patsubst pattern,replacement,text),其中pattern是要匹配的模式,replacement是要替换的内容,text是要进行替换操作的字符串。 例如,我们可以使用$(patsubst %.txt,%.md,file1.txt)将文件名的后缀从.txt替换为.md。返回的结果为:"file1.md"。 另外,通常我们可以将wildcardpatsubst结合使用,以便在makefile中处理一组符合特定模式的文件。 例如,我们可以使用以下语句来定义一个变量,其中包含所有以.c结尾的文件,并将后缀替换为.o: ``` SRC_FILES := $(wildcard *.c) OBJ_FILES := $(patsubst %.c,%.o,$(SRC_FILES)) ``` 上述语句会将当前目录下所有以.c结尾的文件保存在SRC_FILES变量中,并将文件名的后缀替换为.o保存在OBJ_FILES变量中。 通过理解和使用wildcardpatsubst函数,我们可以更加灵活和高效地处理文件名和字符串的模式匹配、替换和操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值