首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Git中删除PR中的提交

在Git中删除PR中的提交
EN

Stack Overflow用户
提问于 2019-12-09 22:03:00
回答 2查看 62关注 0票数 1

我创建了一个公关,但无意中从错误的提交分支。

代码语言:javascript
复制
commit 4
commit 3
commit 2
commit 1 <-- Want to get rid of first commit  

Commit 1实际上是另一个公关的一部分。我想摆脱第一次提交,因为它与我创建的公关无关。做这件事最好的方法是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-12-09 22:16:24

最简单的,没有真正的思考-它的方式通常是一个互动的重新基地。执行git rebase -i <pr-base> (long:git rebase --interactive <pr-base>),删除第一行,保存并退出。它将重写历史上的提交1。然后,与往常一样,可能是git push --force-with-lease来同步您的情况下的更改。

票数 3
EN

Stack Overflow用户

发布于 2019-12-09 22:21:53

这将删除提交,就像它从未存在过一样,即更改将被撤消,并且它将从该分支的历史记录中删除。从逻辑上讲,如果更新的提交基于要删除的提交中的更改,则此操作将无法工作。(Git会告诉你这场“冲突”。)

在您的拉请求分支:

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

(看来我太慢了。)

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59257331

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档