我有一个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重置——很难将所有修改过的文件重置到它们上一次提交的状态。请注意,这将丢弃所有未提交的更改。

其他回答

移动到子模块的目录,然后执行git重置——很难将所有修改过的文件重置到它们上一次提交的状态。请注意,这将丢弃所有未提交的更改。

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

git submodule foreach git reset --hard

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

git submodule foreach --recursive git reset --hard

如果子模块中有更改,则使用

git submodule foreach --recursive git reset --hard

如果您的更改是远程子模块更改,则使用

git submodule update --init

如果已提交这些更改,则使用

git reset --hard
git submodule update --init

如果你想放弃整个存储库中的所有更改以及子模块,你可以使用:

git restore . --recurse-submodules

注意,这只撤销所有本地更改(在存储库和所有子模块中)。 但是git重置…接收一个target-commit-id作为输入,并且可以将HEAD移动到任何提交。

这对我来说是有效的,包括递归到子模块中(也许这就是为什么你的-f不起作用,因为你在子模块中改变了一个子模块):

git submodule update -f --recursive