如何在隐式生成文件规则中排除一些文件?

时间:2018-09-29 01:59:32

标签: makefile gnu-make

我正在构建几个“主”文件,目前具有以下隐式规则:

$(PROJECT_ROOT)build/%.bin: $(PROJECT_ROOT)obj/%.o $(DEPS)
    @mkdir -p $(dir $@)
    @g++ -o $@ $^

现在,我需要对某些“主”文件有特殊的链接说明。我将异常定义如下:

SPECIAL_TARGET_1 = $(PROJECT_ROOT)build/...
SPECIAL_TARGET_2 = $(PROJECT_ROOT)build/...
SPECIAL_TARGETS = $(SPECIAL_TARGET_1) $(SPECIAL_TARGET_2)

并尝试将其过滤如下:

$(filter-out $(SPECIAL_TARGETS), $(PROJECT_ROOT)build/%.bin): $(PROJECT_ROOT)obj/%.o $(DEPS)
    @mkdir -p $(dir $@)
    @g++ -o $@ $^

但是filter-out没有过滤任何内容。

从隐式规则中排除几个文件的正确方法是什么?

1 个答案:

答案 0 :(得分:1)

filter-out函数用于从列表中删除内容。但是您没有列表:您只有一个文本字符串$(PROJECT_ROOT)build/%.bin

如果要添加新规则:

$(SPECIAL_TARGETS):
    @echo TODO I need to write some special linking instructions for $@

然后,此特定规则将覆盖通用模式匹配规则。