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
进行声明。