红联Linux门户
Linux帮助

Linux下patch文件的制作

发布时间:2016-04-02 08:33:12来源:linux网站作者:laughing_cui

首先介绍一下diff和patch。在这里不会把man在线文档上所有的选项都介绍一下,那样也没有必要。在99%的时间里,我们只会用到几个选项。所以必须学会这几个选项。


1.diff

NAME
diff - find differences between two files
SYNOPSIS
diff [options] from-file to-file

简单的说,diff的功能就是用来比较两个文件的不同,然后记录下来,也就是所谓的diff补丁。语法格式:diff 【选项】 源文件(夹) 目的文件(夹),就是要给源文件(夹)打个补丁,使之变成目的文件(夹),术语也就是“升级”。下面介绍三个最为常用选项:

-r 是一个递归选项,设置了这个选项,diff会将两个不同版本源代码目录中的所
 有对应文件全部都进行一次比较,包括子目录文件。
-N 选项确保补丁文件将正确地处理已经创建或删除文件的情况。
-u 选项以统一格式创建补丁文件,这种格式比缺省格式更紧凑些。


2、patch

NAME
patch - apply a diff file to an original
SYNOPSIS
patch [options] [originalfile [patchfile]]
but usually just
patch -pnum <patchfile>

简单的说,patch就是利用diff制作的补丁来实现源文件(夹)和目的文件(夹)的转换。这样说就意味着你可以有源文件(夹)――>目的文件(夹),也可以目的文件(夹)――>源文件(夹)。下面介绍几个最常用选项:
-p0 选项要从当前目录查找目的文件(夹)
-p1 选项要忽略掉第一层目录,从当前目录开始查找。

在这里以实例说明:
— old/modules/pcitable Mon Sep 27 11:03:56 1999
+++ new/modules/pcitable Tue Dec 19 20:05:41 2000
如果使用参数-p0,那就表示从当前目录找一个叫做old的文件夹,在它下面寻找modules下的pcitable文件来执行patch操作。
如果使用参数-p1, 那就表示忽略第一层目录(即不管old),从当前目录寻找modules的文件夹,在它下面找pcitable。这样的前提是当前目 录必须为modules所在的目录。而diff补丁文件则可以在任意位置,只要指明了diff补丁文件的路径就可以了。当然,可以用相对路径,也可以用绝 对路径。不过我一般习惯用相对路径。

-E 选项说明如果发现了空文件,那么就删除它
-R 选项说明在补丁文件中的“新”文件和“旧”文件现在要调换过来了(实际上就是给新版本打补丁,让它变成老版本)


3.实例说明

3.1为单个文件进行补丁操作

diff –uN from-file to-file >to-file.patch
patch –p0 < to-file.patch
patch –RE –p0 < to-file.patch

3.2为文件夹打补丁

diff –urN old_docu/  new_docu/ > new_docu.patch
patch -p1 -d old_docu < new_docu.patch

原理解释:

首先,假设你是基于old_docu/目录为旧目录,new_docu/为新目录,在new_docu下新建了文件,file2,那么你做出来的patch就是类似这样:

--- old_docu/file2
+++ new_docu/file2
+this is file 2

如果你用patch -p0 去打这个patch,那么补丁首先要解决的问题是,往哪儿打这个补丁。它先会去找 — 和 +++ 给出的路径。很显然—这个没找到,+++这个找到了。接着会提示:

The next patch would create the file new_docu/file2,
which already exists!  Assume -R? [n]

如果你按了y,那相当于执行了revert操作,new_docu/file2就没了。
所以这里你不能用-p0,而应该用-p1 -d old_docu/来手工指定要patch的路径,而非让补丁自己去找。


本文永久更新地址:http://www.linuxdiyf.com/linux/19449.html