我需要将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,提交历史完整。
其他回答
您可以尝试使用快速导出:
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或降级快速导出。
好吧,我终于算出来了。这是在Windows上使用TortoiseHg。如果你不使用它,你可以在命令行上做。
安装TortoiseHg 右键单击资源管理器中的空白区域,然后进入TortoiseHg设置:
启用hggit:
打开命令行,输入一个空目录。 git init——bare .git(如果你不使用bare repo,你会得到一个类似abort: git remote error: refs/heads/master failed to update的错误 cd到您的Mercurial存储库。 Hg书签Hg Hg push c:/path/to/your/git/repo 在Git目录下:Git config——bool core。)别问我为什么。关于“工作树”。Git非常不友好。我发誓写实际代码要比使用Git简单。)
希望它会工作,然后你可以从新的git回购推到一个非裸的。
来自:
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路径有关(请参阅上面的说明并为您的系统自定义)。 就这样,你完成了。
这将是一个更好的评论,对不起,我没有评论权限。
@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,提交历史完整。
如果您想将现有的mercurial存储库导入到“GitHub”存储库中,现在只需使用这里提供的GitHub导入器[需要登录]。没有更多的混乱的快速导出等(虽然它是一个非常好的工具)
您将获得所有的提交、分支和标记。还有一件很酷的事情是,你还可以更改作者的电子邮件id。看看下面的截图:
推荐文章
- Github:导入上游分支到fork
- Mercurial:我可以重命名分支吗?
- Git单次修订的日志
- Git在不改变提交时间戳的情况下进行改基
- VS 2017 Git本地提交数据库。每次提交时锁定错误
- 如何在过去的一些任意提交之间注入一个提交?
- 从GitHub克隆项目后拉git子模块
- GitHub上的分叉和克隆有什么区别?
- 递归地按模式添加文件
- 我如何使用notepad++(或其他)与msysgit?
- 如何将现有的解决方案从Visual Studio 2013添加到GitHub
- Git存储库中的悬垂提交和blob是什么?它们来自哪里?
- 我如何简单地从我最新的git提交创建一个补丁?
- Git显示“警告:永久添加到已知主机列表”
- 我如何检索一个回购的远程git地址?