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的更多相关文章

  1. git diff patch方法

    UNIX世界的软件开发大多都是协作式的,因此,Patch(补丁)是一个相当重要的东西,因为几乎所有的大型UNIX项目的普通贡献者,都是通过 Patch来提交代码的.作为最重要的开源项目之一,Linux ...

  2. Linux diff patch

    /***************************************************************************** * Linux diff patch * ...

  3. 关于git的打patch的功能

    UNIX世界的软件开发大多都是协作式的,因此,Patch(补丁)是一个相当重要的东西,因为几乎所有的大型UNIX项目的普通贡献者,都是通过 Patch来提交代码的.作为最重要的开源项目之一,Linux ...

  4. Linux之旅(1): diff, patch和quilt (下)

    Linux之旅(1): diff, patch和quilt (下) 2 quilt 我们自己的项目能够用cvs或svn管理所有代码.但有时我们要使用其它开发人员维护的项目.我们须要改动一些文件,但又不 ...

  5. Linux游(1): diff, patch和quilt (下一个)

    Linux游(1): diff, patch和quilt (下一个) 2 quilt 我们自己的项目可以用cvs或svn管理所有代码.但有时我们要使用其它开发人员维护的项目.我们须要改动一些文件.但又 ...

  6. 如何用git命令生成Patch和打Patch

    在程序员的日常开发与合作过程中,对于code的生成patch和打patch(应用patch)成为经常需要做的事情.什么是patch?简单来讲,patch中存储的是你对代码的修改,生成patch就是记录 ...

  7. 十分钟掌握diff&patch用法

    作为程序员,了解diff&patch命令是非常必要的.比如说我们发现某个项目有bug代码,而自己又没有svn的提交权限,那么此时最合适的解决方法就是用diff命令做一个补丁发给项目成员.项目成 ...

  8. 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 ...

  9. SVN/GIT源代码泄露

    造成SVN源代码漏洞的主要原因是管理员操作不规范.在使用SVN管理本地代码过程中,会自动生成一个名为.svn的隐藏文件夹,其中包含重要的源代码信息.但一些网站管理员在发布代码时,不愿意使用‘导出’功能 ...

随机推荐

  1. VRML开发环境配置

    Vrml真的是个好老的语言啊~~~~ 1. 安装xp虚拟机 vm已经安装过.现在安装xp系统. 发现个网站,msdn itellyou,这里能够下载很多不同的操作系统,都是纯净版的. 选择xp系统:h ...

  2. Android笔记——在布局文件中插入另一个布局文件

    假如有一个布局文件A.xml想把另外一个布局文件B.xml引进其布局,则可以通过下面的代码 <include layout="@layout/B" />

  3. android开发 兵器

    spring for android andriod anotatons 按android原生的方式写代码,会导致冗余,代码丑陋,开发效率低下. 最近对项目代码进行一些梳理和改进.

  4. XSLT函数集合:数值函数、字符串函、节点集函数和布尔函数

    任何的编程语言或者是SQL语句都有内置的函数或方法,而强大灵活的xslt技术也是如此.熟练掌握XSLT的常用函数的用法,XSLT的应用将变得如此轻松,你会发现XSLT比想象中还要牛!以下是xslt数值 ...

  5. 【图像处理】【SEED-VPM】1.注意点

    1. 新装系统要启动NFX 每次虚拟机复位要执行以下命令 /usr/sbin/exportfs -av /sbin/service nfs restart —————————————————————— ...

  6. apache和nginx

    虽然nginx使用较少 还是写写文章,记录下 nginx是异步非阻塞,apache是阻塞的. apache动态页面比nginx好. 由于nginx的高并发性(使用epoll模型),所以出来静态页面性能 ...

  7. windows内核编程 白话设备栈

    在ntddk.h中定义了该函数原型: #if (NTDDI_VERSION >= NTDDI_WINXP) NTKERNELAPI NTSTATUS IoAttachDeviceToDevice ...

  8. jbpm的学习 出处http://blog.csdn.net/hxirui/article/details/1221911

    jbpm入门例子 分类: opensourse2006-09-14 11:30 37308人阅读 评论(22) 收藏 举报 jbpmhibernate数据库oraclemysqltransition ...

  9. HTML 中级

    abbr(表示它所包含的文本是一个更长的单词或短语的缩写形式): <p>This web site is about <abbr title="HyperText Mark ...

  10. Bootstrap <基础二十一>徽章(Badges)

    Bootstrap 徽章(Badges).徽章与标签相似,主要的区别在于徽章的边角更加圆滑. 徽章(Badges)主要用于突出显示新的或未读的项.如需使用徽章,只需要把 <span class= ...