Maven - 如何处理生成的类
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Maven - 如何处理生成的类相关的知识,希望对你有一定的参考价值。
我的困境是我对maven中生成的源文件有疑问。
我正在尝试从WSDL生成一些类,我真的不知道处理生成的源文件的标准方法是什么。
- 我应该在哪里生成.java源文件? (src / main / java,src / main / generated)
- 我应该将它们包含在源代码管理下,还是在签出后生成它们
- 如果我不使用src / main / java文件夹,如何说服Eclipse自动“看到”那些类作为源文件夹?
- 我真的需要.java文件,还是只需要.class-es?
有关此问题的最佳做法是什么?任何帮助或建议表示赞赏。
谢谢你的回答,马克
我遇到的大多数生成代码的Maven插件遵循将生成的Java源文件放在target/generated-sources
文件夹的子目录中的约定。例如,Maven 2 JAXB 2.x Plugin在target/generated-sources/xjc
文件夹中生成Java源代码。
只要构建是可重复的,我就不需要将生成的源提交到我的源代码存储库。因此,我通常配置我的Git,Mercurial,SVN或我用来忽略target
下的所有内容。
我通常手动编辑.classpath
文件以包含Eclipse的源文件夹,并将.classpath
和.project
文件存储在源代码存储库中。
这是一个例子:
<?xml version="1.0" encoding="UTF-8"?>
<classpath>
<classpathentry excluding="**" kind="src" output="target/classes" path="src/main/resources"/>
<classpathentry kind="src" path="target/generated-sources/xjc"/>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/>
<classpathentry kind="con" path="org.maven.ide.eclipse.MAVEN2_CLASSPATH_CONTAINER"/>
<classpathentry kind="output" path="target/classes"/>
</classpath>
重要的是要注意一些Maven插件不会将生成的源附加到POM。你可以用Build Helper Maven Plugin来解决这个问题。
我从来没有找到一种标准的方法来处理生成的源文件。但是,根据我的经验,我会向您推荐以下内容:
- 我应该在哪里生成.java源文件? (src / main / java,src / main / generated)
- 我把它们放在src / main / com / mypackage / generated下。这样,它们已经在类路径中,您将不需要任何其他手动配置来使Eclipse编译没有错误。
- 我应该将它们包含在源代码管理下,还是在签出后生成它们
- 我曾经不包括它们,但是在遇到一些问题后(开发人员因为忘记了而没有生成它们,缺少IDE Maven插件等),我们最终将它们添加到源代码控制中。这有助于任何人知道有一个生成的源包没有神奇地出现,只需浏览一个文件夹(一些源文件不再存在,等等)快速检查模式更改,并查看应用程序的实际大小。
- 如果我不使用src / main / java文件夹,如何说服Eclipse自动“看到”那些类作为源文件夹?
- 通过使用src / main / com / mypackage / generated解决。
- 我真的需要.java文件,还是只需要.class-es?
- 我建议使用.java文件。
在使用JAXB多年后,仅仅是我的两分钱,主要用于WSDL到Java的生成。
这是我多年后的建议:将所有代码生成放在一个单独的maven项目中,并在需要生成代码的正常项目中依赖它。
- 如果它是SNAPSHOT,请为生成的代码执行
mvn install
。 - 除非你知道自己在做什么,否则我不建议将生成的代码放在子模块中,否则Eclipse会不断混淆,因为大多数人都会导入所有子模块(即多模块项目)
- 但是,如果您决定执行多模块(即生成的代码是兄弟项目),您可以:
特别是不要将项目导入Eclipse并在单个项目中使用
mvn install
依赖于m2e生命周期插件和Build Helper插件(这仅适用于受到大力支持的某些代码生成)。 - 如果您需要调试生成的代码,我强烈建议使用maven-attach-sources插件将源附加到jar。
虽然多模块方法在实践中似乎是一个好主意但它变得非常令人烦恼,因为如果有新的SNAPSHOT,每次拉动时Eclipse都会失去同步。
如果生成的代码没有生成,那么通常只是释放它,因此它不是SNAPSHOT(显然这需要设置正确的maven存储库)。
以上是关于Maven - 如何处理生成的类的主要内容,如果未能解决你的问题,请参考以下文章