GUN make (4) 规则的命令

规则的命令是由一些shell命令行组成,被一条一条执行。

通常系统中存在不同的shell,但在make处理Makefile过程中,如果没有明确指定,那么对所有规则中的命令行解析使用 “/bin/sh” 完成。

 

1.  命令回显

回显是指在执行命令之前将要执行的命令输出到标准输出设备。

@参数:

如果命令行以 @ 开始,则make在执行这个命令时不会回显这个要被执行的命令。

比如:

@echo 开始编译 
输出为:开始编译

echo 开始编译 
输出为:echo 开始编译

 

-n 或 --just-print参数:
make在执行时只显示所要执行的命令,但不会真正去执行这些命令。

 

-s 或 --slient参数:
禁止所要执行命令的显式,就好像所要的命令均使用@开始一样。

 

2. 命令的执行

2.1 独立执行

当多行命令时,每一行的命令将在一个独立的子shell进程中执行,执行是相互独立的。

同一行的多个命令属于一个完整的shell命令行。

2.2 并发执行

使用-j 或者 --job使得make在同一时刻可以允许多条命令同时执行。

并发执行的问题:

  • 多个同时执行的命令输出信息将同时被输出到终端。
  • 同一时刻多个执行命令的进程中只能有一个进程获得标准输入,其他需要读取的标准输入流的进程由于输入流无效而导致错误。

 

3. 命令执行的错误

如果一个规则中的某一个命令出错,make就会放弃对当前规则后续命令的执行,也有可能会终止所有规则的执行。

 

为了忽略一些无关命令执行失败的情况:

  • 在命令之前加 “-” 表示忽略此命令的执行失败。
  • 使用 -i 或者 --ignore-errors,使得make忽略所有规则中命令执行时错误。
  • 使用 -k 或者 --keep-going,使得在出现错误时不立即退出,而是继续后续命令的执行,直到执行到最后链接时才有异常退出。

 

4. 中断make的执行

make在执行命令时如果收到一个致命信号,那么make将会删除此过程中已经重建的那些规则的目标文件。

原因:
如果中断信号关闭了编译器,则生成的foo.o可能是不完整的,当时这个不完成的foo.o文件的时间戳比源程序foo.c时间戳新,如果不删除foo.o, 则下次执行make时此文件被认为已经是最新的而不去重建。

 

5. make的递归执行

make递归执行是指在makefile中使用make作为一个命令来执行本身或者其他makefile文件的过程。

在make递归调用时,规则的命令行中应该使用变量 MAKE 来代替 make。优点是当我们使用一个其他版本的make程序时,可以保证最上层使用的make程序和其子目录下执行的make程序保持一直。

subsystem:
    cd subdir && $(MAKE)

等价于进入子目录执行:
subsystem:
    $(MAKE) -C subdir             

 

6. 变量和递归

在make执行过程中 ,使用环境变量传递上层所定义的变量时,不会覆盖子make中Makefile文件中的同名变量定义。

若存在重复,则以子Makefile中为准,除非使用-e选项。

 

若需要向变量传递给子make,需要export进行指定。

export VAR
  • 若不使用export进行指定,上层make只将那些已经初始化的环境变量 和 使用命令行指定的变量(make CFLAGS += -g) 传递给子make程序。
  • 存在特殊变量SHELL 和 MAKEFLAGS ,这两个变量除非使用unexport进行声明,它们在整个make执行过程中始终自动传递给子make。
  • 当不希望传递MAKEFLAGS,需要在调用子make时对这边变量进行赋空:
sub:
    cd subdir && $(MAKE) MAKEFLAGS=
  • 一个不带参数的export指示符表示将Makefile中定义的所有变量传递给子make。如果不需要其中某个,使用unexport单独指定,但是不带参数的unexport没有意义。
export

 

7. -w选项

在多级make递归调用过程中,使用-w 或者 --print-directory让make在开始编译一个目录之前和完成目录编译之后给出相应的提示信息,方便跟踪。

通常-w会被默认打开。可以使用 -s 禁止此选项。

 

比如,在目录/u/gun/make 目录下执行make -w:

在执行开始之前看到:
make:Entering directory '/u/gun/make'
在执行完成之后看到:
make:Leaving directory '/u/gun/make'

 

8. 定义命令包

使用define定义一组命令作为命令包,实现类似于函数的功能。

在命令包中,命令体中的变量和函数的引用不会展开,在规则被使用的时候完全展开。

比如:

define run-yacc
yacc $(firstword $^)
mv y.tab.c $@
endef

使用:
foo.c:foo.y
    $(run-yacc)

