如何处理转换为Mercurial的repo上的Git子模块

tsh*_*ang 9 git mercurial dvcs git-submodules mercurial-subrepos

开始:

$ cat .gitmodules 
[submodule "utils/external/firepython"]
    path = utils/external/firepython
    url = git://github.com/darwin/firepython.git
[submodule "utils/external/textile"]
    path = utils/external/textile
    url = git://github.com/jsamsa/python-textile.git
Run Code Online (Sandbox Code Playgroud)

虽然这仍然是一个Git回购,我需要运行git submodule init,之后会发生一些魔法.由于我现在将回购转换为Mercurial(使用hgext.git扩展名),我不知道该怎么做.是否有一个等效的过程(我需要在我的Mercurial仓库中使用这两个Git模块)?

Mar*_*ler 12

水银支持subrepositories不同种类的:水银,颠覆,和Git.所以你可以创建一个.hgsub文件

utils/external/firepython = [git]git://github.com/darwin/firepython.git
utils/external/textile    = [git]git://github.com/jsamsa/python-textile.git
Run Code Online (Sandbox Code Playgroud)

这将告知Mercurial在克隆Mercurial存储库时克隆您的Git存储库.您需要第一次自己制作Git克隆,或者从磁盘上的其他位置复制它们:

$ git clone git://github.com/darwin/firepython.git utils/external/firepython
$ git clone git://github.com/jsamsa/python-textile.git utils/external/textile
$ hg add .hgsub
$ hg commit -m 'Added Git subrepositories'
Run Code Online (Sandbox Code Playgroud)

然后,您将注意到Mercurial已将一个.hgsubstate文件添加到您的存储库,在该存储库中存储有关Git子存储库的信息.需要此文件,以便Mercurial在您创建新的Mercurial克隆时知道要从子存储库中检出的修订版本.

我的一位同事编写了一个您可能觉得有用的子库存指南.