一起学Makefile(六)
命令的回显:
通常,make在执行命令之前都会把执行的命令进行输出,例如:
关闭命令回显有以下几种方式:
每个需要关闭回显的命令行之前加上”@”符号:
执行make时机上参数-s 或 –slient进制所有执行命令的显示。
在Makefile中使用没有以来的特殊目标时,.SLIENT也可以禁止所有命令的回显。
命令的执行
在Makefile中书写在同一行中的多个命令属于一个完整的shell命令行,书写在独立行的一条命令是一个独立的shell命令行。所以需要注意:在一个规则的命令中,命令行cd改变目录不会对其后的命令的执行产生影响。就是说其后的命令执行的工作目录不会是之前使用cd进入的那个目录。如果要实现这个目的,就不能把cd和其后的命令放在两行来书写。而应该把这两条命令写在一行上,用分号分隔。这样它们才是一个完整的shell命令行。
命令执行的错误执行
通常情况下,规则中的每一条命令在运行结束后,make都会检测命令执行的返回状态,如果返回成功,就执行下一条命令;命令出错(返回状态非0),make就会放弃对当前规则的执行,或者终止对当前makefile的解析执行。
在一些情况下,规则中的一个命令的执行失败并不代表规则执行的错误。为了忽略一些无关紧要的命令执行失败的情况,我们可以在命令之前加一个减号-,来告诉make忽略此命令的执行失败检查。
内嵌函数
make的内嵌函数为我们提供了处理文件名、变量、文本和命令的方法。使我们的Makefile更为灵活和健壮。我们可以在需要的地方调用函数来处理指定的文本(参数),函数在调用它的地方被替换为它的处理结果。函数调用(引用)的展开和变量引用的展开方式类似:
函数调用方式1:
$(FUNCTION ARGUMENTS)
函数调用方式2:
${FUNCTION ARGUMENTS}
内嵌函数分类:
使用wildcard函数改进complicated项目的makefile
wildcard函数,其使用范式:
$(wildcard PATTERN)
函数名称:wildcard
函数功能:列出当前目录下所有符合模式“PATTERN”格式的文件名。
返回值:空格分割的、存在当前目录下的所有符合模式“PATTERN”的文件名。
函数说明:“PATTERN”使用shell可识别的通配符,包括?(单字符)、*(多字符)等。
示例:
$(wildcard *.c)
返回值为当前目录下所有.c源文件列表。
我们可以引进wildcard函数,改进complicated项目的makefile,使其能够自动扫描当前目录下的源文件:
#define variable of executable file executable := complicated #define variable of source document sources := $(wildcard *.c) #using repalce with a reference to a variable #and define the 'object' file list objects := $(sources:.c=.o) #Define compile command variables CC := gcc RM := rm -rf #Ultimate goal rule,generating complicate executor $(executable):$(objects) #using an automated variable to transfer compilation command $(CC) -o $@ $^ #subrule 1 to generate main.o $(objects):%.o:%.c $(CC) -o $@ -c $< clean: $(RM) $(executable) $(objects)
运行结果如下: