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. 设置对话框,常规设置页面 这个对话框允许你指定自己喜欢的语言,同 ...
随机推荐
- 百度MIP页规范详解 —— canonical标签
百度MIP的规范要求必须添加强制性标签canonical,不然MIP校验工具会报错: 强制性标签<link rel="/^(canonical)$/"> 缺失或错误 这 ...
- Hive安装配置指北(含Hive Metastore详解)
个人主页: http://www.linbingdong.com 本文介绍Hive安装配置的整个过程,包括MySQL.Hive及Metastore的安装配置,并分析了Metastore三种配置方式的区 ...
- 在Visual Studio Code中配置GO开发环境
一.GO语言安装 详情查看:GO语言下载.安装.配置 二.GoLang插件介绍 对于Visual Studio Code开发工具,有一款优秀的GoLang插件,它的主页为:https://github ...
- 使用JavaScript为一张图片设置备选路径
在做网页开发的时候,有时候希望给图片设置一个备选路径,即,当src属性对应的主路径加载失败的时候,图片可以马上切换到备选路径.这样,即使主路径失效了,显示备用路径也不会影响网页的正常体验. 注意到网页 ...
- 浏览器的兼容模式下的button中文字垂直方向不居中显示
<button style="cursor:pointer;vertical-align: middle;" >删除</button> 这时候垂直不居中. ...
- Windows下MySQL无法启动
问题描述: 从网上下了5.7 的MySQL,在bin目录下执行 start mysqld ,弹出个cmd窗口一闪就没了,也看不清是什么报错.mysqld --install安装了服务,也启动不了. ...
- 跟着老男孩教育学Python开发【第二篇】:Python基本数据类型
运算符 设定:a=10,b=20 . 算数运算 2.比较运算 3.赋值运算 4.逻辑运算 5.成员运算 基本数据类型 1.数字 int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**3 ...
- 邻接表的广度优先遍历(java版)
到 0 的权是 91 到 2 的权是 31 到 3 的权是 61 到 4 的权是 7 2 到 0 的权是 22 到 3 的权是 5 3 到 0 的权是 33 到 4 的权是 1 4 到 2 的权是 2 ...
- Struts框架的核心业务
Struts的核心业务 Struts核心业务有很多,这里主要介绍了比较简单一些的: 请求数据的处理,和数据自动封装,类型自动转换 1.Struts中数据处理 1.1.方式1:直接过去servletap ...
- 【repost】JS中的异常处理方法分享
我们在编写js过程中,难免会遇到一些代码错误问题,需要找出来,有些时候怕因为js问题导致用户体验差,这里给出一些解决方法 js容错语句,就是js出错也不提示错误(防止浏览器右下角有个黄色的三角符号,要 ...