2011-09-01 73 views
2

我刚开始使用Ivy,而且我非常挣扎,因为我发现Apache网站上的文档和教程非常混乱,并且与如何不相关我想用它。如何使用Ant将不同名称的罐子发布到常春藤

我想用Ant发布一些jar文件到本地的Ivy仓库。 Ant脚本创建四个jar文件:

  • 沉渣 - WS-client.jar中
  • 沉渣 - WS-客户src.jar
  • 沉渣 - enums.jar
  • 沉渣 - 枚举-SRC。罐子

这些罐子应该在常春藤库(如sed-ws-client目录和sed-enums目录)两个不同的目录中结束。版本库目前在相应的目录中包含这些jar的0.0.1和0.0.2版本,以及相应的ivy- [version] .xml文件(这是手动完成的)。

我在计算如何构建“发布”Ant目标和项目的ivy.xml文件时遇到了很多麻烦。我不得不在ivy.xml文件的info标记中放置一个模块名称,但这意味着我只能将jar发布到Ivy存储库中的一个目录中?

我试过各种东西,但Ant构建总是失败。我只想简单说明我需要采取哪些步骤才能使其工作。如果需要,可以更改存储库结构。

这是我到目前为止有:

ivy.xml文件:

<ivy-module version="1.0"> 
<info organisation="myorg" module="SED" revision="1.0" status="dev"></info> 

<publications> 
    <!-- ws-client --> 
    <artifact name="sed-ws-client"/> 
    <artifact name="sed-ws-client" type="src"/> 

    <!-- generated --> 
    <artifact name="sed-enums"/> 
    <artifact name="sed-enums" type="src"/> 

</publications> 

</ivy-module> 

Ant目标:

<target name="ivy-publish" description="Produce the ivy.xml file for the built jars"> 
    <ivy:settings file="d:/temp/ivy/ivysettings.xml" /> 
    <ivy:retrieve /> 
    <ivy:publish organisation="myorg" resolver="default" pubrevision="0.0.2" update="true"> 
     <artifacts pattern="${DEPLOY_DIR}/${sed.ws.client.jar}-[type].[ext]" /> 
     <artifacts pattern="${DEPLOY_DIR}/${sed.enums.jar}-[type].[ext]" /> 
    </ivy:publish> 
</target> 

回答

5

我解决了这个2个ivy文件,因为我的项目发布2模块。每个模块都需要自己的ivy.xml。 这是我的第二个模块的目标,它有自己的ivy文件(ivy-SI.xml)。

<target name="ivy-publish-si"> 
    <ivy:settings file="${basedir}/../KS.build/ivysettings.xml" /> 
    <!--resolve ist need for publish --> 
    <ivy:resolve 
     file="ivy-SI.xml" 
     revision="${project.version}" 
     conf="compile" 
    /> 
    <ivy:publish 
     srcivypattern="ivy-si.xml" 
     resolver="jars.local" 
     conf="compile" 
     overwrite="true" 
     revision="${project.version}"> 
     <artifacts pattern="dist/[artifact]-[revision].[type]" /> 
    </ivy:publish> 

常春藤SI.xml是非常标准:

<?xml version="1.0" encoding="UTF-8"?> 
<ivy-module version="2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="http://ant.apache.org/ivy/schemas/ivy.xsd"> 
<info organisation="readybank" 
    module="KS.SessionInterface" 
    revision="${project.version}" 
    status="integration"/> 
<configurations> 

    <conf name="compile" visibility="public"/> 
    <conf name="run" visibility="public"/> 
    <conf name="deploy" visibility="public"/> 
</configurations> 
<publications> 
    <artifact name="KS.SessionInterface" type="jar" conf="compile" ext="jar"/> 
</publications> 
<dependencies> 
</dependencies> 

</ivy-module> 
3

这是无关紧要如何存储在仓库的文物。常春藤通过模块和工件名称寻找工件。 通常你应该将一个项目视为一个常春藤模块。如果您的项目生成两个模块,则将该项目分成两部分的更好方法。模块是一起改变的逻辑上一致的一组工件

构建失败,因为发布任务找不到要发布的构件。

例如,在此发布任务:

<ivy:publish resolver="${ivy.repository}" update="true" overwrite="true"> 
    <artifacts pattern="${artifacts.dir}/[artifact].[ext]"/> 
</ivy:publish> 

我们告诉艾维从$ {} artifacts.dir文件夹中的ivy.xml描述采取用名和扩展名文物和发布。 和常春藤。XML在这种情况下是这样的:

<ivy-module version="2.0"> 
<info organisation="apache" module="commons-cli" revision="1.2" status="release"/> 
<configurations> 
    <conf name="binary" description="provide only binary files"/> 
    <conf name="development" extends="binary" description="provide binary files with javadoc and sources"/> 
</configurations> 
<publications> 
    <artifact name="commons-cli" ext="jar" conf="binary" type="jar"/> 
    <artifact name="commons-cli-javadoc" ext="jar" conf="development" type="javadoc"/> 
    <artifact name="commons-cli-sources" ext="jar" conf="development" type="source"/> 
</publications> 

相关问题