Makefile 中向下传参问题讨论

发现一个规律,凡是在上一级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 变量就可以了。


提问

就算是规避了,但这个现象的根本问题是什么?如何解决?


你可能感兴趣的:(Make,makefile)