前言
一、环境变量(全局变量)
- Makefile 中的环境变量,是指在执行 Makefile 时,
从外部传入 Make 命令的环境变量
。
一些常用的 Makefile 环境变量:
MAKE
:表示当前正在使用的 Make 工具的名称;PWD
:表示当前目录的绝对路径;SHELL
:表示当前 Shell 的名称。默认是 /bin/sh。可以通过定义 SHELL 变量来指定所使用的 Shell;MAKEFLAGS
:表示传递给 make 命令的所有参数。可以在 Makefile 中通过 $(MAKEFLAGS) 来引用它;MAKELEVEL
:表示 Make 命令嵌套的层数,从 0 开始计数。
环境变量可以在所有的 makefile 中使用。
但是,过多依赖于环境变量会导致代码移植性降低。
- 变量在不同的 makefile 之间进行传递:
(1). 直接在外部定义环境变量进行传递。
(2). 使用 export 定义变量进行传递。(定义临时变量)
(3). 定义 make 命令行变量进行传递。
- 注意:
如果 makefile 文件中 定义了同名变量,环境变量将会被覆盖。
- 运行 make 时,指定 " -e " 选项,优先使用环境变量。
示例:
makefile 文件:
export var := hello # 使用 export 定义临时环境变量 new := world test : @$(MAKE) -f makefile.1 # 首次 进入 makefile.1 文件 执行命令 @$(MAKE) -f makefile.1 new:=$(new) # 再次 进入 makefile.1 文件,使用命令行进行变量传递。
makefile.1 文件:
test: @echo "var => $(var)" @echo "new => $(new)"
执行结果:
第一次进入 makefile.1 文件,只输出了 var 的值,而 new 为空。 因为 var 使用了 export 定义临时环境变量,则 可在 不同的 makefile 文件间传递。
第二次进入 makefile.1 文件,new 也输出了值,这次使用 命令行进行传递变量。
在 Makefile 中, $(MAKE) 是一个内置变量,它表示当前正在使用的 Make 命令的名称。这个变量可以保证在使用不同版本的 Make 工具或者在不同的操作系统中都能正确地工作。
如果在一个 Makefile 中调用另一个 Makefile,可以使用 -f 选项来指定目标 Makefile 文件的名称。
二、目标变量(局部变量)
作用域 只在 指定的目标 及 连带规则 中。
示例:
var := hello # 文件变量 test : var := world # 定义目标变量 var test : another # 依赖于 another @echo "test" @echo "var => $(var)" another : @echo "another" @echo "var => $(var)"
test 目标 和其 another 依赖均打印出 world, 而不是 hello
文件变量: 在 makefile 中定义的变量,这个很好理解,即 作用域为 整个 makefile 文件。
三、模式变量
- 模式变量 是
目标变量的扩展
。 - 作用域只在
符合模式的目标及连带规则中
。
var := hello %e : override var := abc # 定义模式变量 test : @echo "test" @echo "var => $(var)" rule : @echo "rule" @echo "var => $(var)"
%e 表示 目标结尾 是 e 的可以执行 %e : override var := abc。
test 不是以 e 结尾,而 rule 是以 e 结尾,则打印出 abc。