git rm -r --cached未删除子模块文件夹和内容

7
解决方案:从 git rm -r --cached submodule/name 中移除 --cached。参考此脚本
我尝试根据这份 SO 答案删除 git 子模块,但子模块未被删除。
我添加了子模块、提交更改,然后使用git rm -r --cached $path/to/submodule(去掉结尾的 /)删除它并提交更改,但子模块仍然存在。
我可以使用rm -rf submodules/lift_sbt_24 删除文件夹及其内容,但为什么git rm -r --cached不能实现呢?
(从 .gitmodules 中删除相关部分很好用,没有问题,因此在这里不予提及)
这是 Ubuntu 11.10 上的 git 1.7.5.4。完整示例如下:
$> git submodule add git@github.com:lift-stack/lift_24_sbt.git submodules/lift_24_sbt
Adding submodule from repo git@github.com:lift-stack/lift_24_sbt.git as submodules/lift_24_sbt
Cloning into submodules/lift_24_sbt...
remote: Counting objects: 619, done.
remote: Compressing objects: 100% (375/375), done.
remote: Total 619 (delta 172), reused 593 (delta 147)
Receiving objects: 100% (619/619), 1.74 MiB | 112 KiB/s, done.
Resolving deltas: 100% (172/172), done.
$> git status
# On branch master
# Your branch is ahead of 'origin/master' by 1 commits.
#
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#
#   modified:   .gitmodules
#   new file:   submodules/lift_24_sbt
#
$> git add -a
$> git commit 'added submodules/lift_24_sbt'
[master 9894113] update
 2 files changed, 4 insertions(+), 0 deletions(-)
 create mode 160000 submodules/lift_24_sbt
$> git rm -r --cached submodules/lift_24_sbt
rm 'submodules/lift_24_sbt'
$> git status
# On branch master
# Your branch is ahead of 'origin/master' by 1 commits.
#
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#
#   deleted:    submodules/lift_24_sbt
#
# Untracked files:
#   (use "git add <file>..." to include in what will be committed)
#
#   submodules/lift_24_sbt/
$> git add -a
$> git commit -m 'deleted submodules/lift_24_sbt'
# On branch master
# Your branch is ahead of 'origin/master' by 1 commits.
#
nothing to commit (working directory clean)
$> ls -al submodules/lift_24_sbt/
total 1060
drwxr-xr-x 5 kurtosis kurtosis    4096 2012-04-18 17:26 ./
drwxrwxr-x 6 kurtosis kurtosis    4096 2012-04-18 17:26 ../
drwxrwxr-x 8 kurtosis kurtosis    4096 2012-04-18 17:32 .git/
drwxrwxr-x 2 kurtosis kurtosis    4096 2012-04-18 17:26 project/
drwxrwxr-x 3 kurtosis kurtosis    4096 2012-04-18 17:26 src/
-rw-rw-r-- 1 kurtosis kurtosis     931 2012-04-18 17:26 build.sbt
-rw-rw-r-- 1 kurtosis kurtosis     463 2012-04-18 17:26 .gitignore
-rw-rw-r-- 1 kurtosis kurtosis      91 2012-04-18 17:26 README.md
-rwxrwxr-x 1 kurtosis kurtosis     110 2012-04-18 17:26 sbt*
-rw-rw-r-- 1 kurtosis kurtosis     131 2012-04-18 17:26 sbt.bat
-rw-rw-r-- 1 kurtosis kurtosis 1041753 2012-04-18 17:26 sbt-launch.jar
$> git --version
git version 1.7.5.4
2个回答

12
您所看到的是正确的;git rm --cached -r 实际上并没有从 working tree 中删除文件,只是从 index 中删除。如果您想让 git 同时从 indexworking tree 中删除文件,则不应使用 --cached。有关更多信息,请参阅 git-rm man page
以下是对你所做的内容的解释。我假设你是手动输入了你所采取的步骤,而不是从终端复制;据我所知,git add -a不是已知的git-add标志;我也相当确定你想要使用git commit -m <message>
你所采取的简化步骤:

# First, add the submodule. 
$> git submodule add git@github.com:lift-stack/lift_24_sbt.git submodules/lift_24_sbt
# Check that the submodule exists. (It does). 
$> git status
# Add everything to the staging area from the working tree. 
$> git add -a
# Commit all changes. 
$> git commit 'added submodules/lift_24_sbt'

此时,您已成功添加了模块,一切都按预期工作。
接下来您要尝试的是删除该模块:

$> git rm -r --cached submodules/lift_24_sbt

注意:这里我们仅从索引中删除文件,而不是从工作目录中删除,因为使用了--cached选项。
--cached
       Use this option to unstage and remove paths only from the index. Working tree
       files, whether modified or not, will be left alone.

然后,检查我们是否已经删除了子模块:

$> git status
... <snip> 
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#
#   deleted:    submodules/lift_24_sbt

正如您所看到的,子模块已被删除,一切都很好。但请注意,这些文件仍存在于“工作树”中 - 您仍然可以使用ls查看它们。:)


谢谢,是的,我指的是 git add -Agit commit -m。从 git rm -r $1 中删除了 --cached 并将其脚本化。也许在脚本中这样做不太明智,但至少作为逐步参考是有用的。 - Kurtosis

1
你可以尝试简化脚本,使用一个新的命令(git1.8.3,2013年4月22日发布),该命令在对“如何删除Git子模块?”的新回答中有详细介绍:
git submodule deinit

它应该删除子模块的工作树,并从.git/config中注销它。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接