由于一些糟糕的选择,我的本地Git存储库目前比原始库提前了五次提交,并且状态不佳。我想摆脱所有这些承诺,重新开始。

很明显,删除我的工作目录并重新克隆就可以了,但再次从GitHub下载所有内容似乎太过了,而且没有很好地利用我的时间。

也许git-restore是我需要的,但我不想在源代码之前提交10次(甚至6次),即使它确实将代码本身恢复到正确的状态。我只想假装最后半小时从未发生过。

有一个简单的命令可以做到这一点吗?这似乎是一个明显的用例,但我找不到任何例子。


请注意,这个问题专门针对提交,而不是:

未跟踪的文件未分级更改已分段但未提交的更改


当前回答

Try:

git reset --hard <the sha1 hash>

将你的头重置到你想去的任何地方。使用gitk查看你想去哪一个提交。你也可以在gitk内重置。

其他回答

如果您使用的是Atlassian SourceTree应用程序,可以使用上下文菜单中的重置选项。

更新时间:

您可以在此处使用新的GIT LFS:https://git-lfs.github.com/

git lfs migrate import --include="*.file_type"

然后git push

只需删除本地主分支,然后按如下方式重新创建:

git branch -D master
git checkout origin/master -b master

如果您只想丢弃本地提交并将修改保存在文件中,那么请执行git复位@~其他答案解决了硬重置问题

尝试分支时:

git reset --hard origin/<branch_name>

因此,使用“gitlog”或“gitstatus”验证反转(状态,无本地提交)。