【发布时间】:2013-09-11 02:01:09
【问题描述】:
试图找到一种优雅的方法来解决一些复杂的依赖关系。我的 Makefile 中有如下内容:
.PHONY: FOO
FOO: foo
foo:
build foo
.PHONY: BAR
BAR: bar
bar: FOO
build bar
这里的想法是我想用虚假目标(FOO BAR)抽象真实文件(foo,bar)。当然,在我真正的 Makefile 中,它更复杂,这就是抽象很重要的原因。但是,这里的问题是通过使伪目标 FOO 成为 bar 的依赖项,然后 Make 总是尝试重建 bar,即使 foo 和 bar 都是最新的。这显然是因为它总是将 FOO 视为过时的。但这种行为并不真正正确。
看来我只有 3 个选项: 1) 使 bar 直接依赖于 foo。在我真正的 Makefile 中,它更加复杂,并且尝试将真实文件指定为依赖项是非常不可取的。 2)除了所有的虚假之外,还使用变量。这使得整个 Makefile 更加复杂。 3) 从 bar 中删除 foo/Foo 作为依赖项,并在 bar 中添加 FOO 的递归 make 作为规则的一部分。这是非常糟糕的形式。
是否有一些我不知道的更优雅的解决方案?
谢谢。
【问题讨论】:
-
我不确定我明白你为什么要进行这种抽象。
make最好的部分之一是它如何很好地处理真实目标和时间戳。 -
除非你能更清楚地解释为什么你要求目标是假的,否则我看不出我们能提供什么帮助。你想通过把它做成 PHONY 来达到什么目的?如果您不使用 PHONY,什么会中断或无法正常工作? PHONY 的全部意义在于确保与目标关联的配方始终运行,因此这种行为“不是真正正确”的想法是......不是真的正确:-)
-
文件名很复杂(子目录、长名称等)。在所有规则中直接使用文件名会使事情变得相当不可读。从最终用户的角度来看,由于这种复杂性,在命令行上输入目标变得不切实际。我可以选择用变量完全替换 PHONY 目标——我想——这将简化 Makefile,但“make”命令行仍然存在同样的问题(即用户必须指定的目标很复杂) .
标签: makefile dependencies