makefile 变量的扩展

举报
糖果罐子 发表于 2023/07/21 19:49:26 2023/07/21
【摘要】 @TOC 前言 一、环境变量(全局变量)Makefile 中的环境变量,是指在执行 Makefile 时,从外部传入 Make 命令的环境变量。一些常用的 Makefile 环境变量:MAKE:表示当前正在使用的 Make 工具的名称;PWD:表示当前目录的绝对路径;SHELL:表示当前 Shell 的名称。默认是 /bin/sh。可以通过定义 SHELL 变量来指定所使用的 Shell;M...

@TOC

前言


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

  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


总结

下一篇介绍 makefile 中的 条件判断语句

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。