在Makefile规则中,通配符会被自动展开。但在变量的定义和函数引用时,通配符将失效。这种情况下如果需要通配符有效,就需要使用函数“wildcard”,它的用法是:$(wildcard PATTERN…) 。在Makefile中,它被展开为已经存在的、使用空格分开的、匹配此模式的所有文件列表。如果不存在任何符合此模式的文件,函数会忽略模式字符并返回空。需要注意的是:这种情况下规则中通配符的展开和上一小节匹配通配符的区别。
一般我们可以使用“(wildcard *.c)”来获取工作目录下的所有的.c文件列表。复杂一些用法;可以使用“(patsubst %.c,%.o,
#sample Makefile
objects := (patsubst %.c,%.o,(wildcard *.c))
foo : $(objects)
cc -o foo $(objects)
这里我们使用了make的隐含规则来编译.c的源文件。对变量的赋值也用到了一个特殊的符号(:=)。
1、wildcard : 扩展通配符 2、notdir : 去除路径 3、patsubst :替换通配符
例子:建立一个测试目录,在测试目录下建立一个名为sub的子目录 mkdir test cd test
在test下,建立a.c和b.c2个文件,在sub目录下,建立sa.c和sb.c2 个文件
建立一个简单的Makefilesrc=(wildcard *.c ./sub/*.c)dir=(notdir (src))obj=(patsubst %.c,%.o,
all: @echo (src) @echo (dir) @echo
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)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/198374.html原文链接:https://javaforall.cn