一起学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)

运行结果如下:

 

posted @ 2019-10-31 14:12  王清河  阅读(242)  评论(0编辑  收藏  举报