带有可选依赖项的 Makefile

aus*_*ton 5 dependencies makefile optional

我有一些 .c 和 .h 文件,它们是由基于一个 XML 文件和可选的另一个 XML 文件的脚本生成的。

从我读过的内容来看,我应该能够使用通配符,例如:

%Generated.c %Generated.h : %Compulsory.xml $(wildcard %Optional.xml)
   generation-script $< $*
Run Code Online (Sandbox Code Playgroud)

当我更改 XXXCompulsory.xml 而不是当我更改 XXXOptional.xml 时,文件 XXXGenerated.c/h 正在重新生成。有谁知道为什么?

我可以解决重复规则的问题,如下所示:

%Generated.c %Generated.h : %Compulsory.xml
   generation-script $< $*

%Generated.c %Generated.h : %Compulsory.xml %Optional.xml
   generation-script $< $*
Run Code Online (Sandbox Code Playgroud)

但我会认为有更好的方法来指定可选依赖项?

谢谢!

注意:之前已经问过同样的问题(例如,如何管理 C 头文件依赖项?)但在这种情况下,我不能让编译器生成 .d 文件。

编辑: Optional.xml 的位置很好,因为如果我只指定规则,它就可以工作:

%Generated.c %Generated.h : %Compulsory.xml %Optional.xml
   generation-script $< $*
Run Code Online (Sandbox Code Playgroud)

并尝试仅针对 Optional.xml 存在的目标进行编译。

但我注意到这不适用于括号:

%Generated.c %Generated.h : %Compulsory.xml $(%Optional.xml)
   generation-script $< $*
Run Code Online (Sandbox Code Playgroud)

小智 0

当您使用函数通配符时,通配符是 *,而不是 %

($通配符*Optional.xml)