github 上的多次 pr 怎么才能始终只包含 1 个 commit?

2021-01-25 15:51:29 +08:00
 felixin

第一次 fork 后,提交一个 pr a 包含一个 commit a,被上游合并了。

接着在本地 pull upstream,这时候会有个 merged from ... 的 commit 在我的 fork 上。

接着我在本地做第二次修改,又产生了一个新的 commit b,开一个新的 pr b,但是这个 pr 和上游的分叉点还是在 commit a 之前,因此这个 pr 会包含 commit a 和 b 。

请问该如何让 pr b 只包含 commit b ?在不重新 fork 的情况下。

2079 次点击
所在节点    问与答
7 条回复
xiri
2021-01-25 16:21:42 +08:00
pull 的时候用 rebase 合并就不会有那个 merged from 的 commit 了
channingcheng
2021-01-25 17:04:07 +08:00
@xiri
jaween
2021-01-25 17:35:42 +08:00
rebase,刚在掘金看到的
msg7086
2021-01-25 17:46:38 +08:00
pull 的时候默认做 fetch+merge 。而这里 merge 是错误操作。
zdt3476
2021-01-25 18:27:52 +08:00
git pull —rebase
catror
2021-01-25 18:51:59 +08:00
master 分支和上游保持同步,修改代码建新的分支
mxalbert1996
2021-01-25 19:33:30 +08:00
如果上游没对你的 PR 做修改,那么你 pull upstream 的时候会直接 fast forward,不会有额外的 commit 。如果上游是修改以后合并,那么你应该用 rebase 。另外建议设置 pull 时仅限 ff ( git config pull.ff only ),最新版的 git 已经会在你没有指明 pull 模式的时候显示警告。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/748185

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX