上一篇:makefile学习笔记(三)介绍了makefile的多目标规则、多规则目标、静态模式规则和伪目标。本节将介绍makefile的更多内容。
1. 命令
- 命令的回显
通常,make在执行命令行之前会把要执行的命令行进行输出,这就是命令的回显。如以下makefile所示:
all:
echo "Hello csdn!"
在执行make时输出:
$ make
echo "Hello csdn!"
Hello csdn!
有时候命令的回显看起来会很烦人。幸运的是,它是可以被关闭的。关闭命令回显有以下几种方式:
- 每个需要关闭回显的命令行前加上"@"字符;
- 执行make时带上参数 -s 或 –slient 禁止所有执行命令的显示;
- 在Makefile中使用没有依赖的特殊目标 .SILENT 也可以禁止所有命令的回显。
- 命令的执行
在Makefile中,书写在同一行中的多个命令属于一个完整的shell命令行,书写在独立行的一条命令是一个独立的shell命令行。所以需要注意:在一个规则的命令中,命令行cd改变目录不会对其后的命令的执行产生影响。就是说其后的命令执行的工作目录不会是之前使用cd进入的那个目录。如果要实现这个目的,就不能把cd和其后的命令放在两行来书写,而应该把这两条命令写在一行上,用分号分隔。这样它们才是一个完整的shell命令行。
下面用一个名为cmd.mk的makefile对比一下两个规则的输出:
target1:
@echo "target1"
@cd ~
@pwd
target2:
@echo "target2"
@cd ~; pwd
演示如下:
- 命令执行的错误处理
通常情况下,规则中的每一条命令在运行结束后,make都会检测命令执行的返回状态,如果返回成功,就执行下一条命令;命令出错(返回状态非0),make就会放弃对当前规则的执行,或者终止对当前makefile的解析执行。
在一些情况下,规则中的一个命令的执行失败并不代表规则执行的错误。为了忽略一些无关紧要的命令执行失败的情况,我们可以在命令之前加一个减号-,来告诉make忽略此命令的执行失败检查。
2. 内嵌函数
make的内嵌函数为我们提供了处理文件名、变量、文本和命令的方法,使我们的makefile更为灵活和健壮。我们可以在需要的地方调用函数来处理指定的文本(参数),函数在调用它的地方被替换为它的处理结果。函数调用(引用)的展开和变量引用的展开方式类似。
函数调用方式1:
$(</