我有一个指向无效提交的子模块的项目:子模块提交仍然是本地的,当我试图从另一个repo获取它时,我得到:

$ git submodule update
fatal: reference is not a tree: 2d7cfbd09fc96c04c4c41148d44ed7778add6b43
Unable to checkout '2d7cfbd09fc96c04c4c41148d44ed7778add6b43' in submodule path 'mysubmodule'

我知道子模块HEAD应该是什么,有没有办法我可以在本地改变这个,而不从已经提交2d7cfbd09fc96c04c4c41148d44ed7778add6b43的回购?

我不确定我是否说清楚了…我发现了一个类似的情况。


当前回答

当你有一个子模块指向一个重新基于的存储库,并且给定的提交“消失”时,也可能发生这种情况。虽然提交可能仍然在远程存储库中,但它不在分支中。如果你不能创建一个新的分支(例如,不是你的存储库),你就不得不更新超级项目来指向一个新的提交。或者,您可以将子模块的一个副本推到其他地方,然后更新超级项目以指向该存储库。

其他回答

当你有一个子模块指向一个重新基于的存储库,并且给定的提交“消失”时,也可能发生这种情况。虽然提交可能仍然在远程存储库中,但它不在分支中。如果你不能创建一个新的分支(例如,不是你的存储库),你就不得不更新超级项目来指向一个新的提交。或者,您可以将子模块的一个副本推到其他地方,然后更新超级项目以指向该存储库。

试试这个:

git submodule sync
git submodule update

可能的原因

这可能发生在以下情况:

子模块已编辑到位 提交子模块,更新所指向的子模块的散列 没有推送子模块。

例如:发生了这样的事情:

$ cd submodule
$ emacs my_source_file  # edit some file(s)
$ git commit -am "Making some changes but will forget to push!"

此时应该已经推送了子模块。

$ cd .. # back to parent repository
$ git commit -am "updates to parent repository"
$ git push origin master

因此,远程用户不可能找到丢失的提交,因为它们仍然在本地磁盘上。

解决方案

通知修改子模块以推送的人,即。

$ cd submodule
$ git push

无论如何,子模块的历史记录都安全地保存在子模块git中。

那么,为什么不直接删除子模块并重新添加它呢?

否则,您是否尝试手动编辑。git子模块中的HEAD或refs/master/ HEAD

只是偶然发现了这个问题,这些解决方案都不适合我。我的问题的解决方案实际上要简单得多:升级Git。我的版本是1.7.1,在我升级到2.16.1(最新版本)后,这个问题就消失得无影无踪了!我就把它留在这里了,希望能帮到别人。