假设我有一个这样的图
A---B---C---D (master)
\
\-E---F (HEAD)
如果我执行git log -all - online,我将得到所有6次提交。
但如果图像是
A---B---C---D (master, HEAD)
\
\-E---F
我不会看到E和f。我能得到git告诉我所有的提交,包括那些没有命名的分支吗?
谢谢
假设我有一个这样的图
A---B---C---D (master)
\
\-E---F (HEAD)
如果我执行git log -all - online,我将得到所有6次提交。
但如果图像是
A---B---C---D (master, HEAD)
\
\-E---F
我不会看到E和f。我能得到git告诉我所有的提交,包括那些没有命名的分支吗?
谢谢
当前回答
通过查看reflog(位于.git/logs/HEAD),我已经幸运地恢复了提交
然后我不得不向下滚动到文件的末尾,我找到了刚刚丢失的提交。
其他回答
git log有时候获取所有提交的细节并不好,所以要查看这个…
进入你的git项目,输入:
$ nano .git/logs/HEAD
查看你所有的提交,或者:
$ gedit .git/logs/HEAD
要查看所有的提交,
然后你可以在任何你喜欢的浏览器中编辑。
git log --reflog
救了我!我在合并头部时丢失了我的,找不到我的lates承诺!没有显示在源树中,但git日志——reflog显示我之前所有的本地提交
通过查看reflog(位于.git/logs/HEAD),我已经幸运地恢复了提交
然后我不得不向下滚动到文件的末尾,我找到了刚刚丢失的提交。
就像@Kieran的回答,但对于主机来说: Git log - online -all -graph - decoration $(Git reflog | awk '{print $1}')
实际上,git fsck可以用来找到所有丢失的提交,你只需要正确的选项:
git fsck --unreachable --no-reflogs
——unreachable单独是不够的,因为一些提交可能仍然被reflog引用。如果你需要对整个提交历史有一个非常清晰的视图,你可以创建一个别名,就像这样:
git log --all --decorate --oneline --graph $(git fsck --no-reflogs --unreachable | awk '{if ($2 == "commit") print $3}')
老实说,我不确定在最后一个命令中是否需要——unreachable选项,因为默认情况下git日志遍历祖先(除非指定了——no-walk)。我不敢打赌,但我认为没有必要。