简介: 删除您的 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。