我正在尝试解决我们的 Ant/Ivy 系统中的一些技术债务,我目前的任务之一是解决我们目前的一些检索后行为。默认情况下,我们的构建系统检索 Ivy 依赖项,然后将压缩的工件(tar、tar.bz2、gzip、zip only)提取到依赖项文件夹,以便我们的项目具有一致的依赖项位置:
(project.root)/dependency/.archive <- the compressed dependency location
(project.root)/dependency/extracted-foo` <- the uncompressed dependency
提取发生在post-retrieve-artifact trigger
中,以便我们从一些元数据(路径、名称、类型等,都以"dep"为前缀)中受益。
我们目前有一个属性可以设置为关闭 ivy.xml 文件中指定的所有依赖项的此默认行为。因此,我们只剩下要么全有,要么全无的局面。如果我们想要介于两者之间的东西,我们目前必须使用我们的 build.xml 文件并编写一些自定义代码。这很痛苦,因为元数据不容易获得。
我想保留全有或全无标志的使用,但允许项目有选择地提取项目 - 我们有几个项目,如果我们可以将提取过程降低到工件本身的属性,它们的构建.xml文件将大大简化。
因此,我的想法是在artifact
标签上使用extra
属性来"注入"此信息并覆盖搜索此属性的ivy.retrieve.pattern
。
常春藤.xml
<ivy-module version="2.0" xmlns:e="http://ant.apache.org/ivy/extra">
<dependencies>
<dependency org="my.org" name="foo" rev="${foo.version}" conf="${conf.archive}->*" transitive="false">
<artifact name="megapin" type="war" e:expand="expand"/>
</dependency>
</dependencies>
</ivy-module>
构建.xml
这就是我认为我无法显示expand
额外属性的地方。
问题 1:这确实会在检索时将"extract"属性添加到工件名称。我可以使用contains
子句来检查dep.to
中是否存在 有没有办法检索extra
属性(例如,${dep.extra.expand}
?
<property name="ivy.retrieve.pattern" value="${dependency.dir}/[conf]/[artifact]-[rev])(-[expand]).[ext]"/>
</property>
<target name="ivy-post-retrieve-trigger">
<local name="doexpand"/>
<condition property="doexpand">
<contains string="${dep.to}" substring="expand" casesensitive="false"/>
</condition>
<!-- this step works if the flag is set properly, so I'm leaving out these non-relevant steps-->
<...extract if:isset="doexpand"... />
常春藤设置.xml
此文件基本上具有触发器和其他解析器设置。
<triggers>
<ant-call target="ivy-post-retrieve-trigger" prefix="dep" event="post-retrieve-artifact"/>
</triggers>
问题2:关于"noexpand"名称有什么建议吗?我对<contains>
条款的担忧是,"扩张"将一直受到打击。
我想我已经接近让它工作了 - 但我得到的唯一信息是:Property "doexpand" has not been set
,因此它跳过了提取步骤。第三季度关于如何在 Ant/Ivy 的trigger
上使用extra
属性的任何提示/建议/示例?
我最终向 Ivy 添加了一些额外的调试语句(从源代码编译)。在ant-ivy/src/java/org/apache/ivy/ant/AntCallTrigger.java
中,我添加了以下行:
Message.verbose("tp.name=" + p.getName() + " | p.value=" + p.getValue() );
如果我将Ivy.xml文件中的依赖项修改为:
<dependency org="my.org" name="foo" rev="${foo.version}" conf="${conf.archive}->*" transitive="false">
<artifact name="megapin" type="war" e:expand="true"/>
</dependency>
这显示了
[ivy:retrieve] p.name=dep.expand | p.value=true
在这一点上,我可以做类似的事情
<isset property="dep.expand"/>
或
<istrue value=${dep.expand}/>
这回答了我的Q1。此外,我不需要将其添加到 Ivy 检索模式中(从而在检索后更改文件名),可以根据需要使用"true"或"false"值 (Q2),本一般指南回答了Q3。