1.wildcard
wildcard是makefile中的一个函数,在makefile规则中,它可以让通配符自动展开,可以在变量的定义和函数的引用时不让通配符失效,用法如下:
$(wildcard PATTERN...)
展开为已经存在的、使用空格分开的、匹配此模式的所有文件列表。假如不存在任何符合此模式的文件,函数会忽略模式字符并返回空。
如果要展开工作目录下的所有c文件列表,用法如下:
$(wildcard *.c)
配合patsubst一起使用可以将所有的.c文件后缀替换后缀.o,使用方法如下:
$(patsubst %.c,%.o,$(wildcard *.c))
这样我们就可以得到在当前目录可生成的.o文件列表。因此在一个目录下可以使用如下内容的Makefile来将工作目录下的所有的.c文件进行编译并最后连接成为一个可执行文件:
CC=gcc
OBJ := $(patsubst %.c,%.o,$(wildcard *.c))
app : $(objects)
CC -o foo $(objects)
如果想看看展开的列表是不是当前目录下想要展开的文件列表可以添加echo打印,使用如下:
OBJ=$(wildcard *.cpp *.hpp)
all:
echo $(OBJ)