替换过程:
命令包中的 $^ 会被 foo.y替换
$@会被foo.c替换

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
摘自http://www.linuxsir.org/main/doc/gnumake/GNUmake_v3.80-zh_CN_html 由徐海兵老師翻译整理。 本文比较完整的讲述GNU make工具,涵盖GNU make的用法、语法。同时重点讨论如何为一个工程编写Makefile。作为一个Linux程序员,make工具的使用以及编写Makefile是必需的 目 录 第一章:概述 1.1 概述 1.2 准备知识 第二章:GNU make 介绍 2.1 Makefile简介 2.2 Makefile规则介绍 2.3 简单的示例 2.4 make如何工作 2.5 指定变量 2.6 自动推导规则 2.7 另类风格的makefile 2.8 清除工作目录过程文件 第三章:Makefile 总述 3.1 Makefile的内容 3.2 makefile文件的命名 3.3 包含其它makefile文件 3.4 变量 MAKEFILES 3.5 变量 MAKEFILE_LIST 3.6 其他特殊变量 3.7 makefile文件的重建 3.8 重载另外一个makefile 3.9 make如何解析makefile文件 3.9.1 变量取值 3.9.2 条件语句 3.9.3 规则的定义 3.10 总结 第四章:Makefile规则 4.1 一个例 4.2 规则语法 4.3 依赖的类型 4.4 文件名使用通配符 4.4.1 统配符使用举例 4.4.2 通配符存在的缺陷 4.4.3 函数wildcard 4.5 目录搜寻 4.5.1 一般搜索(变量VPATH) 4.5.2 选择性搜索(关键字vpath) 4.5.3 目录搜索的机制 4.5.4 命令行和搜索目录 4.5.5 隐含规则和搜索目录 4.5.6 库文件和搜索目录 4.6 Makefile伪目标 4.7 强制目标(没有命令或依赖的规则) 4.8 空目标文件 4.9 Makefile的特殊目标 4.10 多目标 4.11 多规则目标 4.12 静态模式 4.12.1 静态模式规则的语法 4.12.2 静态模式和隐含规则 4.13 双冒号规则 4.14 自动产生依赖 第五章:规则命令 5.1 命令回显 5.2 命令的执行 5.3 并发执行命令 5.4 命令执行的错误 5.5 中断make的执行 5.6 make的递归执行 5.6.1 变量MAKE 5.6.2 变量和递归 5.6.3 命令行选项和递归 5.6.4 -w选项 5.7 定义命令包 5.8 空命令 第六章:Makefile中的变量 6.1 变量的引用 6.2 两种变量定义(赋值 ) 6.2.1 递归展开式变量 6.2.2 直接展开式变量 6.2.3 如何定义一个空格 6.2.4 “?=”操作符 6.3 变量的高级用法 6.3.1 变量的替换引用 6.3.2 变量的套嵌引用 6.4 变量取值 6.5 如何设置变量 6.6 追加变量值 6.7 override 指示符 6.8 多行定义 6.9 系统环境变量 6.10 目标指定变量 6.11 模式指定变量 第七章:Makefile的条件执行 7.1 一个例 7.2 条件判断的基本语法 7.2.1 关键字“ifeq” 7.2.2 关键字“ifneq” 7.2.3 关键字“ifdef” 7.2.4 关键字“ifndef” 7.3 标记测试的条件语句 第八章:make的内嵌函数 8.1 函数的调用语法 8.2 文本处理函数 8.2.1 $(subst FROM,TO,TEXT) 8.2.2 $(patsubst PATTERN,REPLACEMENT,TEXT) 8.2.3 $(strip STRINT) 8.2.4 $(findstring FIND,IN) 8.2.5 $(filter PATTERN…,TEXT) 8.2.6 $(filter-out PATTERN...,TEXT) 8.2.7 $(sort LIST) 8.2.8 $(word N,TEXT) 8.2.9 $(wordlist S,E,TEXT) 8.2.10 $(words TEXT) 8.2.11 $(firstword NAMES…) 8.3 文件名处理函数 8.3.1 $(dir NAMES…) 8.3.2 $(notdir NAMES…) 8.3.3 $(suffix NAMES…) 8.3.4 $(basename NAMES…) 8.3.5 $(addsuffix SUFFIX,NAMES…) 8.3.6 $(addprefix PREFIX,NAMES…) 8.3.7 $(join LIST1,LIST2) 8.3.8 $(wildcard PATTERN) 8.4 foreach 函数 8.5 if 函数 8.6 call函数 8.7 value函数 8.8 eval函数 8.9 origin函数 8.10 shell函数 8.11 make的控制函数 8.11.1 $(error TEXT…) 8.11.2 $(warning TEXT…) 第九章:执行make 9.1 指定makefile文件 9.2 指定终极目标 9.3 替代命令的执行 9.4 防止特定文件重建 9.5 替换变量定义 9.6 使用make进行编译测试 9.7 make命令行选项 第十章:make的隐含规则 10.1 隐含规则的使用 10.2 make的隐含规则一览 10.3 隐含变量 10.3.1 代表命令变量 10.3.2 命令参数的变量 10.4 make隐含规则链 10.5 模式规则 10.5.1 模式规则介绍 10.5.2 模式规则示例 10.5.3 自动化变量 10.5.4 模式的匹配 10.5.5 万用规则 10.5.6 重建内嵌隐含规则 10.6 缺省规则 10.7 后缀规则 10.8 隐含规则搜索算法 第十一章:使用make更新静态库文件 11.1 库成员作为目标 11.2 静态库的更新 11.2.1 更新静态库的符号索引表 11.3 make静态库的注意事项 11.4 静态库的后缀规则 第十二章 : GNU make的特点 12.1 源自System v的特点 12.2 源自其他版本的特点 12.3 GNU make自身的特点 第十三章 和其它版本的兼容 第十四章 Makefile的约定 14.1 基本的约定 14.2 规则命令行的约定 14.3 代表命令变量 14.4 安装目录变量 14.5 Makefile的标准目标名 14.6 安装命令分类 第十五章 make的常见错误信息   附录:关键字索引 1. GNU make可识别的指示 符 2. GNU make函数 3. GNU make的自动化变量 4. GNU make环境变量 后序

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值