如何撤消保留以前上演版本的“git add”? (索引有历史吗?)

时间:2012-05-27 10:58:29

标签: git pre-commit unstage

我有一个与How to undo 'git add' before commit?类似的问题,但有一个重要区别:

背景

我正在运行一些生成文件的代码,完成后我将添加到我的存储库中。生成文件的代码是新代码,并且不断变化,因此我有时会运行多次更改。

在此过程中,我将生成的文件添加到索引中,因此它们将在最后进行一次大型提交。这也允许我检查我对代码的更改是否在输出中创建了更改,如果是,那么这些更改是什么。但是......我不小心在Changes to be committed部分(作为new file Changes not staged for commit部分出现的文件中添加了另一个git add (作为modified)。我打算在它上面运行一个git diff,但是我滑倒并重新添加它,所以现在我没有办法对它进行区分(我知道),所以......

问题:

有没有办法撤消只是最后一个暂存操作,这样以前添加的版本仍将/再次出现在索引中,修改后的文件将再次出现在我的工作树中,这样我可以分享它吗?

这些都不是承诺或任何事情,因为我的目标是在完成这一小部分开发时将它们全部一起提交。我真的很喜欢那个git通常会在我们提交之前向我显示新文件的更改...但是......我错过了一次机会,现在我想知道是否有办法让它恢复。 ?

我到目前为止看到的东西似乎能够让我回到最后一次提交(没有文件)或文件的当前状态(无论如何),但不是介于两者之间从索引的先前版本开始,这从未成为提交的一部分。任何关于这是否可能的提示(即使是一个不可靠的答案,最好是解释为什么会这样)也将不胜感激。

1 个答案:

答案 0 :(得分:3)

没有直接的方法来访问文件的最后阶段版本。没有索引文件的版本控制,这就是你应该使用commit的内容。将来您可以考虑更频繁地进行临时提交(例如使用commit --amend),然后至少您的先前版本将在您的reflog中(例如git log -g)。

但是,所有文件的所有阶段版本都将添加到git对象数据库中。您应该可以使用git fsck --lost-found找到它们。这会将所有“悬空”blob写入.git/lost-found/other。不幸的是,他们不会以任何特定的顺序或者拥有原始文件名,但任何丢失的blob应该在某处。