svn/git的diff、patch
svn/git的diff、patch
前几天,正当我突突的写代码,企业微信嘀嘀一声响”在不,过来帮我看个bug”。本人一向助人为乐,高兴的冲了过去,然后就开始了一段长达1分钟的问题描述。很明显,此同学只知道结果不对,并没有找出程序的根本问题。
好吧,心凉了一半,果然是找我来干体力活的。坐定,抬手开始调试代码。。。
调试开始,打开编辑器,什么,竟然用的大型IDE,好吧,忍了,卡死了。刚写好一句代码,准备按ctrl+B运行,没反应,再按,依然没反应,好吧,看来这兄弟啥也没配置。刚想打开终端,想想算了,估计环境变量也没有加。再有就是,毕业这么多年,不管是家用还是办公,用到的只有mac和Linux,今天这windows系统,难道要在这阴沟里坏了一世英明。默默的打开windows终端,输入svn info,哇,svn竟然默认加了进来,好吧,有办法了。。。
~ cd /projectdir #进入项目根目录
~ svn diff > test.diff #将同学的修改生成diff文件
通过企微把test.diff发到我的帐号,一共几十KB。然后就告别了该同学,并告诉他我一会回来,不要乱动。终于回到了我的电脑,接收test.diff文件,然后打开熟悉的终端:
~ cd /projectdir # 进入项目根目录
~ svn up # 更新到最新版本
~ svn st # 查看我本机是否有未提交的代码。输出是空,果然所有代码都提交过了
~ patch -p0 < /patch/test.diff # 应用diff文件
此时,我的代码已经跟刚才那位同学一模一样了,好吧,突突的调试代码,很快,问题找到、解决。
现在来总结一下,一共使用了两条命令:
- svn diff > test.diff # 作用是生成diff文件
- patch -p0 < /patch/test.diff # 将diff文件应用到我的代码
好吧,现在问题已经解决了,那么接下来我是应该直接提交代码到版本库呢,还是怎么办。经常长达10余秒的思考,好吧,应该把代码还给那位同学。
再次,在我的项目根目录执行 svn diff > ok.diff,将ok.diff通过企微传给同学。然后迅速跑到同学工位,清空他本地的代码修改,应用ok.diff文件,提交代码到版本库
~ cd /projectdir # 进入项目根目录
~ svn revert * --depth=infinity # 清空他本地的修改
~ svn up # 更新svn (习惯性操作)
~ svn st # 查看当前状态 (习惯性操作)
~ patch -p0 < /patch/ok.diff # 应用diff文件
~ svn diff # 再次查看修改的内容 (习惯性操作)
~ svn ci -m "完成**功能"
终于,收工!
svn/git的diff、patch的更多相关文章
- git diff patch方法
UNIX世界的软件开发大多都是协作式的,因此,Patch(补丁)是一个相当重要的东西,因为几乎所有的大型UNIX项目的普通贡献者,都是通过 Patch来提交代码的.作为最重要的开源项目之一,Linux ...
- Linux diff patch
/***************************************************************************** * Linux diff patch * ...
- 关于git的打patch的功能
UNIX世界的软件开发大多都是协作式的,因此,Patch(补丁)是一个相当重要的东西,因为几乎所有的大型UNIX项目的普通贡献者,都是通过 Patch来提交代码的.作为最重要的开源项目之一,Linux ...
- Linux之旅(1): diff, patch和quilt (下)
Linux之旅(1): diff, patch和quilt (下) 2 quilt 我们自己的项目能够用cvs或svn管理所有代码.但有时我们要使用其它开发人员维护的项目.我们须要改动一些文件,但又不 ...
- Linux游(1): diff, patch和quilt (下一个)
Linux游(1): diff, patch和quilt (下一个) 2 quilt 我们自己的项目可以用cvs或svn管理所有代码.但有时我们要使用其它开发人员维护的项目.我们须要改动一些文件.但又 ...
- 如何用git命令生成Patch和打Patch
在程序员的日常开发与合作过程中,对于code的生成patch和打patch(应用patch)成为经常需要做的事情.什么是patch?简单来讲,patch中存储的是你对代码的修改,生成patch就是记录 ...
- 十分钟掌握diff&patch用法
作为程序员,了解diff&patch命令是非常必要的.比如说我们发现某个项目有bug代码,而自己又没有svn的提交权限,那么此时最合适的解决方法就是用diff命令做一个补丁发给项目成员.项目成 ...
- git -c diff.mnemonicprefix=false -c core.quotepath=false -c credential.helper=sourcetree fetch origin
git -c diff.mnemonicprefix=false -c core.quotepath=false -c credential.helper=sourcetree fetch origi ...
- SVN/GIT源代码泄露
造成SVN源代码漏洞的主要原因是管理员操作不规范.在使用SVN管理本地代码过程中,会自动生成一个名为.svn的隐藏文件夹,其中包含重要的源代码信息.但一些网站管理员在发布代码时,不愿意使用‘导出’功能 ...
随机推荐
- java 中Session 持久化问题
首先: 今天发现了个session 持久化的问题 在Tomcat 停止运行后再启动 session 中保存的东西还会存在 ,百度了一下 原理 1.Session Create 时 2.Sessio ...
- Web Api 多项目文档生成之SwaggerUI
SwaggerUI 可以生成不错的文档,但默认只能作用于单个api 项目,研究了一下源码发现只需修改一下SwaggerConfig.cs文件即可支持多API项目 1.使用生成脚本把xml文件复制到AP ...
- web.config连接字符串的一些总结
阅读目录: DS01:数据库连接字符串的两种写法 DS02:数据库连接字符串的内容 DS01:数据库连接字符串的两种写法 1.连接字符串的两种写法: <configuration> & ...
- Yii2.0数据库操作增删改查详解
1.简单查询: one(): 根据查询结果返回查询的第一条记录. all(): 根据查询结果返回所有记录. count(): 返回记录的数量. sum(): 返回指定列的总数. average(): ...
- μC/OS-Ⅲ系统的任务切换和任务调度
一.任务切换 在操作系统中当任务需要从一个任务切换到另外一个任务时,要将当前任务的现场保存到当前任务的堆栈中(当前任务现场主要指CPU相关寄存器),然后回复新任务的现场并执行新任务.这个叫做上下文切换 ...
- MYSQL数据库忘记密码
1.忘记密码解决办法 Windows下的实际操作如下 1.关闭正在运行的MySQL. 2.打开DOS窗口,转到mysql\bin目录. 3.输入mysqld --skip-grant-tables回车 ...
- Read excel and put cell data into HashMap
//Read excel row by row, put cell name and cell value to a map for each row. HashMap getExpectedResu ...
- c++ 之 编译期多态&运行期多态
编译时多态:程序运行前发生的事件 —— 函数重载.运算符重载 .模板 ——静态绑定 运行时多态:程序运行时发生的事件 —— 虚函数机制——动态绑定 template<typename T> ...
- JQ对象到底是什么
jQuery对象是什么,举个例子,$('#id') 返回的就是jQuery对象,这个东西是整个jQuery的核心所在,所以我先来分析它. var jQuery = function( selector ...
- SQLserver技巧
(1) SQL标记 连接连个表然后用 DATA COMPAREDATA进行区分select 'DATA ' ,'列名1','列名2','列名3' from 表 union select 'COM ...