Makefile 中的 override 指示符

GUN Makefile Manual Chapter6.7

override 指示符

通常在执行 make 时,如果通过命令行定义了一个变量(例如 make V=s),那么它将替代在 Makefile 中出现的同名变量的定义。

就是说,对于一个在 Makefile 中使用常规方式(使用“=”、“:=”或者“define”)定义的变量,我们可以在执行 make 时通过命令行方式重新指定这个变量的值,命令行指定的值将替代出现在 Makefile 中此变量的值。

如果不希望命令行指定的变量值替代在 Makefile 中的变量定义,那么我们需要在 Makefile 中使用指示符“override”来对这个变量进行声明,像下边那样:

override VARIABLE = VALUE 或者:

override VARIABLE := VALUE

也可以对变量使用追加方式:

override VARIABLE += MORE TEXT

对于追加方式需要说明的是:变量在定义时使用了override,则后续对它值进行追加时,也需要使用带有override指示符的追加方式。否则对此变量值的追加不会生效。

指示符 override 并不是用来调整 Makefile 和执行时命令参数的冲突,其存在的目的是为了使用户可以改变或者追加那些使用 make 的命令行指定的变量的定义。从另外一个角度来说,就是实现了在 Makefile 中增加或者修改命令行参数的一种机制。

我们可能会有这样的需求;可以通过命令行来指定一些附加的编译参数,对一些通用的参数或者必需的编译参数在 Makefile 中指定,而在命令行中指定一些特殊的参数。对于这种需求,我们就需要使用指示符override来实现。例如:无论命令行指定那些编译参数,编译时必须打开-g选项,那么在 Makefile 中编译选项CFLAGS应该这样定义:
override CFLAGS += -g
这样,在执行 make 时无论在命令行中指定了那些编译选项(指定CFLAGS的值),编译时-g参数始终存在。同样,使用define定义变量时同样也可以使用override进行声明。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值