请教大神 git push merge 问题

2015-01-07 09:21:34 +08:00
 cha0s
问题是这样的:我在github上建立了一个仓库,默认是master分支,clone到本地后新建了一个dev分支进行开发。通过merge --no-ff合并到本地master。如果我这时push的话,github服务器上就会有本地dev分支的commit信息。有没有什么办法可以只push master分支而不带有本地dev的commit信息?
thanks!
2820 次点击
所在节点    问与答
5 条回复
csslayer
2015-01-07 09:32:38 +08:00
git push origin master

push 本地的 master 到服务器的 master 上。不会在服务器上创建 dev 分支。

dev 分支分离后产生的 commit 当然会push到服务器上,因为那已经是你从根到 master 提交历史的一部分。如果你想抛弃这些 commit 但是保持修改的内容就不应该用 merge,直接apply diff 然后重新 commit 即可。
zhangxiao
2015-01-07 09:39:04 +08:00
merge --squash
cha0s
2015-01-07 09:48:13 +08:00
@csslayer
@zhangxiao 非常感谢,merge --squash正是我想要的!之前是通过rebase操作,很不优雅:P
zhangxiao
2015-01-07 17:22:08 +08:00
@cha0s 其实也看实际情况了。我自己很少用squash,一般只squash那种比较脏的branch。如果commits都比较合理和仔细,感觉还是把commit history留在master里比较好
cha0s
2015-01-07 20:04:42 +08:00
@zhangxiao 对,需求场景主要是本地commit会有一些与部署有关的信息在里边,不能公开到网上。所以push到github的时候要避免那些commit。

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

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

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

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

© 2021 V2EX