Maven、Lombok 和 Eclipse - 有意义的集成模式



所以,我一直想使用龙目岛一段时间 - 我终于开始了一个能够使用它的项目。需要注意的重要一点是,这将是一个大型的企业级应用程序,因此使用的集成模式必须是有意义的,尽可能少地使用黑客攻击。

所以我看了一下龙目岛插件,以及整个delombok软糖。我知道这将复制我的所有代码,并在存在的情况下扩展龙目岛注释。这给了我第二组生成的.java文件,maven 在编译过程中需要使用这些文件。

但是,通过生成这些新的源文件 - eclipse 会拾取它们并尝试将它们拉入我的项目中。因此,它触发了一百万个(好吧,稍微夸张)关于重复类的错误。

一些解决方案建议我更改POM中的<sourceDirectory>。这并没有让事情变得更好,因为mvn eclipse:eclipse现在将从项目中完全省略我的src/main/java java目录 - 只向我显示delombok进程的输出。

然后建议我需要使用一个配置文件来编译/打包项目,另一个配置文件来mvn eclipse:eclipse.这不是一个可接受的解决方案,因为我必须花费足够的时间来维护/解释我已经很复杂的 maven 设置——而不必引入一个全新的配置文件(除了我现有的配置文件)。

我希望能得到一些灵感,使我免于为我的项目写下龙目岛。这是减少样板代码的好工具,但它似乎还没有准备好用于黄金时段的企业使用 - 我觉得非常令人失望:-(

以下是我目前的POM:

<build>
    <sourceDirectory>target/generated-sources/delombok</sourceDirectory>
    <testSourceDirectory>target/generated-test-sources/delombok</testSourceDirectory>
    <plugins>
        <plugin>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>2.3.2</version>
            <configuration>
                <source>1.7</source>
                <target>1.7</target>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok-maven-plugin</artifactId>
            <version>1.12.2.0</version>
            <dependencies>
                <dependency>    
                    <groupId>sun.jdk</groupId>
                    <artifactId>tools</artifactId>
                    <version>1.7</version>
                    <scope>system</scope>
                    <systemPath>${java.home}/../lib/tools.jar</systemPath>
                </dependency>
            </dependencies>
            <executions>
                <execution>
                    <id>delombok</id>
                    <phase>generate-sources</phase>
                    <goals>
                        <goal>delombok</goal>
                    </goals>
                    <configuration>
                        <encoding>UTF-8</encoding>
                        <addOutputDirectory>false</addOutputDirectory>
                        <sourceDirectory>src/main/java</sourceDirectory>
                    </configuration>
                </execution>
                <execution>
                    <id>test-delombok</id>
                    <phase>generate-test-sources</phase>
                    <goals>
                        <goal>testDelombok</goal>
                    </goals>
                    <configuration>
                        <encoding>UTF-8</encoding>
                        <addOutputDirectory>false</addOutputDirectory>
                        <sourceDirectory>src/test/java</sourceDirectory>
                    </configuration>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

目前只是将 delomboked 代码放在我的 eclipse 项目中。


最后说明 - 我也非常沮丧,我必须在我们将要使用的所有 eclipse instasnces 上手动安装 lombok。主要是因为我会接到所有无法让它工作的开发人员的电话。我明白为什么它不像mvn eclipse:eclipse那么简单,但我仍然想指出我的失望。如果我们必须手动设置每个库以在每个开发人员的机器上使用,我们就会回到 maven 之前的日子。

我们已经在我们的项目中成功使用龙目岛 1.5 年了。我们没有使用任何 delombokization,而是将 lombok 作为提供的依赖项,如下所示

    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>0.11.0</version>
        <scope>provided</scope>
    </dependency>

这就是它所需要的。我们可以使用龙目岛注释,它们被 eclipse 和 maven 构建识别。这甚至与 eclipse 中的 EclEmma 兼容,当相应的生成代码是(n't)时,它将注释标记为(未)覆盖。

您必须在每个 Eclipse 实例上手动安装它,因为大多数 JDT 都没有打开以供 eclipse 插件修改。这是龙目岛开发商无法解除的技术限制。无论如何,安装程序非常简单,到目前为止从未让我失望。

您不一定需要使用lombok-maven-plugin来利用龙目岛。据我了解,该插件所做的解散旨在允许代码覆盖率和javadoc之类的东西拥有完整版本的代码。即便如此,这个过程也只会发生在Javadoc构建时。

问题是你的项目是否可以没有它。如果是,那么只需将龙目岛添加为 Maven 依赖项即可。

在 Eclipse 中,你确实需要安装它。请注意,Lombok 仍然处于实验阶段,这可能是它默认不包含在 Eclipse 中的原因。

最新更新