Git与SVN交叉使用

栏目: 编程工具 · 发布时间: 6年前

内容简介:行:

博客分类: FAQ

将本地git项目添加到远程svn中

  • git svn [svnprojpath]
    • svnprojpath为原创svn项目路径 —— 文件夹路径,你要放到哪个文件夹
    • 官方文档中带有-s参数,但我这边加了会有问题,可能是非标准的问题。
  • git svn fetch
    • 此处可能会提示错误警告 —— 忽略,它只是在检测一些历史,不影响
    • git branch -a 看一下分支 —— 单纯看看
  • git svn dcommit
    • 问题1:本地还有未提交的更改 —— git commit 提交下
    • 问题2:head历史没有上游svn信息 —— 为其添加父级信息
      • git show-ref —— 记录下remote/git-svn的commit值,其实是远程项目分支的最后一次commit值[parentcommit]
      • git log --pretty=oneline master —— 记录下第一次commit值[localfirstcommit]
      • git replace --graft [localfirstcommit] [parentcommit] —— 设置父级commit【以前是用.git/info/grafts文件,不过git后期版本会删除这个处理】
    • 问题3:本地修改删除的文件夹,svn上会保留空文件夹 —— 添加选项设置--rmdir
      • 实在没办法删除空文件夹,可以在svn服务上删掉后,本地git svn rebase。
      • 需要原来文件夹中存在内容,然后删除内部文件及文件夹时,--rmdir才会生效,以前的空文件夹时不会自动删除 —— 这个可能也是为了保证svn可以添加空文件夹。
  • .gitignore处理
    • git svn show-ignore > ./git/info/exclude —— 这个好像是针对有svn忽略处理的情况,我们可以忽略这一步
    • 将本地.gitignore文件里的内容添加到./git/info/exclude中 —— 具体配置内容可以网络上,或者如我一样直接使用visual studio自动生成的配置内容
    • 删除本地的.gitignore文件 ——这样避免svn项目中含有.gitignore文件
  • git svn rebase
    • 拉取最新项目
    • 建议每次commit之前拉取最新内容

用git管理远程svn仓库

  • git svn clone [svnprojpath]
    • [svnprojpath]为项目远程路径
  • 之后的操作同上,注意处理.gitignore文件

参考:

行: 奇葩史


以上所述就是小编给大家介绍的《Git与SVN交叉使用》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

腾讯之道

腾讯之道

艾永亮、刘官华、梁璐 / 机械工业出版社 / 2016-7-19 / 59

放眼整个中国乃至全球,腾讯都是一家成功的互联网企业,它代表中国企业在世界互联网版图中竖起了一面高高的旗帜。腾讯为何能取得如此大的成就,它的成功方法和商业逻辑是什么?你是不是和无数中国企业和商界人士一样,都想向腾讯取取经,但是又不得其门而入? 腾讯一直以低调、务实著称,所 以腾讯及其内部员工都极少对外界分享他们的经验;加之腾讯的商业模式多元、业务繁多且交叉、体量又极其庞大,使得从外部来系统研究......一起来看看 《腾讯之道》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具