我不小心说了git rm -r ..我该如何从中恢复呢?

我没有承诺。

我认为所有的文件都被标记为删除,并从我的本地签出中物理删除。

编辑:我可以(如果我知道命令)恢复到上次提交。但如果我能撤销git rm -r ..因为我真的不确定我在最后一次提交之后和git rm -r之前做了什么。


当前回答

更新:

因为git rm。删除工作签出中的this和子目录以及索引中的所有文件,你需要撤消这些更改:

git reset HEAD . # This undoes the index changes
git checkout .   # This checks out files in this and child directories from the HEAD

这应该是你想要的。它不会影响签出代码或索引的父文件夹。


以前的答案不是:

reset HEAD

将会做到这一点,并且不会删除您对文件所做的任何未提交的更改。

在此之后,您需要重复您已经排队的所有git add命令。

其他回答

获取列表提交

git log  --oneline

例如,稳定提交的哈希值为:45ff319c360cd7bd5442c0fbbe14202d20ccdf81

git reset --hard 45ff319c360cd7bd5442c0fbbe14202d20ccdf81
git push -ff origin master

更新:

因为git rm。删除工作签出中的this和子目录以及索引中的所有文件,你需要撤消这些更改:

git reset HEAD . # This undoes the index changes
git checkout .   # This checks out files in this and child directories from the HEAD

这应该是你想要的。它不会影响签出代码或索引的父文件夹。


以前的答案不是:

reset HEAD

将会做到这一点,并且不会删除您对文件所做的任何未提交的更改。

在此之后,您需要重复您已经排队的所有git add命令。

如果上述方法都不能正常工作,则可以使用这里的建议检索数据:http://www.spinics.net/lists/git/msg62499.html

git prune -n
git cat-file -p <blob #>

我收集了一些文件,并在下次提交之前继续修改,这时我意识到我需要其中一些文件。而不是隐藏和重置,你可以简单地签出你错过/删除的个别文件,如果你想:

git checkout HEAD path/to/file path/to/another_file

这使得其他未提交的更改没有任何变通办法。

如果您已经提交并提交了更改,那么您可以这样做来取回文件

// Replace 2 with the # of commits back before the file was deleted.
git checkout HEAD~2 path/to/file