我正在更新我正在处理的项目的 POM 中不同依赖项和插件的版本。其中一项更新是将 maven-compiler-plugin 从 2.3.2 版本升级到 3.1。执行此操作后,项目中的某些组件现在不再成功构建。给出的唯一错误是:
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project project-name: Compilation failure -> [Help 1]
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project project-name: Compilation failure
当使用 -X 开关运行 maven 时,我们还看到日志中有一大块文本。我们成功地通过 javac 运行了这个文本块,发现问题基本上归结为参数字符串(即命令行选项)太长,OS X 中的 Bash 无法处理。
-bash: /usr/bin/javac: Argument list too long
我也尝试逐渐增加版本号,问题从 maven-compiler-plugin 3.0 版开始。
这是在 POM 中导入插件的方式:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.0</version>
<configuration>
<verbose>true</verbose>
<encoding>UTF-8</encoding>
<source>1.6</source>
<target>1.6</target>
<forceJavacCompilerUse>true</forceJavacCompilerUse>
</configuration>
</plugin>
命令行选项中显然有超过 350k 个字符,OS X 终端无法处理这些字符。OS X 的 ARG_MAX 是 32 kb,而 Linux Ubuntu 似乎支持 256 kb。Linux Ubuntu 使用新版本顺利编译程序,所以对我来说,这基本上证实了我们的怀疑。
因此,我的问题归结为两件事:
1)我们能否让 Maven 给我们一个正确的错误消息,而不是需要通过 javac 手动运行的大量文本?(任何其他错误都按应有的方式进行处理,并显示在正确的错误消息中)。我们尝试了几种设置,但都没有成功。
2)是否有一个修复程序可以a)阻止Maven生成这种大小的参数字符串(显然从2.3.2版本到3.1版本发生了一些事情),或者b)在OS X上增加MAX_ARG?