我在Mac上使用GIT。我有工具,我有经验。我想继续使用它。这里没有战争……
问题总是与互操作性有关。大多数人使用SVN,这对我来说很棒。Git SVN开箱即用,是一种简单的解决方案。人们可以继续愉快地使用SVN,我也不会丢失我的工作流程和工具。
现在…有些人跟着Mercurial。对他们来说很好:他们有自己的理由。但是我找不到任何现成的GIT HG。我不想切换到HG,但我仍然需要与他们的存储库进行互操作。
你们有谁知道简单的解决办法吗?
我在Mac上使用GIT。我有工具,我有经验。我想继续使用它。这里没有战争……
问题总是与互操作性有关。大多数人使用SVN,这对我来说很棒。Git SVN开箱即用,是一种简单的解决方案。人们可以继续愉快地使用SVN,我也不会丢失我的工作流程和工具。
现在…有些人跟着Mercurial。对他们来说很好:他们有自己的理由。但是我找不到任何现成的GIT HG。我不想切换到HG,但我仍然需要与他们的存储库进行互操作。
你们有谁知道简单的解决办法吗?
当前回答
双向hg-git(和git-git, hg-hg)同步也可以通过服务Git-hg Mirror实现。它在幕后使用hg-git(以及其他),其代码也是开源的。
免责声明:我来自它背后的公司。
其他回答
Hg-Git Mercurial插件。我自己还没试过,但可能值得一试。
您可以尝试hg2git,这是一个python脚本,是fast-export的一部分,您可以在http://repo.or.cz/w/fast-export.git上找到它。
不过,您需要安装mercurial。
我已经尝试了cosmin的git-hg和abourget的git-hg-again都在mutt的hg回购,似乎后者尊重一个合并的顺序好,前者有点随机。你可以从下面的截图中看到。
cosmin的git-hg导入mutt的合并历史图:
abourget's git-hg-again导入mutt的合并历史图:
hgk在mutt's hg库上绘制的实际历史图:
正如你从上面看到的,abourget的git-hg-第二个图非常接近原始的hgk图,实际上反映了mutt的真实工作流程。
我再次发现git-hg的一个缺点是它没有添加一个'hg'远程,而是将所有的引用作为本地标签导入,git-hg有一个很好的'hg'远程表示上游hg repo。
由于hg-git是一个双向桥接,它还允许您将更改集从Git推到Mercurial。
2021年的最新答案似乎是git朱砂,Firefox就是用的。
本页上建议的其他脚本要么没有维护,要么需要过时的软件才能运行(通常是python 2.7)。相比之下,cinnabar可以使用python 3.5+,并且至少可以维护到本文撰写之日。
一旦朱砂安装,你可以克隆mercurial库直接前缀hg:::
git clone hg::https://hg.mozilla.org/mozilla-unified
或添加或设置一个远程到
git remote set-url origin hg::https://hg.mozilla.org/mozilla-unified
git fetch origin
你可以按下多变的遥控器。
使用hg2git和git2hg命令允许将git提交的sha1转换为mercurial更改集。 更多文档可在github页面。