【问题标题】:"Null" versus "empty" arguments in MavenMaven 中的“空”与“空”参数
【发布时间】:2011-10-14 20:20:09
【问题描述】:

为什么 Maven 坚持将空字符串和空格字符串处理为“空值”?采取以下 pom - 我收到关于错误配置参数的常见虚假消息。我如何安排传递一个 Maven 将实际识别的空值,而不是用荒谬的错误消息折磨我?

[ERROR] BUILD ERROR
[INFO] ------------------------------------------------------------------------
[INFO] Misconfigured argument, value is null. Set the argument to an empty value if this is the required behaviour.

pom.xml:

<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.test</groupId>
    <artifactId>test</artifactId>
    <packaging>pom</packaging>
    <version>0</version>
    <name>test</name>
    <url>http://maven.apache.org</url>
    <properties>
        <my.val>             </my.val>
    </properties>
    <build>
        <plugins>
            <plugin>
                <groupId>org.codehaus.mojo</groupId>
                <artifactId>exec-maven-plugin</artifactId>
                <version>1.2.1</version>
                <executions>
                    <execution>
                        <id>Exec test</id>
                        <phase>prepare-package</phase>
                        <goals>
                            <goal>exec</goal>
                        </goals>
                        <configuration>
                            <executable>${env.JAVA_HOME}/bin/java</executable>
                            <arguments>
                                <argument>${my.val}</argument>
                            </arguments>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

【问题讨论】:

  • 我不确定我是否遇到过您所指的这种“虚假消息”,这可能表明它并不那么常见。您可能想提供更多细节,而不是假设每个人都知道您在说什么。
  • 我不可能是唯一一个看到“错误配置的参数”消息的人,因为我经常看到它,这要归功于 Maven 充其量是高度特殊的强制方法,但它确实存在。
  • 有趣。这似乎是 exec 插件的一个缺点。您是否检查过/提交了错误/增强报告?
  • @Ryan。看起来这个问题从 2007 年就已经知道了 -> mail-archives.apache.org/mod_mbox/maven-users/200708.mbox/…
  • @Alexander - 这当然令人沮丧。哎呀。

标签: maven


【解决方案1】:

看起来这个问题从 2007 年就已经知道了 -> http://mail-archives.apache.org/mod_mbox/maven-users/200708.mbox/%3C5a2cf1f60708090246l216f156esf46cc1e968b37ccd@mail.gmail.com%3E

在您的情况下,您可以尝试改用&lt;commanlineArgs&gt; 配置参数。

如果你有很多论点,那就不漂亮了,但如果你只有一两个,它可能是一个选择。

<configuration>
  <executable>${env.JAVA_HOME}/bin/java</executable>
  <commandlineArgs>${my.val}</commandlineArgs>
</configuration>

我还在 MEXEC Jira 中创建了一个错误报告:http://jira.codehaus.org/browse/MEXEC-104

更新

要通过&lt;commandlineArgs&gt; 提供类路径,请执行以下操作:

<commandlineArgs>-classpath %classpath my.main.class.MyMainClass ${my.val}</commandlineArgs>

实际上,解析器甚至允许折叠长行以使其更具可读性,例如

<commandlineArgs>
  -classpath %classpath
  my.main.class.MyMainClass
  ${my.val}
</commandlineArgs>

【讨论】:

    【解决方案2】:

    您可以将my_val 设置为一些虚拟系统属性值,例如-Ddummy=dummy。 我知道这并不优雅,但至少是一种解决方法。

    【讨论】:

      猜你喜欢
      • 2018-02-02
      • 2013-03-11
      • 1970-01-01
      • 2021-04-29
      • 2010-12-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多