makefile 变量的扩展

简介: makefile 变量的扩展

前言


一、环境变量(全局变量)

  1. Makefile 中的环境变量,是指在执行 Makefile 时,从外部传入 Make 命令的环境变量

一些常用的 Makefile 环境变量:

  • MAKE:表示当前正在使用的 Make 工具的名称;
  • PWD:表示当前目录的绝对路径;
  • SHELL:表示当前 Shell 的名称。默认是 /bin/sh。可以通过定义 SHELL 变量来指定所使用的 Shell;
  • MAKEFLAGS:表示传递给 make 命令的所有参数。可以在 Makefile 中通过 $(MAKEFLAGS) 来引用它;
  • MAKELEVEL:表示 Make 命令嵌套的层数,从 0 开始计数。

环境变量可以在所有的 makefile 中使用。

但是,过多依赖于环境变量会导致代码移植性降低。

  1. 变量在不同的 makefile 之间进行传递:

(1). 直接在外部定义环境变量进行传递

(2). 使用 export 定义变量进行传递。(定义临时变量

(3). 定义 make 命令行变量进行传递

  1. 注意:
    如果 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

相关文章
|
6月前
|
C语言
Makefile模式规则与自动变量
Makefile模式规则与自动变量
48 0
|
存储 Shell 编译器
makefile 变量赋值方式
makefile 变量赋值方式
98 1
|
存储 Cloud Native Linux
CMake学习之内部变量
CMake学习之内部变量
|
6月前
|
算法 开发者
【Makefile 相关 】Makefile中patsubst(扩展通配符)的含义
【Makefile 相关 】Makefile中patsubst(扩展通配符)的含义
153 0
|
6月前
|
编译器 Linux C语言
预处理详解(#和##运算符、命名约定、#undef​​、命令行定义​、条件编译、头文件的包含​)
预处理详解(#和##运算符、命名约定、#undef​​、命令行定义​、条件编译、头文件的包含​)
makefile 变量的替换,嵌套引用,命令行变量
makefile 变量的替换,嵌套引用,命令行变量
109 1
玩转Makefile | 编译有共用文件的多个程序
玩转Makefile | 编译有共用文件的多个程序
289 0
玩转Makefile | 编译有共用文件的多个程序