深入理解 Makefile 规则与变量
1. Make 规则命令部分的特性
Make 规则的命令部分并非 shell 脚本。当 Make 调用规则来构建目标时,规则命令部分的每一行会在单独的 shell 实例中分别执行。因此,要确保任何命令都不依赖于前一行的副作用。
例如,以下命令不会在 src
子目录中运行 etags
:
TAGS:
cd src/
etags *.c
在构建 TAGS
时,Make 先在当前目录下运行 cd src/
,该命令退出后,又在新的 shell 中、当前目录下运行 etags *.c
。
若要让多个命令在同一个 shell 中运行,有两种方法:
- 将它们放在一行,用分号分隔。
- 添加反斜杠,使其在逻辑上处于同一行。
示例如下:
TAGS:
cd src/ ;\
etags *.c
在大型项目中,让多个命令在同一 shell 中运行还能加快处理速度。
2. 模式规则
2.1 模式规则的基本概念
模式规则可经济地描述具有重复模式的情况。例如, circle.o