目录

创建分支

  • 创建一个分支

    1
    svn copy svn://xx.com/repo/trunk svn://xx.com/repo/branches/TRY-something -m 'make branches TRY-something'
  • 把工作目录转到分支

    1
    svn switch svn://xx.com/repo/branches/TRY-something

当然,也可以再转到主干: svn switch svn://xx.com/repo/trunk

合并一个分支到主干

一旦分支上的开发结束,分支上的代码需要合并到主干。SVN中执行该操作需要在trunk的工作目录下进行。

  • 查找到分支版本

    • 方法一:最后一个r11340就是创建分支时的reversion

      1
      2
      cd branch
      svn log --stop-on-copy
    • 方法二:
      1
      2
      3
      4
      5
      cd trunk
      svn -q --stop-on-copy 分支URL #这条命令会查询出自创建分支以后分支上的所有修改,最下面的那个版本号就是我们要找的版本号.
       
      #示例:
      svn log -q --stop-on-copy svn://192.168.1.177/tags/beta_2009_12_24
  • 分支合并到主干

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    svn merge -r 分支版本号:HEAD 分支的URL   #HEAD为当前主干上的最新版本
     
    #示例:
    cd trunk
    svn merge -r 12:HEAD svn://192.168.1.177/tags/beta_2009_12_24
     
    cd trunk
    svn merge --reintegrate http://svn_server/xxx_repository/branches/br_feature001
    # 分支合并到主干中完成后应当删该分支,因为在SVN中该分支已经不能进行刷新也不能合并到主干。
     
    # 合并版本并将合并后的结果应用到现有的分支上
    svn -r 148:149 merge http://svn_server/xxx_repository/trunk
  • 解决冲突:

    1
    2
    3
    4
    5
    6
    7
    svn st | grep ^C      # 查找合并时的冲突文件,手工解决冲突
    svn resolved filename # 告知svn冲突已解决
    svn commit -m ""      # 提示合并后的版本
     
    svn: Aborting commit: '/path/resources/noc' remains in conflict
    $ svn revert resources/noc
    Reverted 'resources/noc'

两个分支合并

两个分支合并可以拆分为一下两步:

  • 第一步:

197从旧主干引出,186打完tag,表示是新主干

合并最新代码的意思是:将新主干与旧主干比对,并添加到197中。这样197既有自己的新增的代码,也同时有最新线上的代码。

1
2
3
cd 197_Branch
svn merge https://xxx.com/tags/project/project_Old_BL https://xxx.com/tags/project/project_New_BL
svn ci -m 'merge 186 trunk'
  • 第二步:

但是后来,其他人又向186提了代码,所以还需要将186分支(即打了tag后的186,打了tag前的186已是主干)合并至197中。

合并办法:找出186分支,比对与新主干之间的差别,并添加到197中。这样197就有最新的全部代码了。

1
2
3
cd 197_Branch
svn merge https://xxx.com/tags/project/project_New_BL https:/xxx.com/project/branches/project/186_Branch
svn ci -m 'merge 186 branch'

合并主干上的最新代码到分支上

1
2
3
4
5
6
7
cd br_feature001
svn merge http://svn_server/xxx_repository/trunk
 
# 如果需要预览该刷新操作,可以使用svn mergeinfo命令,如:
svn mergeinfo http://svn_server/xxx_repository/trunk --show-revs eligible
 
# 或使用`svn merge --dry-run`选项以获取更为详尽的信息。

发布

产品开发已经基本完成,并且通过很严格的测试,这时候我们就想发布给客户使用,发布我们的1.0版本。

给当前主干打个标签,并且这个标签不再改动了,但是实际上标签和分支是一个意思,你可以在标签上继续做改动,但这不推荐。

1
2
3
4
5
6
7
# 建立tags
svn copy svn://xx.com/repo/trunk svn://xx.com/repo/tags/RB-1.0
svn copy http://svn_server/xxx_repository/trunk http://svn_server/xxx_repository/tags/release-1.0 -m "1.0 released"
 
# 删除分支或tags
svn rm http://svn_server/xxx_repository/branches/br_feature001
svn rm http://svn_server/xxx_repository/tags/release-1.0
 
 

创建分支

svn cp -m "create branch" http://svn_server/xxx_repository/trunk http://svn_server/xxx_repository/branches/br_feature001
  • 1
  • 2
  • 1
  • 2

获得分支

svn co http://svn_server/xxx_repository/branches/br_feature001 
  • 1
  • 1

合并主干上的最新代码到分支上

cd br_feature001
svn merge http://svn_server/xxx_repository/trunk
  • 1
  • 2
  • 1
  • 2

如果需要预览该刷新操作,可以使用svn mergeinfo命令,如

svn mergeinfo http://svn_server/xxx_repository/trunk --show-revs eligible
  • 1
  • 2
  • 1
  • 2

或使用svn merge –dry-run选项以获取更为详尽的信息。

分支合并到主干 
一旦分支上的开发结束,分支上的代码需要合并到主干。SVN中执行该操作需要在trunk的工作目录下进行。命令如下:

