svn diff 详解
UI版:




如果多人编辑同一段代码,常常容易出现冲突的情况:
如果出现冲突,我们如何解决他呢?
1 可以选择使用自己的文件mime file,也可以使用 他们的文件 their file
2 解决冲突, 而不是逃避。 在上图 Mergerd 部分直接编辑即可:

编辑完毕,然后 选择“Marked as resolved” 即可
其中红色块表示是冲突,是必须要处理的。如果不处理冲突,那么ctrl+s 会提示 :

出现unresolved conflicts,即

这个是必须解决的,否则 冲突会一直保留。 冲突解决完毕,下面的merged部分的红色会消失。 否则表示冲突没有解决,是无法执行 “mark as resolved”操作的。
圆圈表示空行,
— 表示左边的版本的内容
+ 表示右边的版本的内容
<=> 表示移动的内容, 这个其实没什么用
灰色部分表示原来是没有的。
(左边)褚红色的表示被修改的内容,—— 这里一定是修改而不是新增 ———— 这个只会出现在左边,也就是被修改的部分。
橘黄色的表示 空行或空的内容
黄色(或者不知道是否可以说是浅黄色)的表示 新增或修改的内容。 —— 没错, 这回包括了新增 和修改。
浅紫色表示 修改的行中, 没有发生变的部分 —— 新增的不会有浅紫色
白色, 当然表示没有发生任何变化的部分
红色: 表示冲突, 通常,左右两边都会出现红色。其他颜色是可以忽视的,但是红色必须正确处理,否则代码会保留冲突!!
总结, 除了黑色的字体颜色之外,
左边(原文件,或者说新文件) 可能出现的颜色有:
上面提及的颜色都可能出现
右边(新文件) 可能出现的颜色有:
白色
黄色 黄色,一律表示发生变化的内容, 以单词为单位(这里面的单词是java的变量名), 以 . , ; / ';" 为分隔符。
浅紫色
灰色
红色
可以看到, svn 的diff 功能其实是不完美的, 比较,常常出现不准确的情况, 比如
下面是 文本版diff 说明,参照 : http://www.xuebuyuan.com/2028115.html
在冲突解决一节结束后,我们的main.c文件的内容如下 #include <stdio.h>
#include "add.h"
#include "sub.h" int main()
{
printf("5 + 10 = %d.\n",add(,));
printf("15 - 10 = %d.\n",sub(,));
//kris's test
printf("kris: 12 + 28 = %d.\n",add(,));
//sally's test
printf("sally: 60 - 33 = %d.\n",sub(,));
return ;
}
下面,我们做一些修改,具体如下 #include <stdio.h>
#include "add.h"
#include "sub.h" int main()
{
printf("5 + 10 = %d.\n",add(,));
printf("15 - 10 = %d.\n",sub(,));
//kris's test
printf("kris: 32 + 28 = %d.\n",add(,));
printf("kris: 15 - 10 = %d.\n",sub(,));
//sally's test
printf("sally: 60 - 33 = %d.\n",sub(,));
return ;
}
修改完后,调用svn diff命令,会有如下的输出,下面就说说输出中各部分的意思。 root@letuknowit:/home/kris/calc/trunk# svn diff main.c
Index: main.c
===================================================================
--- main.c (revision )
+++ main.c (working copy)
@@ -, +, @@
printf("5 + 10 = %d.\n",add(,));
printf("15 - 10 = %d.\n",sub(,));
//kris's test
- printf("kris: 12 + 28 = %d.\n",add(,));
+ printf("kris: 32 + 28 = %d.\n",add(,));
+ printf("kris: 15 - 10 = %d.\n",sub(,));
//sally's test
printf("sally: 60 - 33 = %d.\n",sub(,));
return ;
Index: main.c svn diff可以查看当前工作拷贝中所有的被修改的文件,对于每个文件的diff输出部分由Index: 文件名的形式进行区分。
等于号后面的内容就是关于main.c文件的diff情况了。 --- main.c (revision )
+++ main.c (working copy)
---打头的是原始文件,也就是版本库中的最新版本,或者理解为修改前的文件
+++ 打头的是目标文件,这个就是你修改后的版本 @@ -, +, @@
这里的-和+分别表示原始文件和目标文件,,7表示从第7行开始的7行,-,7就是原始文件的从第7行开始的7行内容,+,8的意思类似,表示目标文件从第7行开始的8行内容。结合起来理解就是:
目标文件从第7行开始的8行内容和原始文件的从第7行开始的7行内容之间存在差异 printf("5 + 10 = %d.\n",add(,));
printf("15 - 10 = %d.\n",sub(,));
//kris's test
- printf("kris: 12 + 28 = %d.\n",add(,));
+ printf("kris: 32 + 28 = %d.\n",add(,));
+ printf("kris: 15 - 10 = %d.\n",sub(,));
//sally's test
printf("sally: 60 - 33 = %d.\n",sub(,));
return ;
这个就是具体的差异情况了,前面的-号表示需要从原始文件中删除的行,+号表示目标文件中将要增加的行,-号开头的部分只属于原始文件,+号开头的部分只属于目标文件,其余的是两者相同的部分。 printf("5 + 10 = %d.\n",add(,));
printf("15 - 10 = %d.\n",sub(,));
//kris's test
- printf("kris: 12 + 28 = %d.\n",add(,));
+ printf("kris: 32 + 28 = %d.\n",add(,));
+ printf("kris: 15 - 10 = %d.\n",sub(,));
//sally's test
printf("sally: 60 - 33 = %d.\n",sub(,));
return ;
为了进一步了解@@ -, +, @@的意思,上面加上了行号等信息,第一列的数字是行号,后面两列的数字表示第几行。经过标注可以清晰的看出原始文件第7行开始的7行和目标文件第7行开始的8行内容了。
svn diff 详解的更多相关文章
- svn merge详解
svn merge详解 [OK] http://blog.163.com/lgh_2002/blog/static/4401752620106202710487/ Subversion的分支通常用于在 ...
- 【山外笔记-SVN命令】svn命令详解
本文打印版文件下载地址 [山外笔记-SVN命令]svn命令详解-打印版.pdf 一.命令简介 svn命令用于Subversion命令行客户端,执行svn相关的操作. 二.命令语法 1.svn语法: ( ...
- SVN功能详解
SVN功能详解 TortoiseSVN是windows下其中一个非常优秀的SVN客户端工具.通过使用它,我们可以可视化的管理我们的版本库.不过由于它只是一个客户端,所以它不能对版本库进行权限管理. ...
- Linux SVN 命令详解
1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例如:svn checkout svn://192.168.1.1/pro/domain ...
- Linux SVN 命令详解(zz)
Linux下常用SVN命令 2012-04-02 11:46:00 标签:服务器 目录 Linux checkout linux系统 1.将文件checkout到本地目录 svn checkout p ...
- Linux下svn命令详解
本文主要是说明linux下svn命令的使用方法,同时记录自己在使用中遇到的一些疑惑. 1.Linux命令行下将文件checkout到本地目录 svn checkout url(url是服务器上的目录) ...
- SVN命令详解
在开发中,除了在本机文件夹上进行svn更新外,在命令行中进行svn操作也非常关键,下面列举下网站摘抄的一些文档:1.将文件checkout到本地目录 svn checkout path(path是服务 ...
- Linux SVN 操作详解(转)
1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例如:svn checkout svn://192.168.1.1/pro/domain ...
- SVN四部曲之SVN设置详解深入
想知道不同的设置是干什么用的,你只需将鼠标指针在编辑框/选项框上停留一秒钟...一个帮助提示气泡就会弹出来. 常规设置 图 4.68. 设置对话框,常规设置页面 这个对话框允许你指定自己喜欢的语言,同 ...
随机推荐
- ASP.NET Core应用的错误处理[2]:DeveloperExceptionPageMiddleware中间件如何呈现“开发者异常页面”
在<ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式>中,我们通过几个简单的实例演示了如何呈现一个错误页面,这些错误页面的呈现分别由三个对应的中间件来完成,接下来我们将 ...
- html与html5
HTML 是一种在 Web 上使用的通用标记语言.HTML 允许你格式化文本,添加图片,创建链接.输入表单.框架和表格等等,并可将之存为文本文件,浏览器即可读取和显示.HTML 的关键是标签,其作用是 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(55)-Web打印
系列目录 前言 1.本次主要弥补工作流,用户表单数据的打印 2.使用JQprint做为web打印插件 3.兼容:FireFox,Chrome,IE. 4.没有依赖也没有配置,使用简单 代码下载:htt ...
- Android消息传递之基于RxJava实现一个EventBus - RxBus
前言: 上篇文章学习了Android事件总线管理开源框架EventBus,EventBus的出现大大降低了开发成本以及开发难度,今天我们就利用目前大红大紫的RxJava来实现一下类似EventBus事 ...
- 免费高效实用的.NET操作Excel组件NPOI(.NET组件介绍之六)
很多的软件项目几乎都包含着对文档的操作,前面已经介绍过两款操作文档的组件,现在介绍一款文档操作的组件NPOI. NPOI可以生成没有安装在您的服务器上的Microsoft Office套件的Excel ...
- [Nginx笔记]关于线上环境CLOSE_WAIT和TIME_WAIT过高
运维的同学和Team里面的一个同学分别遇到过Nginx在线上环境使用中会遇到TIME_WAIT过高或者CLOSE_WAIT过高的状态 先从原因分析一下为什么,问题就迎刃而解了. 首先是TIME_WAI ...
- Entity Framework 延伸系列目录
1.采用MiniProfiler监控EF与.NET MVC项目 2.采用EntityFramework.Extended 对EF进行扩展 3.EntityFramework执行存储过程中遇到的那些坑 ...
- bzoj3932--可持久化线段树
题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...
- Lucene4.4.0 开发之排序
排序是对于全文检索来言是一个必不可少的功能,在实际运用中,排序功能能在某些时候给我们带来很大的方便,比如在淘宝,京东等一些电商网站我们可能通过排序来快速找到价格最便宜的商品,或者通过排序来找到评论数最 ...
- LINQ to SQL语句(7)之Exists/In/Any/All/Contains
适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...