git submodule修改了文件状态

问题描述 投票:42回答:3

我在我的主git文件夹树中添加了一个子模块,并且没有更改任何内容,但它显示已修改。我该怎么办?

$ git status
# On branch master
# Changed but not updated:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#    modified:   example.com/soundmanager
#
no changes added to commit (use "git add" and/or "git commit -a")

我尝试过git子模块更新,但它没有做任何事情。

git git-submodules
3个回答
68
投票

报告git子模块状态的方式在最近的git版本中发生了很大变化,所以你应该真正包括git --version的输出,以便我们能够准确地帮助你。

但是,无论如何,git diff example.com/soundmanager的输出应该告诉你更多。如果您看到具有相同提交名称的输出,但在新版本中添加了-dirty,例如:

diff --git a/example.com/soundmanager b/example.com/soundmanager
--- a/example.com/soundmanager
+++ b/example.com/soundmanager
@@ -1 +1 @@
-Subproject commit c5c6bbaf616d64fbd873df7b7feecebb81b5aee7
+Subproject commit c5c6bbaf616d64fbd873df7b7feecebb81b5aee7-dirty

...这意味着子模块中的git status不干净 - 尝试cd example.com/soundmanager然后git status看看发生了什么。

另一方面,如果您看到不同的提交版本,例如:

diff --git a/example.com/soundmanager b/example.com/soundmanager
index c4478af..c79d9c8 160000
--- a/example.com/soundmanager
+++ b/example.com/soundmanager
@@ -1 +1 @@
-Subproject commit c4478af032e604bed605e82d04a248d75fa513f7
+Subproject commit c79d9c83c2864665ca3fd0b11e20a53716d0cbb0

...这意味着你的子模块所在的版本(即你从cd example.com/soundmanager && git show HEAD看到的版本)与主项目树中提交的版本不同(即你从git rev-parse HEAD:example.com/soundmanager看到的版本)。如果前者是正确的,您应该在主项目中添加并提交新版本的子模块,例如:

git add example.com/soundmanager
git commit -m "Update the soundmanager submodule"

另一方面,如果后者是您想要的,您可以更改子模块所使用的版本:

git submodule update example.com/soundmanager

5
投票

我通过专门添加目录而不是仅添加新目录的内容而错误地添加子模块而进入此状态。

我只需要像这样删除子模块:

git rm --cached path/to/my/new_directory

然后在第一时间添加我想要的内容:

git add path/to/my/new_directory/*

0
投票

我使用了以下git命令并解决了这个问题:

git submodule update --init  --recursive
© www.soinside.com 2019 - 2024. All rights reserved.