有没有办法扩展Makefile宏来创建规则?

时间:2018-09-24 17:51:48

标签: gnu-make

在此makefile示例中:

EXTERNAL_TXT_FILES:= a/A.txt a/b/B.txt a/b/c/C.txt

EXTERNAL_TXT_NAMES:= $(notdir $(EXTERNAL_TXT_FILES))

DEST_TXT_FILES:= $(addprefix txt/, $(EXTERNAL_TXT_NAMES))

.PHONY:all
all: $(DEST_TXT_FILES)

$(DEST_TXT_FILES):
    cp $< $@

txt/A.txt: a/A.txt
txt/B.txt: a/b/B.txt
txt/C.txt: a/b/c/C.txt

可以看到最后三行是公式化的。

是否可以重写此Makefile,以便DEST_TXT_FILES的固定目标元素可以依赖于其派生自EXTERNAL_TXT_FILES的元素,而不必明确写出来吗?

用于测试:

$ mkdir -p a/b/c txt && rm -f txt/* && touch a/A.txt a/b/B.txt a/b/c/C.txt && make

我希望将makefile的最后三行替换成这样:

foreach (FILE, $(EXTERNAL_TXT_FILES), $(addprefix txt/, $(notdir $(FILE))) : $(FILE))

1 个答案:

答案 0 :(得分:0)

重复项:How can I use macros to generate multiple Makefile targets/rules inside foreach? Mysterious behaviour

我的解决方案:

EXTERNAL_TXT_FILES:= a/A.txt a/b/B.txt a/b/c/C.txt

EXTERNAL_TXT_NAMES:= $(notdir $(EXTERNAL_TXT_FILES))

DEST_TXT_FILES:= $(addprefix txt/, $(EXTERNAL_TXT_NAMES))

.PHONY:all
all: $(DEST_TXT_FILES)

define DUMMY_RULE
$(addprefix txt/, $(notdir $(1))): $(1)
endef

$(foreach FILE, $(EXTERNAL_TXT_FILES), $(eval $(call DUMMY_RULE, $(FILE))))

$(DEST_TXT_FILES):
    cp $< $@