SVN与TortoiseSVN实战:补丁详解
硬广:《SVN与TortoiseSVN实战》系列已经写了五篇,第二篇《SVN与TortoiseSVN实战:标签与分支》和第三篇《SVN与TortoiseSVN实战:TortoiseSVN新建及合并分支》重点介绍了标签和分支的概念及实际操作演示,关注人数较多,三、四篇《SVN与TortoiseSVN实战:冲突详解(二)》详解了SVN如何判定冲突及冲突文件说明和解决冲突方法。
本篇详细SVN中补丁的概念,版本控制之道这本书对于SVN的讲解比较全面了,但书中也没有讲解补丁的概念,关于SVN补丁的介绍也寥寥无几。
其实学习和掌握补丁的用法后,在某些项目环境中还是有用武之地的,主要讲以下两点:
1、SVN补丁的概念;
2、SVN补丁的应用场景;
3、SVN补丁的制作及应用;
感谢博友的建议,在每篇前写明本篇所要讲述的重点 ~。~
1、SVN补丁的概念
SVN补丁其实并不神秘,只是平时工作中接触较少。
SVN补丁可以理解为一个patch格式的文件,这个patch格式文件可以忠实记录文件变动,而这个patch文件是根据SVN中文件的修改制作的。

Create patch和Apply patch就是创建和应用补丁,至于Properties为什么在这一组会在属性篇中讲,TortoiseSVN菜单的分组划分是很有设计哲学的,没事时可以仔细研究下。
2、SVN补丁的应用场景(一)
第一种场景看下这两张图:


图一的方式可以用之前讲的主干/分支来解决,每次修改主线版的内容通过合并的方式将修改合并到定制版中,这种方式需要在每个定制版中合并,人工每次操作非常麻烦,还容易出错。
图二是使用补丁的方式,主线版修改后创建补丁,在所有定制版中统一应用一次补丁,其目录结构如下:

patches下是所有定制版的项目目录,这样划分可以在整个patches目录上应用一次补丁,大大简化了操作。
2、SVN补丁的应用场景(二)
还有一种是涉及到权限的应用,将某些项目组的成员配置成只有读权限,而没有写权限。
这些只读权限的成员不能直接提交修改,而需要将修改制作成补丁,发给具有写权限的成员,审核通过后应用补丁,提交到SVN中。
这也是基于SVN的一种权限管理,熟悉Git的应该会比较理解。
3、SVN补丁的制作及应用(一)
最简单的方法是基于修改的文件直接创建补丁,在将本地文件修改后,在签入SVN之前(叹号标记时),选中文件,使用TortoiseSVN的Create patch菜单可以直接将文件的修改创建为patch格式的补丁文件:

3、SVN补丁的制作及应用(二)
还有一种方式可以基于已签入的改动来创建补丁,这种方式甚至可以创建降级补丁。
在主干目录上使用TortoiseSVN的Show Log菜单,用Ctrl选中两个版本,右键使用图中标记的菜单:

