经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 软件/图像 » Git » 查看文章
Git与SVN交叉使用
来源:cnblogs  作者:奇葩史  时间:2018/10/8 8:48:28  对本文有异议

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

  • git svn [svnprojpath]

    • svnprojpath为原创svn项目路径 —— 文件夹路径,你要放到哪个文件夹

    • 官方文档中带有-s参数,但我这边加了会有问题,可能是非标准的问题。

  • git svn fetch

    • 此处可能会提示错误警告 —— 忽略,它只是在检测一些历史,不影响

    • git branch -a 看一下分支 —— 单纯看看

  • git svn dcommit

    • 实在没办法删除空文件夹,可以在svn服务上删掉后,本地git svn rebase。

    • 需要原来文件夹中存在内容,然后删除内部文件及文件夹时,--rmdir才会生效,以前的空文件夹时不会自动删除 —— 这个可能也是为了保证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后期版本会删除这个处理】

    • 问题1:本地还有未提交的更改 —— git commit 提交下

    • 问题2:head历史没有上游svn信息 —— 为其添加父级信息

    • 问题3:本地修改删除的文件夹,svn上会保留空文件夹 —— 添加选项设置--rmdir

    • .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文件

    参考:

    行:奇葩史

     友情链接:直通硅谷  点职佳  北美留学生论坛

    本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

    W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
    关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
    皖ICP备17017327号-2 皖公网安备34020702000426号