我刚刚运行了一个git diff,我得到以下输出的所有我的大约10个子模块

diff --git a/.vim/bundle/bufexplorer b/.vim/bundle/bufexplorer
--- a/.vim/bundle/bufexplorer
+++ b/.vim/bundle/bufexplorer
@@ -1 +1 @@
-Subproject commit 8c75e65b647238febd0257658b150f717a136359
+Subproject commit 8c75e65b647238febd0257658b150f717a136359-dirty

这是什么意思?我该怎么解决呢?


当前回答

之所以会出现这种情况,是因为子模块的指针并不是子模块目录中的实际内容。要解决这个问题,你必须再次运行git子模块update:

其他回答

之所以会出现这种情况,是因为子模块的指针并不是子模块目录中的实际内容。要解决这个问题,你必须再次运行git子模块update:

我最终删除了子模块目录,并再次初始化它

cd my-submodule
git push
cd ../
rm -rf my-submodule
git submodule init
git submodule update

检查子模块的递归性。我的问题是我的子模块错误地指向了他内部的另一个子模块。

在我的例子中,我不确定是什么导致了这种情况的发生,但我知道我只是想让子模块被重置到它们最新的远程提交,然后完成它。这涉及到把这里几个不同问题的答案结合起来:

Git子模块更新——递归——远程——初始化

来源:

如何将我的更改恢复到git子模块?

简单的方法拉最新的所有git子模块

要忽略任何子模块中所有未跟踪的文件,使用以下命令忽略这些更改。

git config --global diff.ignoreSubmodules dirty

它将添加以下配置选项到您的本地git配置:

[diff]
  ignoreSubmodules = dirty

更多信息可以在这里找到