cd trunk
svn merge --reintegrate http://svn_server/xxx_repository/branches/br_feature001
  • 1
  • 2
  • 1
  • 2

分支合并到主干中完成后应当删该分支,因为在SVN中该分支已经不能进行刷新也不能合并到主干。

合并版本并将合并后的结果应用到现有的分支上

svn -r 148:149 merge http://svn_server/xxx_repository/trunk

svn命令行创建和删除分支和tags的更多相关文章

  1. svn 命令行创建和删除 分支和tags

    创建分支 svn cp -m "create branch" http://svn_server/xxx_repository/trunk http://svn_server/xx ...

  2. mysql navicat 及命令行 创建、删除数据库

    1.命令行创建数据库 create database mybatis default character set utf8 collate utf8_general_ci; drop database ...

  3. svn在linux下的使用(svn命令行)ubuntu 删除 新增 添加 提交 状态查询 恢复

    合并步骤:(1)先切换到分支:(2)svn merge trunk . (3)svn sw trunk (4)svn merge --reintegrate branch . svn merge ht ...

  4. [SVN] svn在linux下的使用(svn命令行)ubuntu 删除 新增 添加 提交 状态查询 恢复

    转载自:http://www.cnblogs.com/xulb597/archive/2012/07/18/2597311.html 合并步骤:(1)先切换到分支:(2)svn merge trunk ...

  5. svn命令行批量删除和批量添加

    svn命令行批量删除和批量添加 如果使用svn的命令行,例如在linux下的终端中使用,svn的添加命令是svn add,删除命令是svn del,但是缺乏批量的操作,如果我在资源管理器中,手动添加了 ...

  6. Mac SVN 命令行

    Mac自带了SVN命令行,如我的升级到10.10(OSX yosemite)后命令行版本为1.7.10 以下是一些常用命令 1.将文件checkout到本地目录 svn checkout path(p ...

  7. [MAC] Mac下的SVN命令行

    转载自: http://www.cnblogs.com/snandy/p/4072857.html Mac自带了SVN命令行,如我的升级到10.10(OSX yosemite)后命令行版本为1.7.1 ...

  8. Linux环境SVN命令行使用经验总结(转)

    在windows机器上开发得差不多了之后,打包传送到开发机编译,在开发机上解决编译错误. [缺点] 浪费时间在打包解包,机器间传输代码. 在windows机器上开发之后,check in代码进分支,在 ...

  9. 转:svn命令行操作

    原文:http://zhumeng8337797.blog.163.com/blog/static/10076891420115218821912/SVN命令行 -- ::| 分类: CVS |字号 ...

随机推荐

  1. 8、Django的模型层(2)

    第3节:多表操作 3.1 创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作 ...

  2. MySql详解(一)

    MySql详解(一) 作为一名Java开发人员,数据库的地位不用多说了.从大学时期的SqlServer,到现在最流行的MySql和Oracle.前者随着阿里巴巴的去IOE化,在互联网公司中的使用比例是 ...

  3. Common lang一些边界方法总结(好记性不如烂笔头,需要慢慢积累).一定要利用好现有的轮子,例如Apache common与Google Guava

    好记性真是不如烂笔头啊!!!! 如下代码: List<String> list = new ArrayList<String>(); list.add("1" ...

  4. Spring 加载Controller逻辑的源码笔记

    org.springframework.web.servlet.handler.AbstractHandlerMethodMapping#initHandlerMethods 进行加载Controll ...

  5. 把php session 会话保存到redis

    php的session会话默认时以文件形式保存在php.ini配置文件设置的会话缓存目录,文件保存会话的效率很低,每当每个用户登录一次就会在服务器上生成一个唯一的session_id文件,当用户登录量 ...

  6. metamask-iframe-stream,没成功

    https://github.com/kumavis/iframe-stream/blob/master/test/rebundle.js iframe-stream-其实就是将iframe打包成流 ...

  7. C#游戏开发中精确的时间调配

    方法一:参考<精通C#游戏编程>一书.根据学习WorldWind源码可知,WorldWind中采用的方法与该方法基本一致. using System; using System.Colle ...

  8. linux iostat 性能指标说明(转)

    iostat属于sysstat软件包.可以用yum install sysstat 直接安装. 备注: 如果%iowait的值过高,表示硬盘存在I/O瓶颈, %idle值高,表示CPU较空闲, 如果% ...

  9. SVD(奇异值分解)Python实现

    注:在<SVD(奇异值分解)小结 >中分享了SVD原理,但其中只是利用了numpy.linalg.svd函数应用了它,并没有提到如何自己编写代码实现它,在这里,我再分享一下如何自已写一个S ...

  10. 【arm学习】我的第一个裸板程序

    初学ARM感觉写个裸板程序还真的不容易,可能是没有用到ADS,keil之类的开发平台的缘故吧.编译,链接过程在linux平台上完成,这样学起来更有实感,还能顺便熟悉linux环境,以及命令,何乐而不为 ...