patch(未摘抄)

来源:互联网 发布:五浪真言知乎 编辑:程序博客网 时间:2024/05/17 18:15
patch给文件1应用补丁文件变成另外一个文件2(需要先用"diff 文件1 文件2"生成补丁文件)。语法patch [选项] [原始文件 [补丁文件]]描述:patch 命令读取如何更改文件的源文件指示信息,然后应用这些更改。源文件包含由 diff 命令产生的差别列表(或者 diff 列表)。差异列表是比较两个文件和构建关于如何纠正差别的指示信息的结果。缺省情况下,patch 命令使用从标准输入读入的源文件,但是使用 -i 标志和 PatchFile 变量可以覆盖此设置。差异列表有三种格式:正常、上下文或者是 ed 编辑器风格。patch 命令确定差异列表格式,除非被 -c、-e 或 -n 标志否决。  缺省情况下,文件的打过补丁的版本替换原始版本。指定 -b 标志时,每个补丁文件的原文件保存在同名的文件中,只是在文件名后附加了后缀 .orig。使用 -o 标志也可以指定输出的目的地。常用选项:-r 是一个递归选项,设置了这个选项,diff会将两个不同版本源代码目录中的所有对应文件全部都进行一次比较,包括子目录文件。-N 选项确保补丁文件将正确地处理已经创建或删除文件的情况。-u 选项以统一格式创建补丁文件,这种格式比缺省格式更紧凑些。-p0 选项从当前目录查找目的文件(夹)(直接使用补丁文件里面指定的路径)-p1 选项忽略掉第一层目录,从当前目录查找(去掉补丁文件指定路径最左的第1个'/'及前面所有内容)。-E 选项说明如果发现了空文件,那么就删除它-R 选项说明在补丁文件中的“新”文件和“旧”文件现在要调换过来了(实际上就是给新版本打补丁,让它变成老版本)举例:**单个文件的:首先将两个文件的内容显示如下:$ cat test0000000000000000000000000$ cat test1000000001111111100000000*生成补丁:$ diff -uN test0 test1 >test1.patch这样将通过比较,生成test1的补丁文件。这里选项u表示使用同一格式输出这样产生的输出便于阅读易于修改,N表示把不存在的文件看做empty的.就算文件test0不存在,也会生成补丁。*把test0通过打补丁变成test1文件:$ patch -p0 prj1.patch这里选项u表示使用同一格式输出这样产生的输出便于阅读易于修改,N表示把不存在的文件看做empty的,r表示递归地比较子目录,比较的结果被标准重定向到文件prj1.patch中了。运行之后,输出的就是一个补丁,描述了两个文件的不同,这个补丁就是把diff参数的第一个文件打补丁变成第二个文件的补丁文件。实际过程依次比较两个目录下的同名文件,如果这里不加-N就会指明prj0name和test0只在prj0中存在,prj1name和test1只在prj1中存在,这就无法比较了,所以这里为了能够比较,加上了-N选项。为了便于理解,这里给出prj1.patch文件的内容:$ cat prj1.patchdiff -uNr prj0/prj0name prj1/prj0name--- prj0/prj0name 2009-08-24 10:44:19.000000000 +0800+++ prj1/prj0name 1970-01-01 08:00:00.000000000 +0800@@ -1,5 +0,0 @@-----------prj0/prj0name----------diff -uNr prj0/prj1name prj1/prj1name--- prj0/prj1name 1970-01-01 08:00:00.000000000 +0800+++ prj1/prj1name 2009-08-24 10:45:05.000000000 +0800@@ -0,0 +1,5 @@+---------++prj1/prj1name++---------diff -uNr prj0/test0 prj1/test0--- prj0/test0 2009-08-24 11:21:12.000000000 +0800+++ prj1/test0 1970-01-01 08:00:00.000000000 +0800@@ -1,7 +0,0 @@-0000000-0000000-0000000-0000000-0000000-0000000-0000000diff -uNr prj0/test1 prj1/test1--- prj0/test1 1970-01-01 08:00:00.000000000 +0800+++ prj1/test1 2009-08-24 11:21:33.000000000 +0800@@ -0,0 +1,7 @@+1111111+1111111+1111111+1111111+1111111+1111111+1111111*将prj0中的所有文件打补丁成为prj1中的所有文件:步骤如下:1)$ cp prj1.patch ./prj02)$ cd prj03)$ patch -p1 < prj1.patch这里,把补丁文件复制到了prj0下面,然后将该文件夹下面的文件"变成"prj1下的文件了.$ ls -pprj1name prj1.patch test1关于patch命令的-p选项接数字n,意思是去掉补丁文件里指定路径的前n个'/'前缀.例如补丁文件中指定路径是/u/howard/src/blurfl/blurfl.c,那么p0选项处理之后的路径还是原来路径不变,而p1选项处理之后的路径是u/howard/src/blurfl/blurfl.c,同理p4处理之后的路径是:blurfl/blurfl.c.注意:如果在外层目录运行这个命令,那么会在外层目录创建两个prj1name和test1文件。*将打好补丁的prj0中的所有文件还原成为原来打补丁之前的文件:$ patch -R -p1 < prj1.patch运行之后文件变成原来的文件了,如下:$ ls -pprj0name prj1.patch test0*将prj1中的所有文件反向打补丁成为prj0中的所有文件:$ patch -R -p1 < prj1.patch运行之后prj1中的文件变成prj0的文件了,如下:$ ls -pprj0name prj1.patch test0*将prj1中反打补丁后的文件还原成原来的prj1中的文件:$ patch -p1 < prj1.patch运行之后,prj1中的文件被还原了,如下:$ ls -pprj1name prj1.patch test1*在外层目录把prj0的内容打补丁成prj1的内容:$ls -pprj0/ prj1.patch$patch -p0
  • patch(未摘抄)
  • gzip(未摘抄)
  • sort(未摘抄)
  • 未使用绑定变量检查【摘抄ASKTOM】
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • 摘抄
  • c#设计模式--简单工厂模式
  • try exception
  • Hello World!
  • 昨夜的梦
  • gzip(未摘抄)
  • patch(未摘抄)
  • SAP明敲Sun实损Oracle 呼吁解放Java
  • 安装SQLSERVER2000 时出现 [Microsoft][ODBC 驱动程序管理器] 未发现数据源
  • Oracle sql developer 连接问题ORA-12514
  • sort(未摘抄)
  • WML建手机网 wap1.2
  • 第1部分 接口型模式 第3章 Adapter(适配器)模式
  • 慎用++运算符,java和C++中的一个对比
  • HTML指令简明详解
  • 原创粉丝点击