我想我不需要问这个,但我没有任何进展。
这个问题的解决方案: How are maven scopes mapped to ivy configurations by ivy实际上解决了问题,但在其理论部分。
我有这个配置:
<conf name="compile" description="???" />
<conf name="runtime" description="???" extends="compile" />
<conf name="test" description="???" extends="runtime" />
<conf name="provided" description="???" />
假设我有这种依赖:
<dependency org="org.apache.tomcat" name="servlet-api" rev="6.0.16" transitive="false" />
我想要的是:当我调用常春藤:在捆绑它之前检索将库复制到.war lib目录,我只想复制所有运行时(并隐式编译)但没有servlet-api。
那么如何使用常春藤:然后检索?
<ivy:retrieve conf="WHAT_TO_PUT_HERE" />
以及如何配置依赖项:
<dependency conf="WHAT_IS_THE_CONF_MAPPING" org="org.apache.tomcat" name="servlet-api" rev="6.0.16" transitive="false" />
我在这里稳定,所以请任何帮助将不胜感激。
知道servlet-api的ivy.xml使用
定义工件conf="master"
所以我认为问题是如何“真正”将提供的maven范围映射到提供的IVY配置。
答案 0 :(得分:6)
这是将依赖关系映射到本地“提供”配置的方法:
<dependency org="org.apache.tomcat" name="servlet-api" rev="6.0.16" conf="provided->master"/>
配置映射的工作原理如下:
provided->master
^ ^
| |
Local Remote
config config
如答案中所解释的,特殊的“主”配置仅包含此模块本身发布的工件,没有传递依赖:
这意味着不需要“transitive = false”属性。
您如何使用配置取决于您。第一个选项更简单,但我更喜欢第二种方法,因为我的配置报告与我的类路径内容相匹配
您可以按如下方式创建单个类路径:
<ivy:cachepath pathid="compile.path" conf="compile,provided"/>
然后可以在javac任务中使用它,如下所示:
<javac ... classpathref="compile.path">
..
或者我更喜欢在配置和类路径之间进行一对一的映射:
<ivy:cachepath pathid="compile.path" conf="compile"/>
<ivy:cachepath pathid="provide.path" conf="provided"/>
后一种方法的问题是javac任务需要明确说明类路径用法如下:
<javac ...
<classpath>
<path refid="compile.path"/>
<path refid="provided.path"/>
</classpath>
我认为这明确地解释了你如何使用这个特殊的提供范围,但这完全取决于你。