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

如何在Makefile中替换单词列表中某个模式的所有匹配项?

在Makefile中,我们可以使用模式规则(Pattern Rules)来替换单词列表中某个模式的所有匹配项。模式规则是Makefile中的一种规则,用于定义如何根据一组模式和替换规则来生成目标文件。

下面是在Makefile中替换单词列表中某个模式的所有匹配项的步骤:

  1. 首先,定义一个模式规则,指定要替换的模式和替换规则。例如,假设我们要将列表中所有以"foo"开头的单词替换为"bar",可以定义如下模式规则:
  2. 首先,定义一个模式规则,指定要替换的模式和替换规则。例如,假设我们要将列表中所有以"foo"开头的单词替换为"bar",可以定义如下模式规则:
  3. 上述规则表示将所有以".foo"为后缀的文件替换为以".bar"为后缀的文件,并使用sed命令将文件中的"foo"替换为"bar"。
  4. 接下来,定义一个目标规则,指定要生成的目标文件列表。根据需要,可以使用通配符、变量或者手动指定文件列表。例如,假设我们要替换当前目录下所有以".foo"为后缀的文件,可以定义如下目标规则:
  5. 接下来,定义一个目标规则,指定要生成的目标文件列表。根据需要,可以使用通配符、变量或者手动指定文件列表。例如,假设我们要替换当前目录下所有以".foo"为后缀的文件,可以定义如下目标规则:
  6. 上述规则中,$(wildcard *.foo)表示获取当前目录下所有以".foo"为后缀的文件列表,$(patsubst %.foo,%.bar,...)表示将文件列表中所有以".foo"为后缀的文件替换为以".bar"为后缀的文件。
  7. 最后,在Makefile中添加模式规则和目标规则,并保存文件。在命令行中执行"make"命令即可开始替换过程。

在以上步骤中,我们使用了sed命令来实现对文件内容的替换操作。你可以根据具体需求选择合适的替换工具或命令。

这是一个简单的例子,展示了如何在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

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

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
领券