5

给定三个 POM 文件:

  • C 依赖于 B。
  • B 继承自 A。
  • 我可以建造 A 和 B
  • C 无法构建,因为它依赖于 B。

完整的源代码和构建输出包含在下面供您查看。

这是A的POM:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.foo</groupId>
    <artifactId>A</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>A</name>
    <repositories>
        <repository>
            <id>foo releases</id>
            <name>libs-releases-local</name>
            <layout>default</layout>
            <url>http://foo.net/artifactory/libs-releases-local</url>
        </repository>
    </repositories>
    <dependencies>
        <dependency>
            <groupId>org.eclipse.swt</groupId>
            <artifactId>swt</artifactId>
            <classifier>${swt.classifier}</classifier>
            <version>3.6.1</version>
        </dependency>
    </dependencies>
    <profiles>
        <profile>
            <id>windows-x86</id>
            <properties>
                <swt.classifier>win32-x86</swt.classifier>
            </properties>
        </profile>
    </profiles>
</project>

这是B的POM:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>com.foo</groupId>
        <artifactId>A</artifactId>
        <version>1.0-SNAPSHOT</version>
        <relativePath>../A</relativePath>
    </parent>
    <artifactId>B</artifactId>
    <packaging>jar</packaging>
    <name>B</name>
    <profiles>
        <profile>
            <id>windows-x86</id>
            <properties>
                <swt.classifier>win32-x86</swt.classifier>
            </properties>
        </profile>
    </profiles>
</project>

这是C的POM:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.foo</groupId>
    <artifactId>C</artifactId>
    <packaging>jar</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>C</name>
    <dependencies>
        <dependency>
            <groupId>${project.groupId}</groupId>
            <artifactId>B</artifactId>
            <version>${project.version}</version>
        </dependency>
    </dependencies>
</project>

这是 C 的构建输出:

------------------------------------------------------------------------
Building C
   task-segment: [install]
------------------------------------------------------------------------
[compiler:compile]
Nothing to compile - all classes are up to date
Downloading: http://foo.net/artifactory/libs-releases-local/org/eclipse/swt/swt/3.6.1/swt-3.6.1-${swt.classifier}.jar
[WARNING] Unable to get resource 'org.eclipse.swt:swt:jar:${swt.classifier}:3.6.1' from repository foo releases (http://foo.net/artifactory/libs-releases-local): Error transferring file: foo.net
Downloading: http://repo1.maven.org/maven2/org/eclipse/swt/swt/3.6.1/swt-3.6.1-${swt.classifier}.jar
Unable to find resource 'org.eclipse.swt:swt:jar:${swt.classifier}:3.6.1' in repository central (http://repo1.maven.org/maven2)
------------------------------------------------------------------------
[ERROR]BUILD ERROR
------------------------------------------------------------------------
Failed to resolve artifact.

Missing:
----------
1) org.eclipse.swt:swt:jar:${swt.classifier}:3.6.1

我知道这个问题与https://issues.apache.org/jira/browse/MNG-3228有关,但我不确定如何解决它。请帮忙!

UPDATE:

Adding a classifier to B helped. Now C builds so long as the repository only contains B's jar file. If I upload B's POM file alongside the JAR in the repository, C fails with the aforementioned error (${swt.classifier} not defined). Any ideas?

4

4 回答 4

2

在您写的评论中,“我期望 SWT 的分类器在 B 的构建时得到解决,而不是 C 的构建时”,但这是错误的 - 您需要在 C 的构建时使用分类器,因为 C 依赖于 swt(传递通过 A)。该依赖项仅由属性完全确定,因此您必须有一种方法来评估 C 的 pom.xml 中的属性。

  • A 取决于 swt-${classifier}
  • C 取决于 A
  • 因此 C 依赖于 swt-${classifier}
  • 因此 C 的 pom 必须定义属性。它可以由配置文件定义(如在 A 中),或在运行时手动定义(不利于再现性),但没有它就无法构建 C。

就这么简单(而且令人费解)。

如果您期望该属性在此过程中以某种方式完全“解决”,并且在您构建 C 时已经很好地定义,那么您不了解 Maven 如何处理这些属性。它让他们独自一人。曾尝试在 Maven 2.1 中做一些不同的事情(当您安装 A 时,分类器属性表达式将转换为它的值),但它没有成功,导致许多令人惊讶的行为,它在 2.2 中恢复,实际上导致2.1 将被迅速弃用。有关更多详细信息以及有关问题真正复杂程度的一些提示,请参阅下面的链接。

https://cwiki.apache.org/confluence/display/MAVENOLD/Artifact-Coordinate+Expression+Transformation

除非 Maven 开发人员做出其他决定,否则我认为我们将继续保留自 2.0 以来一直存在的行为:“工件坐标中的表达式被忽略。用户有很多绳子可以用来吊死自己”

但是,一旦您习惯了它,它就不再令人困惑了。只有当你试图猜测 Maven 时,你才会感到惊讶。

于 2010-12-15T07:04:51.580 回答
1

Maven 正在尝试查找工件 org.eclipse.swt:swt:3.6.1 但坐标未正确解析。错误是说${swt.classifier}没有从<properties/>您的 POM.xml 中的块中识别出来。由于该值显示在一个<profile/>块中,您可以验证您正在运行的 Maven 命令吗?

尝试这个: mvn dependency:resolve -P windows-x86

此外,验证 SWT 的版本和分类器是否确实正确。我在 Maven Central 上看到的最新版本不是 3.6.0,而是3.3.0-v3346

于 2010-11-13T14:09:20.027 回答
1

从 Maven 3.1.0 开始,这是不可能的。这是相关的功能请求:https ://issues.apache.org/jira/browse/MNG-1388

于 2011-01-31T18:06:23.073 回答
0

我知道这个问题与https://issues.apache.org/jira/browse/MNG-3228有关,但我不确定如何解决它。

我不确定是否存在与此问题相关的链接,我在上面显示的 pom.xml 中看不到任何与配置文件激活相关的内容。

实际上,我什至不确定是否理解预期的结果。分类器应该从哪里来?也许我遗漏了一些部分,但我认为您应该安装/部署B 的合格版本(具有完全解析的 POM)并让 C 依赖于这个合格的版本。

我需要如何修改 B 的 POM 才能部署合格的版本?我期望 SWT 的分类器在 B 的构建时得到解决,而不是 C 的构建时。

是的,但是在 C 的构建时,C 需要 B.pomB 的依赖项,因此必须完全解决 B的安装/部署。至少,我认为事情是这样运作的。

但我必须承认,我不确定如何准确处理这种情况,并且在阅读了MNG-4140Artifact-Coordinate Expression Transformation页面等问题后,我完全感到困惑。

我建议以正确的方式将其发布在 maven 用户列表上(我将密切关注该线程,因为我认为我现在使用配置文件、属性和依赖项修复了一些损坏的 POM,谢谢 :)

于 2010-11-13T12:17:27.160 回答