makefile:多个自动变量

时间:2019-05-08 14:56:35

标签: makefile gnu-make

假设我有以下内容:

$: make foo-bar

// makefile contents
.PHONY foo-

foo-%:
    echo $*

我想增加灵活性:

# either: 

$: make foo-bar:foobar

# or: 

$: make foo-bar-foobar

// makefile contents, pseudocode

.PHONY foo- foo-?-?

foo-%:
    echo $*

foo-%1-%2:
    echo $*1 $*2

需要注意的是,我已经看到大型的,自动生成的makefile,它们已经成功实现了复杂的接口,例如:

make foo:bar:baz

理想情况下,可以实现逻辑符号:

make foo::bar:baz

# but I understand that this may be reaching.

现代gnu make可以做到吗?我不担心较旧的版本。优点是简洁明了,因为有些冗长的解决方法。

1 个答案:

答案 0 :(得分:1)

如果每个细分的可能性都有限,则一种选择是执行以下操作:

 targs := $(foreach v1,foo foo1 foo2,\
        $(foreach v2,bar bar1 bar2,\
          $(foreach v3,foobar1 foobar2 foobar3, \
            $(v1)-$(v2)-$(v3))))

$(targs) :
    @IFS=- read v1 v2 v3 <<< $@; \
    echo $$v1 $$v2 $$v3

否则,如果第一段始终为foo-,则可以执行以下操作:

 foo-% :
       IFS=- read v1 v2 v3 <<< $@; \
       echo $$v1 $$v2 $$v3

除此之外,您可能需要创建脚本以将目标手动拆分为多个部分,并且如果您想将这些部分用作单独的目标,则有可能调用子make。