繁体   English   中英

从 Git 中的 PR 中删除提交

[英]Remove a Commit from a PR in Git

我创建了一个 PR 但不小心分支了错误的提交。

commit 4
commit 3
commit 2
commit 1 <-- Want to get rid of first commit  

Commit 1实际上是另一个 PR 的一部分。 我想摆脱第一次提交,因为它与我创建的 PR 无关。 解决这个问题的最佳方法是什么?

最简单的、不需要考虑的方式通常是交互式 rebase。 执行git rebase -i <pr-base> (long: git rebase --interactive <pr-base> ),删除第一行,保存退出。 这将重写历史记录中的提交 1。 然后它可能像往常一样git push --force-with-lease来同步您的案例中的更改。

这将删除从未有过的提交,即更改将被撤消,并将从该分支的历史记录中删除。 从逻辑上讲,如果较新的提交基于您要删除的提交中的更改,则这将不起作用。 (Git 会告诉你这个“冲突”。)

在您的拉取请求的分支上:

  1. git rebase HEAD~4 --interactive (4 是要显示的提交数)
  2. 对于要删除的提交,将第一个单词从pick更改为drop [警告:数据丢失风险。 如果您不想丢失其内容,请确保此提交是另一个分支的一部分。]
  3. 保存并关闭文件”。
  4. git push --force (这将强行覆盖远程。如果你不希望其他人在这个远程分支上工作,我没问题。)

(好吧,看来我太慢了。)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM