2

昨天和今天我将我的 eclipse juno 项目转换为 eclipse 中的多模块 maven 项目。我有 1 个 'pom-root' 类型的 maven 项目,我所有的其他项目都是模块。这些模块将根项目作为父项目。这可以正常工作。

几个小时前,我确实尝试将根项目添加到 egit,只需右键单击根项目并选择共享项目 - > egit。

我首先在一个新目录中创建了一个新的存储库,结果是我所有的模块项目都变成了空的,并且所有的源文件都被复制到了存储库目录中。很高兴我确实看到了这一点,并且可以通过将文件复制回来轻松恢复。

接下来在尝试失败后,我尝试在项目的父文件夹中创建存储库。这以某种方式失败了,根项目变得腐败。经过大量的摆弄,我删除了损坏的根项目并创建了一个新的“pom-root”类型,不知何故我设法让一切重新运行。

接下来我浏览到stackoverflow(:-))并问我的问题:

如何将我的多模块 maven 项目放在新的本地 git 存储库中?(不会丢失或破坏一切)

4

1 回答 1

3

简介: 删除您的 Eclipse 项目(只是它们的元数据,而不是它们的内容),然后通过从本地存储库中导入它们来重新创建它们。

警告:我正处于“一点知识是一件危险的事情”的阶段,所以对此持怀疑态度。

我刚刚经历了这个,我想我有一个解决方案/解决方法。

我相信,问题在于大多数 Eclipse 仍然无法理解嵌套在其他项目中的项目。当您共享根项目时,EGit 将所有项目文件从 Eclipse 工作区移出到本地 git 存储库,然后更新根项目的 Eclipse 元数据以反映文件的新位置(很好),但是(因为它是对嵌套项目一无所知),这意味着它将子模块中的所有文件都视为根项目的一部分,因此将它们移动到 git repo 中(没关系),但没有更新这些子模块的 Eclipse 项目元数据(那很糟)。因此 Eclipse 显示您现在有一堆(子)项目没有任何文件(甚至没有 .project 文件,也没有 pom.xml)。

解决方案(我相信)是:删除您的 Eclipse 项目。不完全是。但非常小心;见下文。[为了安全起见,也许使用 zip 来备份位于 repo 工作目录中的可爱文件。如果他们已经上演或提交了这将是没有实际意义的,但大概在这一点上他们还没有]。

当您选择每个 Eclipse 项目并右键单击删除时,请确保未选中“删除磁盘上的项目内容(无法撤消)”复选框 - 换句话说,您正在删除每个项目的 Eclipse 元数据(我做了这适用于所有子模块,甚至适用于根项目),但您不会删除位于存储库工作目录中的文件。

(我担心 m2e 可能过于“有用”,并且当我删除每个子模块时,它可能会将其从父级的 pom.xml 中删除,但幸运的是这似乎没有发生)。

在 Eclipse Preferences for Team - Git - Projects 中,我确实启用了“自动共享位于 git 存储库中的项目”。这让生活更轻松,但我认为如果你愿意,你可以使用更少的自动化方法。

删除所有相关的 Eclipse 项目后,使用 Git Repositories 视图导入 Maven 项目;这将创建新的 Eclipse 项目(用于根项目和子模块),其中包含指向存储库中文件的有效元数据。哈利路亚。

我相信这是可行的,因为 Eclipse 中对嵌套项目一无所知的一部分是 m2e 中的 import-maven-projects 逻辑。

此时所有文件仍未跟踪,因此接下来您可能要选择根项目并右键单击 Team --> Add to Index (我假设这也会添加所有子模块,因为它忽略了嵌套项目并将它们视为根项目中的额外文件)。

我想知道如果我再添加一个新的子模块会发生什么——它会“正常工作”(并在 git repo 中共享)还是需要更多的回转?我很高兴地发现(据我所见)它“正常工作”:Eclipse 项目元数据在正确的位置显示文件(在 git repo 中,作为根项目下的子项)并将项目标记为在 git 中共享。

所以我的猜测是,如果你或我有一台时间机器,那么简单的方法就是创建根 Maven 项目,将其共享给 EGit,然后才开始创建子 Maven 模块。

我的环境(尽管可能无关紧要):Eclipse 4.3.1 (Kepler SR1) 及其组件的常用版本:m2e 1.4.0、EGit 3.0.3、m2e EGit 连接器 0.14.0。

于 2013-11-25T02:16:43.350 回答