以下常春藤设置文件:
<ivysettings>
<settings defaultResolver="central"/>
<resolvers>
<ibiblio name="central" m2compatible="true"/>
<url name="my-repo">
<artifact pattern="http://myserver/myrepo/[organisation]/[artifact]/[revision]/[artifact].[ext]"/>
</url>
</resolvers>
<modules>
<module organisation="org.mycompany" resolver="my-repo"/>
</modules>
</ivysettings>
默认配置为从 Maven Central 检索工件,并从 HTTP 服务器检索本地工件。
更新
常春藤.xml
ivy 文件中没有什么特别之处。只需声明依赖项以及将它们关联到哪个配置:
<configurations>
<conf name="compile" description="Required to compile application"/>
</configurations>
<dependencies>
<!-- compile dependencies -->
<dependency org="org.slf4j" name="slf4j-api" rev="1.6.4" conf="compile->default"/>
<dependency org="org.mycompany" name="my-module" rev="1.0" conf="compile->default"/>
</dependencies>
笔记:
构建.xml
<target name="resolve" dependencies="Resolve build dependencies">
<ivy:resolve/>
<ivy:report todir='build/reports' graph='false' xml='false'/>
<ivy:cachepath pathid="compile.path" conf="compile"/>
..
</target>
笔记:
- ivycachepath 任务将 ivy 配置转换为填充的 ANT 类路径。很有用。
- ivy 报告任务告诉你类路径上的 jars
常春藤解析构建输出
所有的魔法都在设置文件中。运行构建会产生以下结果:
[ivy:resolve] found org.slf4j#slf4j-api;1.6.4 in central
[ivy:resolve] found org.mycompany#my-module;1.0 in my-repo
..
[ivy:resolve] downloading http://repo1.maven.org/maven2/org/slf4j/slf4j-api/1.6.4/slf4j-api-1.6.4.jar ...
..
[ivy:resolve] downloading http://myserver/myrepo/org.mycompany/my-module/1.0/my-module.jar ...
笔记:
- my-repo解析器用于具有“org.mycompany” groupId 的模块。
- 其他一切都来自默认解析器 Maven Central。