我需要将mercurial项目转换为git项目,但我想保持提交历史完整。我目前的解决方案是删除hg相关文件,然后git init &&手动添加我需要的文件,但这不会保留历史。有什么解决办法吗?
当前回答
如果您想将现有的mercurial存储库导入到“GitHub”存储库中,现在只需使用这里提供的GitHub导入器[需要登录]。没有更多的混乱的快速导出等(虽然它是一个非常好的工具)
您将获得所有的提交、分支和标记。还有一件很酷的事情是,你还可以更改作者的电子邮件id。看看下面的截图:
其他回答
另一种选择是创建一个免费的Kiln帐户——在git和hg之间往返,保留100%的元数据,这样您就可以使用它进行一次性转换,或者使用它访问存储库,使用任何您喜欢的客户端。
来自:
http://hivelogic.com/articles/converting-from-mercurial-to-git
迁移 这是一个相对简单的过程。首先下载快速导出(最好的方法是通过它的Git存储库,我将直接克隆到桌面),然后创建一个新的Git存储库,执行迁移,并签出HEAD。在命令行中,它是这样的:
cd ~/Desktop
git clone git://repo.or.cz/fast-export.git
git init git_repo
cd git_repo
~/Desktop/fast-export/hg-fast-export.sh -r /path/to/old/mercurial_repo
git checkout HEAD
在运行fast-export后迁移项目时,您应该看到一个长长的提交列表。如果您看到错误,它们可能与不正确指定的Python路径有关(请参阅上面的说明并为您的系统自定义)。 就这样,你完成了。
如果您想将现有的mercurial存储库导入到“GitHub”存储库中,现在只需使用这里提供的GitHub导入器[需要登录]。没有更多的混乱的快速导出等(虽然它是一个非常好的工具)
您将获得所有的提交、分支和标记。还有一件很酷的事情是,你还可以更改作者的电子邮件id。看看下面的截图:
您可以尝试使用快速导出:
cd ~
git clone https://github.com/frej/fast-export.git
git init git_repo
cd git_repo
~/fast-export/hg-fast-export.sh -r /path/to/old/mercurial_repo
git checkout HEAD
也来看看这个SO问题。
如果你使用的是4.6以下的Mercurial版本,adrihanu会支持你:
正如他在他的评论中所说:“如果你使用Mercurial < 4.6,你会得到' revsymbol not found '错误。你需要通过在~/fast-export目录下运行git checkout标签/v180317来更新你的Mercurial或降级快速导出。
这将是一个更好的评论,对不起,我没有评论权限。
@mar10评论是我需要这样做的缺失部分。
注意,'/path/to/old/ mercural_repo '必须是文件系统上的路径(而不是URL),因此您必须在此之前克隆原始存储库。- 13年12月27日3月10日16:30
这条评论是关于为我解决这个问题的答案https://stackoverflow.com/a/10710294/2148757,这与这里标记正确的答案https://stackoverflow.com/a/16037861/2148757相同
这将我们的hg项目移动到git,提交历史完整。
推荐文章
- 如何禁用Git凭证管理器的Windows?
- Git 拉取与 Git 变基
- 在git中压缩提交是什么意思?
- 在GIT中合并2个分支
- git标签也会被推送吗?
- 嵌套的Git存储库?
- Git bash错误:无法fork子进程:没有可用的终端(-1)
- 有没有办法在SourceTree中获得两个分支的视觉差异?
- Git标记是否只应用于当前分支?
- Git分支:master vs. origin/master vs. remotes/origin/master
- 如何根据文件扩展名过滤git差异?
- 如何设置一个git项目使用外部回购子模块?
- Git同时在两个分支上工作
- 如何在Visual Studio中删除未推送的外向提交?
- Git在两个不同的文件之间的差异