我有一个像下面这样的makefile:
m1:
@echo building m1
m1_:
@echo building m1_
m2:
@echo building m2
m2_:
@echo building m2_
m3_DEPS = m2 m1
SUBSTITUTE=$(patsubst %,%_,$($@_DEPS))
.SECONDEXPANSION:
#%: $$(SUBSTITUTE)
%: $$(patsubst \%,\%_,$$($$@_DEPS))
@echo Building $@
@echo Dependencies are $^
关键是
%: $$(patsubst \%,\%_,$$($$@_DEPS))
我正在使用模式规则和patsubst,它本身使用百分号。我以为我可以逃脱 %
与...的性格 \
,但我仍然没有得到预期的行为。运行“make m3”给出输出
building m2
building m1
Building m3
Dependencies are m2 m1
但是,我希望得到
building m2_
building m1_
Building m3
Dependencies are m2_ m1_
评论那条线和呼叫 patsubst
通过变量间接确实产生了那个输出。
SUBSTITUTE=$(patsubst %,%_,$($@_DEPS))
%: $$(SUBSTITUTE)
此外,我已经测试过使用非模式规则有效,这让我觉得它与模式规则和百分号的交互有关:
m3: $$(patsubst %,%_,$$($$@_DEPS))