发现一个规律,凡是在上一级Makefile中这样执行:make -C xxx CFLAGS="$(CFLAGS)"
,那么在 xxx/Makefile 中对 CFLAGS
的设置就会不生效。
做个实验
Makefile 的内容:
CFLAGS=-I../xxx
all:
@echo ---top:CFLAGS=$(CFLAGS)---
make -C sub CFLAGS="$(CFLAGS)"
sub/Makefile 的内容:
CFLAGS+=-L/usr/include
all:
@echo ---sub:CFLAGS=$(CFLAGS)---
我们在 sub/Makefile 中让 CFLAGS
追加了 -L/usr/include
按理解,sub/Makefile 的输出结果应该是:-I../xxx -L/usr/include
,而实现输出的内容是 -I../xxx
证明 sub/Makefile 中 CFLAGS+=-L/usr/include
根本就没有生效。
规避方法
那应该怎么办呢? 尝试过了,将 Makefile 改成这样:
CFLAGS=-I../xxx
export CFLAGS
all:
@echo ---top:CFLAGS=$(CFLAGS)---
make -C sub
用 export 关键字来向下传 CFLAGS 变量就可以了。
提问
就算是规避了,但这个现象的根本问题是什么?如何解决?