通过向您展示一些代码来解释我的问题要容易得多。
这里是:
FILES = $(F1)
A.FILES = $(FILES)
FILES = $(F2)
B.FILES = $(FILES)
F1 := file1
F2 := file2
all: a b
a: $(A.FILES)
echo $^
b: $(B.FILES)
echo $^
$(F1) $(F2):
echo $@
问题是调用make a
打印file2,而不是file1。如何保持使用名为FILES的变量指定A.FILES?
我知道,:=可以完成工作,但是以后可能会定义F1。
我想拥有一些可以满足以下条件的东西:
FILES = $(F1)
A.FILES <- FILES (assignation) such that A.FILES = $(F1)
谢谢!
答案 0 :(得分:1)
没有直接的方法可以做到这一点。您可以做一些棘手的事情来使其正常工作,例如:
F = $(F1)
A := $(value F)
F= $(F2)
B := $(value F)
F1 = foo
F2 = bar
$(eval A := $(A))
$(eval B := $(B))
all: ; @echo 'A=$(A) B=$(B)'
但是没有别的办法了。
ETA
实际上alain提供了更好的解决方案:
F = $(F1)
$(eval A = $(value F))
F= $(F2)
$(eval B = $(value F))
F1 = foo
F2 = bar
all: ; @echo 'A=$(A) B=$(B)'