来源:segmentfault 不管是软件工程师,还是硬件工程师,基本都会牵涉到版本管理的问题。市面上版本管理的工具很多,但大家最熟悉的可能还是Svn和Git了。 以前很多工程师都习惯使用SVN,随着Git工具的逐渐成熟和强大,很多公司就开始转移使用Git了。。。 本文分享一篇“实操 Svn 迁移到 Git”,来源: 导出 svn 工程首先,我们需要 $ sudo yum install git-svn 原理上,就是使用
那么我们只是将主分支及其 log 取到了本地,但是其他的分支并没有。如果要把所有的分支都 checkout 出来的话,需要用到 需要注意的有三点:
于是,对应我们的实际情况,git-svn 命令是这样的: git svn clone http://rdsvn./some_mid_path/ \ # 注意这里并没有把主分支的路径写完整 稍等一会儿,就可以看到整个 svn 的主分支及分支都被导出来了,一颗赛艇! 分支处理执行
这几个分支都被视为 Git 的远程分支,你的本地仓库暂时是空的。可以使用 讲道理,svn 上的分支命名和 git 上的分支命名规则未必是一致的,因此这个时候你会想要重新命名分支。我的建议是这么操作:
上传到 git 服务器首先要在 git 服务器上创建一个空的工程,比如 “git@rdgit./some_mid_path/some_group/firmware.git” 然后在本地仓库中执行: git remote add origin git@rdgit./some_mid_path/some_group/firmware.git 然后将主分支上传:
其他的分支也是利用这个语句创建新分支上传。 完成之后,在 git 服务器上就可以看到完整的 change log 以及分支变化情况啦。 关于空目录其实迁移的时候还需要注意一个问题,那就是 svn 支持空目录的版本控制,但是 git 不支持。 导出 svn 之后,最好对比一下原始的 svn 工程内是否有空目录。如果有,那么你需要手工(或者写脚本)在导出的 git 工程中创建这些目录,并且在目录中建立一个 “ |
|
来自: 西北望msm66g9f > 《编程》