14、makefile 基本语法(下)
一、wildcard 函数
格式: $ (wildcard PATTENR)
功能: 展开指定的目录
举例:
在 /home/topeet/test 目录有一个 a.c 的 c 文件和一个 test 的文件夹,在/home/topeet/test/test 文件夹下有一个 b.c 的文件。
我们在当前目录下创建的 makefile 里面写下如下代码,echo 前面加了@ 符号,echo 这个命令就不显 示:
执行结果:
我们得到了 ./a.c 和 ./test/b.c ,所以 wildcard 函数会把我们指定的 ./ 和 ./test/ 目录下的 c 文件展开。
二、notdir 函数
格式: $$ (notdir $$ (var) )
功能:去掉路径。
举例:
我们在上面的 makefile 中加上以下代码,因为上面的例子我们得到的结果是 ./a.c 和 ./test/b.c 是有路径的,我们可以直接使用这个变量。
执行结果:
因为 notdir 函数可以去掉路径,所以 /a.c 和 ./test/b.c 去掉路径就得到了 a.c 和 b.c
三、dir 函数
格式: $(dir <names...>)
功能:取出目录,这里的目录指的是最后一个反斜杠/ 之前的部分,如果没有反斜杠/就返回当前。
举例:
我们在上面的例子中加入以下代码,如下图所示:
因为 var2 的值为 ./a.c 和 ./test/b.c ,所以取出目录就是 ./ 和 ./test ,如下图所示:
四、patsubst 函数
格式: $(patsubst 原文件,目标文件,文件列表)
功能:替换文件后缀
举例
我们在上面的例子中加入以下代码,如下图所示:
这个函数会把 var1 变量的 a.c 和 b.c 的 .c 后缀替换为 .o ,如下图所示:
五、foreach 函数
格式:$(foreach <var>,<list>,<text>)
功能:把参数 <list>中的单词逐一取出放到参数 <var>所指定的变量中,然后再执行 <text> 所包含的表达 式。每一次 <text> 会返回一个字符串
因为 var2 变量的值为 ./ 和 ./test ,所以先把 ./ 取出来放在 n 变量,然后再执行 wildcard 函数取出 ./test 和 ./test 下面的 c 文件的路径。所以执行结果如下图所示: