如何轻松撤消git重基?冗长的手动方法是:

签出两个分支的提交父级创建并签出临时分支手工挑选所有提交重置故障的重基分支以指向临时分支

在我目前的情况下,这是可行的,因为我可以很容易地发现两个分支的提交(一个是我的东西,另一个是同事的东西)。然而,我的方法给我的印象是次优且容易出错(假设我刚刚用自己的两个分支重新建立了基础)。

澄清:我所说的是一个重基,在重基过程中,多次提交被重复,而不仅仅是一次。


当前回答

git reset --hard origin/{branchName}

是重置rebase所做的所有本地更改的正确解决方案。

其他回答

git reset --hard origin/{branchName}

是重置rebase所做的所有本地更改的正确解决方案。

实际上,rebase将您的起点保存到ORIG_HEAD,因此这通常很简单:

git reset --hard ORIG_HEAD

然而,reset、rebase和merge都会将原始HEAD指针保存到ORIG_HEAD中,因此,如果您在尝试撤消rebase之后执行了这些命令,则必须使用reflog。

使用reflog对我不起作用。

对我有用的东西与这里描述的相似。在.git/logs/refs中打开以重新基于分支命名的文件,找到包含“rebase finsihed”的行,类似于:

5fce6b51 88552c8f Kris Leech <me@example.com> 1329744625 +0000  rebase finished: refs/heads/integrate onto 9e460878

签出行中列出的第二个提交。

git checkout 88552c8f

一旦确认这包含了我丢失的变化,我就分支起来,松了一口气。

git log
git checkout -b lost_changes

我通常做的是git reset#commit_hash

到最后一次提交,我认为rebase没有效果。

然后git拉动

现在,分支应该与主分支完全匹配,而重基提交不应该在其中。

现在,你可以在这个分支上随意选择提交的内容。

如果您已经将分支推送到远程存储库(通常是它的源位置),然后您成功地进行了重基(没有合并)(gitrebase--abort给出“没有正在进行的重基”),您可以使用命令:

git reset--硬原点/{branchName}

例子:

$ ~/work/projects/{ProjectName} $ git status
On branch {branchName}
Your branch is ahead of 'origin/{branchName}' by 135 commits.
  (use "git push" to publish your local commits)

nothing to commit, working directory clean

$ ~/work/projects/{ProjectName} $ git reset --hard origin/{branchName}
HEAD is now at 6df5719 "Commit message".

$ ~/work/projects/{ProjectName} $ git status
On branch {branchName}
Your branch is up-to-date with 'origin/{branchName}.

nothing to commit, working directory clean