9

所以,我一直想使用 Lombok 有一段时间了——我终于开始了一个可以使用它的项目。需要注意的重要一点是,这将是一个大型的企业级应用程序,因此使用的集成模式必须是有意义的,并且尽可能少的 hack。

因此,我查看了 lombok-maven-plugin 和整个delombok软糖。我知道这将复制我的所有代码,并在存在的地方扩展 lombok 注释。这给了我第二组生成的.java文件,maven 在编译期间需要使用这些文件。

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

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

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

我希望能得到一些灵感,让我免于为我的项目注销 Lombok。这是一个减少样板代码的好工具,但它似乎还没有为黄金时段的企业使用做好准备——我觉得这很令人失望:-(

以下是我当前的 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 实例上手动安装 lombok。主要是因为我会接到所有无法让它工作的开发人员的电话。我明白为什么它没有那么简单,mvn eclipse:eclipse但我仍然想指出我的失望。如果我们必须手动设置每个库以在每个开发人员的机器上使用,我们就会回到前 maven 时代。

4

2 回答 2

7

我们在项目中成功使用 lombok 已有 1.5 年了。我们没有使用任何 delombokification,而是像这样将 lombok 作为提供的依赖项

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

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

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

于 2013-11-06T10:41:53.247 回答
5

您不一定需要使用lombok-maven-pluginLombok 来利用。据我了解,插件所做的delombofication旨在允许代码覆盖率和 javadoc 等内容拥有完整版本的代码。即便如此,该过程也只会在 Javadoc 构建时发生。

问题是您的项目是否可以在没有它的情况下生存。如果是,那么只需添加 lombok 作为 Maven 依赖项即可。

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

于 2013-11-06T10:02:21.720 回答