svn命令行创建和删除分支和tags
创建分支
- 创建一个分支
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
12
cd
branch
svn log --stop-on-copy
- 方法二:
12345
cd
trunk
svn -q --stop-on-copy 分支URL
#这条命令会查询出自创建分支以后分支上的所有修改,最下面的那个版本号就是我们要找的版本号.
#示例:
svn log -q --stop-on-copy svn:
//192
.168.1.177
/tags/beta_2009_12_24
- 方法一:最后一个r11340就是创建分支时的reversion
- 分支合并到主干
123456789101112
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
- 解决冲突:
1234567
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的更多相关文章
- svn 命令行创建和删除 分支和tags
创建分支 svn cp -m "create branch" http://svn_server/xxx_repository/trunk http://svn_server/xx ...
- mysql navicat 及命令行 创建、删除数据库
1.命令行创建数据库 create database mybatis default character set utf8 collate utf8_general_ci; drop database ...
- svn在linux下的使用(svn命令行)ubuntu 删除 新增 添加 提交 状态查询 恢复
合并步骤:(1)先切换到分支:(2)svn merge trunk . (3)svn sw trunk (4)svn merge --reintegrate branch . svn merge ht ...
- [SVN] svn在linux下的使用(svn命令行)ubuntu 删除 新增 添加 提交 状态查询 恢复
转载自:http://www.cnblogs.com/xulb597/archive/2012/07/18/2597311.html 合并步骤:(1)先切换到分支:(2)svn merge trunk ...
- svn命令行批量删除和批量添加
svn命令行批量删除和批量添加 如果使用svn的命令行,例如在linux下的终端中使用,svn的添加命令是svn add,删除命令是svn del,但是缺乏批量的操作,如果我在资源管理器中,手动添加了 ...
- Mac SVN 命令行
Mac自带了SVN命令行,如我的升级到10.10(OSX yosemite)后命令行版本为1.7.10 以下是一些常用命令 1.将文件checkout到本地目录 svn checkout path(p ...
- [MAC] Mac下的SVN命令行
转载自: http://www.cnblogs.com/snandy/p/4072857.html Mac自带了SVN命令行,如我的升级到10.10(OSX yosemite)后命令行版本为1.7.1 ...
- Linux环境SVN命令行使用经验总结(转)
在windows机器上开发得差不多了之后,打包传送到开发机编译,在开发机上解决编译错误. [缺点] 浪费时间在打包解包,机器间传输代码. 在windows机器上开发之后,check in代码进分支,在 ...
- 转:svn命令行操作
原文:http://zhumeng8337797.blog.163.com/blog/static/10076891420115218821912/SVN命令行 -- ::| 分类: CVS |字号 ...
随机推荐
- 第 14 章 结构和其他数据形式(names)
*--------------------------------- names1.c -- 使用指向结构的指针 ---------------------------------*/ #includ ...
- time模块案例演示
案例01: 2008年8月8日20:08:08 往后88,888,888秒是哪天?星期几? 日期->时间戳(浮点数)->可以做数学运算 演示: import time # 构造日期的元组, ...
- 使用SuperMap对接天地图
我们在做项目时,经常需要与天地图对接,对接形式分为2种: 1. 将公网天地图用作项目底图,在JavaScript客户端加载显示: 2. 将自己发布的WMTS地图服务给别人用,同时需要自己的服务能和天地 ...
- scrt中使用alt键
session Options-->Terminal---->Emulation------>Emacs----->Use ALT as meta key
- Kubernetes1.91(K8s)安装部署过程(一)--证书安装
安装前忠告:如果你用的是虚拟机,强烈不建议你使用克隆(链接克隆)的方式,至于完整克隆不知道有没有问题,每一台全新安装centos7系统最好. 一.安装前主题环境准备 1.docker安装 建议使用官网 ...
- [转]VS2013+简单稀疏光束调整库SSBA配置(64位编译)
有关SSBA库的资源比较少,我是在Github上搜索下载的,具体的GitHub官方下载地址为:SSBA 下载后在SSBA解压文件夹下新建文件夹build. 打开cmake gui,在source co ...
- C#游戏开发中精确的时间调配
方法一:参考<精通C#游戏编程>一书.根据学习WorldWind源码可知,WorldWind中采用的方法与该方法基本一致. using System; using System.Colle ...
- P2176 [USACO14FEB]路障Roadblock
题目描述 每天早晨,FJ从家中穿过农场走到牛棚.农场由 N 块农田组成,农田通过 M 条双向道路连接,每条路有一定长度.FJ 的房子在 1 号田,牛棚在 N 号田.没有两块田被多条道路连接,以适当的路 ...
- 2017-2018-2 20155224『网络对抗技术』Exp8:Web基础
实践具体要求 Web前端HTML(0.5分) 能正常安装.启停Apache.理解HTML,理解表单,理解GET与POST方法,编写一个含有表单的HTML. Web前端javascipt(0.5分) 理 ...
- 20155232《网络对抗》Exp 6 信息搜集与漏洞扫描
20155232<网络对抗>Exp 6 信息搜集与漏洞扫描 一.实践内容 (1)各种搜索技巧的应用 (2)DNS IP注册信息的查询 (3)基本的扫描技术:主机发现.端口扫描.OS及服务版 ...