V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
cha0s
V2EX  ›  问与答

请教大神 git push merge 问题

  •  
  •   cha0s · 2015-01-07 09:21:34 +08:00 · 2806 次点击
    这是一个创建于 3387 天前的主题,其中的信息可能已经有所发展或是发生改变。
    问题是这样的:我在github上建立了一个仓库,默认是master分支,clone到本地后新建了一个dev分支进行开发。通过merge --no-ff合并到本地master。如果我这时push的话,github服务器上就会有本地dev分支的commit信息。有没有什么办法可以只push master分支而不带有本地dev的commit信息?
    thanks!
    5 条回复    2015-01-07 20:04:42 +08:00
    csslayer
        1
    csslayer  
       2015-01-07 09:32:38 +08:00   ❤️ 1
    git push origin master

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

    dev 分支分离后产生的 commit 当然会push到服务器上,因为那已经是你从根到 master 提交历史的一部分。如果你想抛弃这些 commit 但是保持修改的内容就不应该用 merge,直接apply diff 然后重新 commit 即可。
    zhangxiao
        2
    zhangxiao  
       2015-01-07 09:39:04 +08:00 via Android   ❤️ 1
    merge --squash
    cha0s
        3
    cha0s  
    OP
       2015-01-07 09:48:13 +08:00
    @csslayer
    @zhangxiao 非常感谢,merge --squash正是我想要的!之前是通过rebase操作,很不优雅:P
    zhangxiao
        4
    zhangxiao  
       2015-01-07 17:22:08 +08:00
    @cha0s 其实也看实际情况了。我自己很少用squash,一般只squash那种比较脏的branch。如果commits都比较合理和仔细,感觉还是把commit history留在master里比较好
    cha0s
        5
    cha0s  
    OP
       2015-01-07 20:04:42 +08:00
    @zhangxiao 对,需求场景主要是本地commit会有一些与部署有关的信息在里边,不能公开到网上。所以push到github的时候要避免那些commit。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   995 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 22:02 · PVG 06:02 · LAX 15:02 · JFK 18:02
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.