我需要将mercurial项目转换为git项目,但我想保持提交历史完整。我目前的解决方案是删除hg相关文件,然后git init &&手动添加我需要的文件,但这不会保留历史。有什么解决办法吗?
当前回答
这将是一个更好的评论,对不起,我没有评论权限。
@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,提交历史完整。
其他回答
这将是一个更好的评论,对不起,我没有评论权限。
@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,提交历史完整。
您可以尝试使用快速导出:
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或降级快速导出。
来自:
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路径有关(请参阅上面的说明并为您的系统自定义)。 就这样,你完成了。
另一种选择是创建一个免费的Kiln帐户——在git和hg之间往返,保留100%的元数据,这样您就可以使用它进行一次性转换,或者使用它访问存储库,使用任何您喜欢的客户端。
如果您想将现有的mercurial存储库导入到“GitHub”存储库中,现在只需使用这里提供的GitHub导入器[需要登录]。没有更多的混乱的快速导出等(虽然它是一个非常好的工具)
您将获得所有的提交、分支和标记。还有一件很酷的事情是,你还可以更改作者的电子邮件id。看看下面的截图:
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- 在TortoiseHg储存密码
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式