【发布时间】:2013-05-14 14:30:00
【问题描述】:
我有点进退两难。我不小心在两个 Git 存储库之间合并了代码。无论出于何种原因,repo 名称都是相同的,并且在我知道之前,repo 的 URL 之一已经更改。所以我最终合并了来自两个不同项目的代码。这是来自存储库提交的插图。
我没有命名任何分支(一直在研究 HEAD)。如何删除其中一个提交(特别是橙色的那个)?
【问题讨论】:
我有点进退两难。我不小心在两个 Git 存储库之间合并了代码。无论出于何种原因,repo 名称都是相同的,并且在我知道之前,repo 的 URL 之一已经更改。所以我最终合并了来自两个不同项目的代码。这是来自存储库提交的插图。
我没有命名任何分支(一直在研究 HEAD)。如何删除其中一个提交(特别是橙色的那个)?
【问题讨论】:
你可以这样做:
git reset --hard 628612ac
如果您确定当前工作副本中没有您需要的任何内容。这会将HEAD 放到合并之前的提交中。实际上没有删除任何内容 - 其他提交变得无法访问,并且将在未来某个时候被垃圾收集。
另一种选择是使用git-revert:
git revert -m 1 e90aeed8
这将保留您的历史记录。它会创建一个新的提交来恢复 e90ae... 所做的一切。
这是一个关于这个主题的好读物:https://www.kernel.org/pub/software/scm/git/docs/howto/revert-a-faulty-merge.txt
【讨论】: