Apache Ant&常春藤:生成错误的依赖项

时间:2011-02-10 12:22:18

标签: ant ivy

我正在为我的项目编写一个Java库:我使用Ivy进行依赖项管理,并将JAR发布到我的本地存储库。

当我更新ivy.xml(即添加新的外部库)时,一切正常:检索并使用所有工件。

但是,当我发布我的库时,Ivy生成的ivy-module xml包含缺少/错误的引用(通常是以前版本的外部库)。

这是我在build.xml中的目标:

    <target name="publish" depends="jar" description="Publish this project in the ivy repository">
    <property name="revision" value="${version}" />
    <ivy:publish artifactspattern="${jar.dir}/[artifact].[ext]" resolver="projects" pubrevision="${revision}" status="release" update="true" overwrite="true" />
    <echo message="project ${ant.project.name} released with version ${revision}" />
</target>

这是我的ivy.xml:

<ivy-module version="2.0">
<info organisation="xyz" module="zyx"/>
<configurations defaultconfmapping="*->*,!javadoc,!sources" />
<dependencies>
    <dependency org="ch.qos.logback" name="logback-classic" rev="0.9.28" /> 
    <dependency org="commons-lang" name="commons-lang" rev="2.5"/>
    <dependency org="commons-io" name="commons-io" rev="2.0"/>
    <dependency org="org.simpleframework" name="simple-xml" rev="2.4.1">
        <exclude module="stax"/>
        <exclude module="stax-api"/>
    </dependency>
    <dependency name="AlmaUtils" rev="1.3.10"/>
    <!-- Reflections -->
    <dependency org="org.reflections" name="reflections" rev="0.9.5-RC2">
        <exclude module="logback-classic"/>
    </dependency>
    <!-- Bouncycastle cryptography -->
    <dependency org="org.bouncycastle" name="bcprov-ext-jdk16" rev="1.45"/>
    <dependency org="jdom" name="jdom" rev="1.1">
        <exclude module="xerces"/>
        <exclude module="xalan"/>
    </dependency>
    <!-- Scripting -->
    <dependency name="js-engine" rev="1.0"/>
    <dependency org="rhino" name="js" rev="1.7R2"/>
    <!-- JGA -->
    <dependency name="jga" rev="0.8.1"/>
</dependencies>

1 个答案:

答案 0 :(得分:2)

也许您应该在构建中添加以下目标。

<target name="clean-all" depends="clean" description="Purge ivy cache">
    <ivy:cleancache/>
</target>

这将擦拭板岩清洁并确保您的构建完全清洁。

Ivy基本上是一个优化的下载程序,但是,当您升级复杂的依赖项树的版本时,有时它会做出不正确的缓存决策。当本地存储库非常大时,Maven构建也会受到此问题的影响。