好的,这是我的建议。首先,这是一个用 bash 制作的快速生成器,它可以接受一个“--list”参数,该参数创建一个 omake 变量来包含要做的事情的列表。生成器称为“generator.txt”,因为我们将通过将其重命名为 .sh 来“制作”它。
#!/bin/bash
if [ "$1" = "--list" ]; then
echo -e 'FILES[] = \n\ta\n\tb\n\tc'
else
echo 1 > a.dot
echo 2 > b.dot
echo 3 > c.dot
fi
然后,OMakefile 本身:
.INCLUDE: rules : generator.txt
cp generator.txt generator.sh
chmod 755 generator.sh
./generator.sh
./generator.sh --list > rules
DOTS[] =
$(addsuffix .dot, $(FILES))
SVGS[] =
$(addsuffix .svg, $(FILES))
# rule to turn a .dot into a .svg
%.svg: %.dot
cp $*.dot $*.svg
.DEFAULT: $(SVGS)
.PHONY: clean
clean:
rm -f generator.sh a.* b.* c.* rules
这里的诀窍是从 generator.txt 生成“规则”文件,以包含在 OMakefile 中。每当 generator.txt(我们的生成器的源代码)更改时,我们重新创建(构建)生成器,运行它(创建文件 a.dot、b.dot、c.dot),最后使用 --list 运行它以生成我们的FILE[] 变量包含要生成的文件列表。
然后,生成 DOTS 和 SVGS 变量以及将点转换为 svg 的规则变得微不足道。默认目标取决于 svg 列表,它将按顺序构建所有内容。
这种方法的问题是构建生成器非常粗糙,因为我们必须将“包含”依赖项列表作为真实文件。尽管如此,这至少应该以正确的顺序执行操作。
请注意修改 generator.txt(例如,添加另一个要生成的 .dot,或更改 .dot 内容的生成方式)如何正确强制重新生成 generator.sh,然后重新生成任何生成的文件被修改。
编辑
我认为主要问题是 omake 期望能够在开始做任何工作之前生成整个依赖关系图。因此,它不能处理某些依赖项来构建生成器,然后生成更多依赖项来处理其输出。
我想有一些方法可以解决:
第一个是将生成器构建为 .INCLUDE 指令的一部分,正如我首先描述的那样,这很麻烦,因为您必须将所有生成器构建过程放入该指令中。
第二个是失去一些灵活性,并处理一个输入到一个输出,例如让生成器只生成一个包含所有连接输入的文件。如您所知,您将只有一个文件,您可以轻松设置依赖项。
第三个,我最喜欢的,是有一个两阶段构建系统。在子目录中,您有一个生成生成器并输出文件的 OMakefile。在另一个子目录中,您有另一个 OMakefile,它读取第一个目录的内容以生成要处理的文件列表,然后运行转换。然后,在主目录中,bash 脚本在第一个目录中调用 omake,然后在第二个目录中调用。希望这意味着您可以使用单个命令生成所有内容,而且重建将是最小的:第一个 omake 只会在输入发生更改时重新生成文件,而第二个 omake 只会转换更改的文件或新文件。