新窗口中使用File Save存为补丁即可。
补丁的应用非常简单了,就不演示了,选中应用位置使用Apply patch菜单选择应用的补丁即可。
记录,为更好的自己!
SVN与TortoiseSVN实战:补丁详解的更多相关文章
- SVN与TortoiseSVN实战:补丁详解(转)
硬广:<SVN与TortoiseSVN实战>系列已经写了五篇,第二篇<SVN与TortoiseSVN实战:标签与分支>和第三篇<SVN与TortoiseSVN实战:Tor ...
- SVN与TortoiseSVN实战:文件加锁详解
硬广:<SVN与TortoiseSVN实战>系列已经写了八篇,本篇是完结篇,整个系列结合TortoiseSVN对SVN中容易被忽视的部分进行了详解,以技巧性为主. 本篇详解使用Tortoi ...
- SVN与TortoiseSVN实战:冲突详解(二)
硬广:<SVN与TortoiseSVN实战>系列已经写了四篇,第二篇<SVN与TortoiseSVN实战:标签与分支>和第三篇<SVN与TortoiseSVN实战:Tor ...
- SVN与TortoiseSVN实战:冲突详解(一)
硬广:<SVN与TortoiseSVN实战>系列已经写了三篇,第一篇<SVN与TortoiseSVN实战:从入门到精通>,第二篇<SVN与TortoiseSVN实战:标签 ...
- SVN与TortoiseSVN实战:属性的奇技淫巧(一)
硬广:<SVN与TortoiseSVN实战>系列已经写了六篇,本系列结合TortoiseSVN对SVN中容易被忽视的部分进行了详解,预计再用三.四篇来结束这个系列. 本篇详解一下SVN的属 ...
- SVN与TortoiseSVN实战:属性的奇技淫巧(二)
硬广:<SVN与TortoiseSVN实战>系列已经写了七篇,本系列结合TortoiseSVN对SVN中容易被忽视的部分进行了详解. 关于属性的奇技淫巧较多,分为两篇来写,第一篇详见< ...
- ARP缓存表的构成ARP协议全面实战协议详解、攻击与防御
ARP缓存表的构成ARP协议全面实战协议详解.攻击与防御 1.4.3 ARP缓存表的构成 在局域网的任何一台主机中,都有一个ARP缓存表.该缓存表中保存中多个ARP条目.每个ARP条目都是由一个IP ...
- SVN与TortoiseSVN实战:TortoiseSVN新建及合并分支
硬广:<SVN与TortoiseSVN实战>系列已经写了两篇,第一篇<SVN与TortoiseSVN实战:从入门到精通>,关于分支和标签的知识介绍可翻阅第二篇<SVN与T ...
- SVN与TortoiseSVN实战:标签与分支
最近在写<IOS性能调优系列>,今天偷个懒,写写SVN与TortoiseSVN实战的第二篇,标签与分支. 第一篇详见<SVN与TortoiseSVN实战:从入门到精通> SVN ...
随机推荐
- Going Home (hdu 1533 最小费用流)
集训的图论都快结束了,我才看懂了最小费用流,惭愧啊. = = 但是今天机械键盘到了,有弄好了自行车,好高兴\(^o^)/~ 其实也不是看懂,就会套个模板而已.... 这题最重要的就是一个: 多组输入一 ...
- suibi
测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等. 我所了解的模块接口测试大体分为两类:模块接口测试和web接口测试 模块接口测试是单元测试的基础.它主要测试模块的调用 ...
- ICANN认证企业列表
查询地址: http://www.internic.net/alpha.html
- Eclipse "IOConsole updater" has encounter a problem
因为调试方便,把eclipse里的控制台输出调整为无限制了,结果各种log打了一夜居然把堆内存打爆了. 还是改回去吧. 在日志输出的状态下(貌似没日志的时候没法选)右键console的内容区域 -&g ...
- ylbtech-LanguageSamples-XMLdoc
ylbtech-Microsoft-CSharpSamples:ylbtech-LanguageSamples-XMLdoc 1.A,示例(Sample) 返回顶部 “XML 文档”示例 本示例演示如 ...
- Mac 终端常用命令备忘
Tab 补全 pwd 显示路径 一 .ls ls -lh 查看当前路径详细文件 ls .. 返回上级目录 ls -a 显示隐藏文件 ls -a -l 以详细列表显示 ls ../../ ...
- mysql 非安装版本就可以用, 用于打包用
http://blog.csdn.net/iihero/article/details/5596401 http://blog.csdn.net/iihero/article/details/5596 ...
- 安装LINUX X86-64的10201出现链接ins_ctx.mk错误-转自yingtingkun
详细错误信息为: Error in invoking target ‘install’ of makefile ‘/opt/oracle/product/10.2/ctx/lib/ins_ctx.mk ...
- memcpy、memmove、memset
void * memcpy(void * dst, const void * src, size_t count) { void *res=dst; while (count--) { *(char* ...
- 【原】Nginx添加Content-MD5头部压测分析
如需转载,必须注明原文地址,请尊重作者劳动成果. http://www.cnblogs.com/lyongerr/p/5048464.html 本文介绍了webbenck安装,但是最后使用的是ab工具 ...