首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何从makefile字符串变量中提取模式

从makefile字符串变量中提取模式可以使用makefile中的字符串处理函数和模式匹配功能。以下是一种常见的方法:

  1. 使用$(subst from,to,text)函数将字符串变量中的某个子字符串替换为另一个字符串。例如,假设我们有一个字符串变量SRC_FILES包含了一组源文件名,我们想提取其中的.c文件,可以使用以下代码:
代码语言:txt
复制
SRC_FILES := file1.c file2.cpp file3.c file4.h
C_FILES := $(subst .cpp,.c,$(filter %.cpp,$(SRC_FILES)))

上述代码中,$(filter %.cpp,$(SRC_FILES))会返回SRC_FILES中以.cpp结尾的文件名,然后$(subst .cpp,.c,...)将这些文件名的后缀替换为.c,最终得到C_FILES变量包含了.c文件名。

  1. 使用$(patsubst pattern,replacement,text)函数进行模式匹配和替换。例如,假设我们有一个字符串变量SRC_FILES包含了一组源文件名,我们想提取其中的以file开头的文件,可以使用以下代码:
代码语言:txt
复制
SRC_FILES := file1.c file2.cpp file3.c file4.h
FILE_FILES := $(patsubst file%,%,$(filter file%,$(SRC_FILES)))

上述代码中,$(filter file%,$(SRC_FILES))会返回SRC_FILES中以file开头的文件名,然后$(patsubst file%,%,...)将这些文件名中的file前缀去掉,最终得到FILE_FILES变量包含了提取后的文件名。

  1. 使用正则表达式进行模式匹配和替换。makefile中没有内置的正则表达式函数,但可以使用shell命令来实现。例如,假设我们有一个字符串变量SRC_FILES包含了一组源文件名,我们想提取其中的以数字结尾的文件,可以使用以下代码:
代码语言:txt
复制
SRC_FILES := file1.c file2.cpp file3.c file4.h
NUM_FILES := $(shell echo $(SRC_FILES) | grep -oE '[0-9]+')

上述代码中,$(shell echo $(SRC_FILES) | grep -oE '[0-9]+')会将SRC_FILES中的内容通过管道传递给grep命令,并使用正则表达式'[0-9]+'匹配其中的数字部分,最终得到NUM_FILES变量包含了提取后的数字。

以上是从makefile字符串变量中提取模式的一些常见方法,根据具体的需求和字符串格式,可以选择适合的方法进行处理。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Makefile经典教程(掌握这些足够)

    makefile很重要       什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义。特别在Unix下的软件编译,你就不能不自己写makefile了,会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力。因为,makefile关系到了整个工程的编译规则。一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。

    02

    linux下源码安装

    源码安装:配置(configure)、编译(make)、安装(make install),所有操作中间错误可以忽略,最后段末尾统一报错。 ####1.配置  configure:生成Makefile的shell脚本  文件结构如下:   <文件夹>     |-configure.in     |-Makefile.am     |-acconfig.h     |-<源码文件>       |-tt.c       |-qq.c       |-qq.h       |-Makefile.am  其中configure.in作为./configure的配置输入;makefile.am通过automake生成makefile.in再由./configure生成makefile;acconfig.h由autoheader生成config.h.in再由./configure生成config.h  configure.h使用autoconf和automake命令的shell脚本,可以通过autoscan自动生成或手写  acconfig.h包含了configure.in中未定义的宏 autoscan–>autoheader–>aclocal–>automake|autoconf

    04

    makefile中的include的作用(makefile中的变量)

    例子: 建立一个测试目录,在测试目录下建立一个名为sub的子目录 $ mkdir test $ cd test $ mkdir sub 在test下,建立a.c和b.c2个文件,在sub目录下,建立sa.c和sb.c2 个文件 建立一个简单的Makefile src=$(wildcard *.c ./sub/*.c) dir=$(notdir $(src)) obj=$(patsubst %.c,%.o,$(dir) ) all: @echo $(src) @echo $(dir) @echo $(obj) @echo “end” 执行结果分析: 第一行输出: a.c b.c ./sub/sa.c ./sub/sb.c wildcard把 指定目录 ./ 和 ./sub/ 下的所有后缀是c的文件全部展开。 第二行输出: a.c b.c sa.c sb.c notdir把展开的文件去除掉路径信息 第三行输出: a.o b.o sa.o sb.o 在$(patsubst %.c,%.o,$(dir) )中,patsubst把$(dir)中的变量符合后缀是.c的全部替换成.o, 任何输出。 或者可以使用 obj=$(dir:%.c=%.o) 效果也是一样的。 这里用到makefile里的替换引用规则,即用您指定的变量替换另一个变量。 它的标准格式是 $(var:a=b) 或 ${var:a=b} 它的含义是把变量var中的每一个值结尾用b替换掉a 今天在研究makefile时在网上看到一篇文章,介绍了使用函数wildcard得到指定目录下所有的C语言源程序文件名的方法,这下好了,不用手工一个一个指定需要编译的.c文件了,方法如下: SRC = $(wildcard *.c) 等于指定编译当前目录下所有.c文件,如果还有子目录,比如子目录为inc,则再增加一个wildcard函数,象这样: SRC = $(wildcard *.c) $(wildcard inc/*.c) 也可以指定汇编源程序: ASRC = $(wildcard *.S) 这样一来,makefile模板可修改的基本就是AVR名称和时钟频率了,其它的一般不用动了。

    05

    嵌入式裸板学习之基础知识

    简介 数据在内存中以字节形式存放,X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以随时在程序中(在ARM Cortex 系列使用REV、REV16、REVSH指令 [1] )进行大小端的切换。 大端模式 指数据的高字节,保存在内存的低地址中,而数据的低字节,保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放; 小端模式 是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低,和我们的逻辑方法一致。

    02
    领券