fork 一个项目,两边并行提交,不定期 merge,怎么解决包名冲突的问题? - V2EX
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
wencan

fork 一个项目,两边并行提交,不定期 merge,怎么解决包名冲突的问题?

  •  1
     
  •   wencan Sep 30, 2022 2960 views
    This topic created in 1321 days ago, the information mentioned may be changed or developed.
    比如
    张三有一个 Go 项目,包名为 git.com/zhangsan/pkg
    李四 fork 了一份,包名改为 git.com/lisi/pkg
    然后张三的修改提交到 git.com/zhangsan/pkg ,李四的修改提交到 git.com/lisi/pkg 。两边不定期把对方的 branch/commit 合并到自己的项目。怎么解决 merge 时的包名冲突问题?每次 merge 时挨个解决冲突吗?
    实际场景中,可能是 fork 一个开源项目到公司 group 下。
    9 replies    2022-10-10 20:50:31 +08:00
    lookStupiToForce
        1
    lookStupiToForce  
       Sep 30, 2022
    这个总得根据文档提前商定的吧,包括命名规则规范之类
    这还只是包名冲突,如果函数内容在运行时才发现冲突,你们还打算把这本可以提前商定或者提交时 review 到就解决的东西,延到运行时发现冲突了才解决?
    hopingtop
        2
    hopingtop  
       Sep 30, 2022
    蹲一个好的解决方案
    hopingtop
        3
    hopingtop  
       Sep 30, 2022
    @#2
    hopingtop
        4
    hopingtop  
       Sep 30, 2022
    @hopingtop 两边不定期把对方的 branch/commit 合并到自己的项目。怎么解决 merge 时的包名冲突问题?这个需求采用直接分支 merge 的方法好吗?正常流程是不是走 pull request 好点?
    rb6221
        5
    rb6221  
       Sep 30, 2022
    import 用相对包名呗。然后包名前缀不同的部分放在一个单独的配置文件里 对这个文件做 gitignore
    lysS
        6
    lysS  
       Sep 30, 2022
    怎么有两个并行的主分支,而且还需要在之间同步?是单向同步吗?
    stackexplode
        7
    stackexplode  
       Sep 30, 2022
    定义一个主干
    wusu
        8
    wusu  
       Oct 10, 2022
    在原项目的目录下开发,把 remote 改成自己的项目 url ;定义 go module ,与项目路径无关
    wencan
        9
    wencan  
    OP
       Oct 10, 2022
    @wusu 重点是代码里的包名
    About     Help     Advertise     Blog     API     FAQ     Solana     3627 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 68ms UTC 04:43 PVG 12:43 LAX 21:43 JFK 00:43
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86