当前位置: 代码迷 >> Eclipse >> 当 Maven 遇下 Eclipse
  详细解决方案

当 Maven 遇下 Eclipse

热度:611   发布时间:2016-04-23 01:56:40.0
当 Maven 遇上 Eclipse

简介:? Maven 是一个功能强大的工具,但需要将其集成到流行的集成开发环境 (IDE) 中,以使其功能更易用且让您的工作更轻松,从而增加您的生产力和项目质量。Mevenide 将 Maven 平滑集成到 Eclipse 中,帮助降低了第一次面对 Maven 时的学习曲线。本教程提供了如何让 Maven 与 Eclipse 协作的具体例子。

用 Maven 处理复杂构建

Maven 概述

最近有一股 Maven 热,您可能也没有幸免。在 2001 年 Maven 进入市场之前,还没有真正的构建工具。开发人员和构建管理人员必须不厌其烦地编写构建脚本,并以没完没了的维护噩梦收场。

Maven 是围绕项目对象模型 (POM) 概念的软件项目管理工具,POM 封装了项目的结构和概念元数据,比如标识信息,依赖关系和布局描述。重要项目元数据的声明表示缩短了需要投入项目中的时间量,并增强了它的全局理解力。

Maven 还促进了重用性和简约性,通过鼓励减少内容关联并将项目分割成更小的实体,使得项目更易维护。但当应用程序分割成小颗粒的子项目时,您需要一种方法来立即构建整个应用程序。基于此目的,Maven 提供了一种自动分解处理顺序、将多个项目构建成全局项目的方法(参阅 参考资料)。


构造项目

在本教程中,将为 Eclipse 创建 JavaNCSS 插件(参阅 参考资料)。JavaNCSS 允许从 Java 源代码收集简单的 metric。不幸的是,它在开发时并未考虑到重用性和集成。所以,必须先在其上创建一薄层以便将其简单嵌入。尽管 JavaNCSS 主要是一个命令行工具,但它具有将收集到的数据保存到 XML 文件中的能力。毫无疑问,您将使用该特性。

您已经能猜到需要做什么了。您需要一个命令行包装器和一个解析器。

为了实现简约性和重用性的目的,您将分离这两方面,将它们开发为独立的项目,每个项目生成自己的工件,并具有自己的生命周期。然而,它们是同一项目的一部分,因此共享一些属性,比如公共目录布局。为了避免信息重复,将在抽象父项目中分解共享属性。最终将得到三个项目:

  • metrics-model 提供解析器。该解析器和映射到 XML 的底层类是使用 maven-modello-plugin (参阅 参考资料)从 XML 描述(可以在本教程的 os-maveneclsrc.zip 文件中找到)中生成的。
  • metrics-core 封装命令行包装器,并依赖 metrics-model
  • metrics-commonsmetrics-coremetrics-model 继承的父项目。

下列代码段显示了 metrics-commons 的项目模型:

?

<project>    <pomVersion>3</pomVersion>    <groupId>dw-metrics</groupId>    <artifactId>metrics-commons</artifactId>    <currentVersion>1.0-SNAPSHOT</currentVersion>    <name>Metrics Parent</name>    <build>        <sourceDirectory>src/main/java</sourceDirectory>        <unitTestSourceDirectory>src/test/java</unitTestSourceDirectory>        <!-- declare resource directories as well -->    </build></project>

简单的解析器生成

metrics-coremetrics-model 都继承了 metrics-commons,如下所示:

  1. 创建 metrics-modelmetrics-core POM
  2. 记住将 metrics-model 添加到 metrics-core 依赖关系中,将 maven-modello-plugin 添加到 metrics-core 的依赖关系列表中,如下所示:
    <project>    <extend>../metrics-commons/project.xml</extend>    <pomVersion>3</pomVersion>    <artifactId>metrics-model</artifactId>    <name>Metrics Model</name>    <dependencies>        <dependency>            <groupId>maven</groupId>            <artifactId>maven-modello-plugin</artifactId>            <version>1.0-alpha-1-SNAPSHOT</version>            <type>plugin</type>        </dependency>    </dependencies>    <build>        <sourceDirectory>target/generated-sources/modello</sourceDirectory>    </build></project>

因为要生成该项目包含的惟一源文件,所以必须覆盖 metrics-model POM 中的 sourceDirectory 元素以使 maven-java-plugin 正确工作。源生成应发生在编译开始之前:

  1. metrics-model 中创建 maven.xml 文件

  2. 要为每个子项目生成 .classpath 文件,从 metrics-master 中运行下列命令:
    maven -Dgoal=eclipse:generate-classpath multiproject:goal

在开始编码之前,将项目导入到 Eclipse 中,步骤如下:

  1. 启动 Eclipse
  2. 浏览到 file > import
  3. 选择 Existing Project into workspace 并单击 Next
  4. 在根目录文本框中,输入 metrics-master 的父文件夹
  5. 单击 Select All,然后单击 Finish

最后一步配置

此时,项目将不编译。maven-eclipse-plugin 使用特殊的类路径变量 MAVEN_REPO 生成 .classpath,它指向本地存储所有依赖关系的本地 Maven 存储库, 从而允许更好的协作开发。需要按如下步骤声明:

  1. 打开 Preferences 窗口
  2. 转到位于 Java > Build Path 节点下的 Classpath Variables 页面
  3. 单击 New
  4. 将名称设置为 MAVEN_REPO,值设置为本地 Maven 存储库的位置(参见图 2)

    图 2. 在 Classpath Variables 窗口中添加 MAVEN_REPO
    在 Classpath Variables 窗口中添加 MAVEN_REPO

现在可以开始编码了。


关于多项目

正如前面所看到的,Maven 在处理涉及许多子项目的复杂项目时有用。如果更深入地研究所推荐的 Maven 多项目布局,将注意到它是以层次方式构造的:结构的根包含共享元数据,比如父 POM、共享属性和公共目标定义。在某种程度上,该结构类似于 Eclipse 工作空间,包括包含当前工作空间配置的顶层元数据文件夹。

但是,Eclipse 工作空间元数据不能由用户手动编辑,但是您应该能够添加并手动编辑 Maven 元数据(最终添加文件夹以构造它)。不能将 Maven 项目根导入为 Eclipse 项目,因为它将与现有子项目重叠,而 Eclipse 还不支持项目重叠。


关于非 Eclipse 友好的项目

自然冲突存在于典型 Maven 项目布局(层次结构,父文件位于层次结构根)和 Eclipse 项目结构。这就是为什么让 Maven 和 Eclipse 顺利协作的惟一可行方法是平铺层次结构,以使共享元数据包含在子项目中。

但这并不总是可行。例如,假设要检出层次结构化的但对其没有控制权的项目。如何让 Eclipse 与该项目良好协作?在这种情况下,一些应急方案(每个都具有自己的缺点)可以帮助您处理该问题:

  • 使用一个大 Eclipse 项目——主要缺点是损失依赖关系可见度;几乎无法说明哪个模块依赖于哪个库。这还促进了循环,使得平均信息量增加得更快,维护更困难。
  • 在 Eclipse 外部编辑根文件——这是本文展示的最安全的应急方案。但是,该解决方案不易于使用,因为它需要在工具间切换,而且还易出错。
  • 创建只包含到根文件和文件夹的链接的虚拟项目——尽管易于使用,但该解决方案有两个缺点:不支持变量扩张(因此在团队环境中很麻烦),而且必须手动配置。

这些只是提示,并非建议。应该尽量避免使用这些方法。最终,应该尝试重构您的构建,而不要依赖这些让事情变得更困难的应急方案。

  相关解决方案