4

我有一个现有的 Ant 项目,并希望通过避免重新构建已经是最新的组件来加快构建过程。

Ant 允许您指定一个目标依赖于另一个目标,但默认情况下,每个先决条件都会重新构建,即使它已经是最新的。(这是 Ant 和 make 之间的关键区别。默认情况下,make 仅在需要时重新构建目标 - 即,如果某些先决条件更新。)

<uptodate property="mytarget.uptodate">  // in set.mytarget.uptodate task
  ...
</uptodate>
<!-- The prerequisites are executed before the "unless" is checked. -->
<target name="mytarget" depends="set.mytarget.uptodate" unless="mytarget.uptodate">
  ...
</target>

为了使 Ant 仅在必要时重新构建先决条件,Ant 中似乎有两种通用方法。

第一种方法是使用uptodate任务来设置属性。然后,您的任务可以测试该属性并仅在(未)设置该属性时进行构建。

<uptodate property="mytarget.uptodate">  // in set.mytarget.uptodate task
  ...
</uptodate>
<!-- The prerequisites are executed before the "unless" is checked. -->
<target name="mytarget" depends="set.mytarget.uptodate" unless="mytarget.uptodate">
  ...
</target>

另一种方法是使用outofdate来自 ant contrib 的任务。更好的是,它只是一个目标,没有定义单独的属性;相比之下,outofdate 需要单独的目标来设置和测试属性。

第二种方法是<fileset>使用<modified> 选择器创建一个。它计算文件的 MD5 哈希值并选择 MD5 与之前存储的值不同的文件。它是可选的设置

 <param name="cache.cachefile"     value="cache.properties"/>

在选择器内;它默认为“cache.properties”。这是一个将所有文件从 src 复制到内容已更改的 dest 的示例:

    <copy todir="dest">
        <fileset dir="src">
            <modified/>
        </fileset>
    </copy>

这些都不是很令人满意,因为它需要我为应该是自动的进程(避免重新构建)编写 Ant 代码。

还有 Ivy,但我无法从它的文档中判断它是否提供此功能。Ivy 文档中的关键用例似乎是从 Internet 下载子项目,而不是通过暂存单个项目的各个部分来避免浪费工作。Maven 提供了类似的功能,在其文档中突出显示了相同的用例。(将现有的 non-trivila 项目迁移到 Maven 据说是一场噩梦;相比之下,使用 Maven 开始新开发项目更容易接受。)

有没有更好的办法?

4

1 回答 1

1

这种大型构建的条件编译是我最初在ANT中错过的make的一个特性。我建议不要使用目标依赖项,而是将您的大型项目分成更小的模块,每个模块都发布到一个公共共享存储库。

然后可以使用 Ivy 来控制项目主模块使用的组件版本。

<ivy-module version="2.0">
    <info organisation="com.myspotontheweb" module="multi_module_project"/>
    <publications>
        <artifact name="main" type="jar"/>
    </publications>
    <dependencies>
        <dependency org="com.myspotontheweb" name="component1" rev="latest.integration"/>
        <dependency org="com.myspotontheweb" name="component2" rev="latest.integration"/>
        <dependency org="com.myspotontheweb" name="component3" rev="latest.integration"/>
        <dependency org="com.myspotontheweb" name="component4" rev="latest.integration"/>
    </dependencies>
</ivy-module>

ivy:retrieve任务只会下载/复制其中一个已更改的子模块(从其构建文件中发布)

这一切听起来更复杂,但也许您已经在构建文件中细分了项目......例如,如果您的 ANT更新任务依赖于构建工件之一。

于 2010-01-27T20:43:09.143 回答