我有一个git子模块(RestKit),我已经添加到我的repo。

我不小心更改了里面的一些文件,我想回到原始版本。为了做到这一点,我试着逃跑

Mac:app-ios user$ git submodule update RestKit

但正如你在这里看到的,这并没有起作用,因为它仍然是“修改的内容”:

Mac:app-ios user$ git status
...
#   modified:   RestKit (modified content)

甚至

Mac:app-ios user$ git submodule update -f RestKit 

不恢复本地修改的文件。 如何重置该子模块的内容?


当前回答

我重置所有子模块的方法(不分离和保留它们的主分支):

git submodule foreach 'git checkout master && git reset --hard $sha1'

其他回答

对我来说,有

git reset --hard

只需将子模块重置到它签出时的状态,而不需要主模块的repo引用的提交/状态。我仍然会像OP说的那样有“修改的内容”。所以,为了让子模块回到正确的提交,我运行:

git submodule update --init

然后当我执行git status时,它在子模块上是干净的。

如果您希望为所有子模块执行此操作,而不必更改目录,则可以执行

git submodule foreach git reset --hard

你也可以使用递归标志应用到所有子模块:

git submodule foreach --recursive git reset --hard

我重置所有子模块的方法(不分离和保留它们的主分支):

git submodule foreach 'git checkout master && git reset --hard $sha1'

一个比之前所有答案都更安全的方法:

git submodule deinit -f .
git submodule update --init

第一个命令完全“解除”所有子模块的绑定,第二个命令则对它们进行新的签出。 它比其他方法花费的时间长,但无论子模块的状态如何,它都可以工作。

很简单:

cd /path/to/submodule/root
git submodule update -f --init  .

大多数答案都建议重置所有的子模块,我认为这不是最好的方法,因为它们可能会有合法的变化。