中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > C/C++
使用diff patch制作补丁
作者:未知 时间:2005-09-13 23:28 出处:Blog.ChinaUnix.net 责编:chinaitpower
              摘要:使用diff patch制作补丁
linux的常用命令

diff   diff是生成源码补丁的必备工具。其命令格式为:  diff [命令行选项] 原始文件 新文件 常用命令行选项如下:    -r 递归处理目录     -u 输出统一格式(unified format)    -N patch里包含新文件   -a patch里可以包含二进制文件   它的输出在stdout上,所以你可能需要把它重定向到一个文件。diff的输出有“传统格式”和“统一格式”之分,现在大都使用统一格 式:   传统格式示例:    [hahalee@builder]$ diff a.txt b.txt    1a2    > here we insert a new line    3d3    < why not this third line?   统一格式示例:    [hahalee@builder]$ diff -u a.txt b.txt    --- a.txt Thu Apr 6 15:58:34 2000    +++ b.txt Thu Apr 6 15:57:53 2000    @@ -1,3 +1,3 @@    This is line one    +here we insert a new line    and this is line two    -why not this third line?   通过比较可以看出,传统格式的patch文件比较小,除了要删除/插入的行外没有冗余信息。统一格式则保存了上下文(缺省是上下各三 行,最少需要两行),这样,patch的时候可以允许行号不精确匹配的情况出现。另外,在patch文件的开头明确地用---和+++标示出原始文件 和当前文件,也方便阅读。要选用统一格式,用 u 开关。   通常,我们需要对整个软件包做修改,并生成一个patch文件,下面是典型的操作过程。这里就要用到前面介绍的几个命令行开关了:   tar xzvf software.tar.gz # 展开原始软件包,其目录为software   cp _a software software-orig # 做个修改前的备份   cd software   [修改,测试……]   cd ..   diff _ruNa software-orig software > software-my.patch   现在我们就可以保存software-my.patch做为这次修改的结果,至于原始软件包,可以不必保存。等到下次需要再修改的时候,可以用 patch命令把这个补丁打进原始包,再继续工作。比如是在linux kernel 上做的工作,就不必每次保存几十兆修改后的源码了。这是好处之 一,好处之二是维护方便,由于unified patch格式有一定的模糊匹配能力,能减少原软件包升级带来的维护工作量(见后)   patch   patch命令跟diff配合使用,把生成的补丁应用到现有代码上。常用命令行选项:   patch [命令行选项] [待patch的文件[patch]]   -pn patch level(n是数字) -b[后缀] 生成备份,缺省是.orig 为了说明什么是patch level,这里看一个patch文件的头标记。   diff -ruNa xc.orig/config/cf/Imake.cf xc.bsd/config/cf/Imake.cf   --- xc.orig/config/cf/Imake.cf Fri Jul 30 12:45:47 1999   +++ xc.new/config/cf/Imake.cf Fri Jan 21 13:48:44 2000   这个patch如果直接应用,它会去找xc.orig/config/cf目录下的Imake.cf文件,假如你的源码树的根目录是缺省的xc而不是xc.orig,除了mv xc xc.orig之外,有无简单的方法应用此patch呢?patch level就是为此而设:patch会把目标路径名砍去开头patch level个节(由/分开的部分)。 在本例中,可以用下述命令:cd xc; patch _p1 < /pathname/xxx.patch 完成操作。注意,由于没有指定patch文件,patch程序默认从stdin读 入,所以用了输入重定向。   如果patch成功,缺省是不建备份文件的(注:FreeBSD下的patch工具缺省是保存备份),如果你需要,可以加上 b 开关。这样把修改前的 文件以“原文件名.orig”的名字做备份。如果你喜欢其它后缀名,也可以用“b 后缀”来指定。   如果patch失败,patch会把成功的patch行给patch上,同时(无条件)生成备份文件和一个.rej文件。.rej文件里是没有成功提交的patch 行,需要手工patch上去。这种情况在原码升级的时候有可能会发生。   关于二进制文件的说明:binary文件可以原始方式存入patch文件。diff可以生成(加-a选项),patch也可以识别。如果觉得这样的patch文件 太难看,解决方法之一是用uuencode处理该binary文件。

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有