使用和制作patch文件

对于进行修改文件比较差异,很快的创建一个补丁文件(patch),到底怎么做呢?下面将为读者讲述一下:如何创建和使用补丁文件以及牵涉到patch文件的结构的一些详细说明。
一、创建补丁文件
<blockquote>
diff -Naur 旧的目录 新的目录 > patch文件</blockquote>
或者
<blockquote>diff -Naur 旧的文件 新的文件 > patch文件</blockquote>
对于目录层数的一些限制,在创建patch的时候文件夹的层数应当是一样的,比如
<blockquote>
--- old/lib/TWiki Aug 17 11:03:56 2008
+++ new/lib/TWiki Aug 19 20:05:41 2008
</blockquote>
这样是可以的,而
<blockquote>
--- old/other/lib/TWiki Aug 17 11:03:56 2008
+++ new/lib/TWiki Aug 19 20:05:41 2008
</blockquote>
这样做可能会有一些问题。

二、如何使用patch
1,对于一个patch文件,有两种常用使用方法:
<blockquote>cat new-patch | patch -p02.</blockquote>

<blockquote>patch -p0 < new-patch</blockquote>
2,patch命令里面的层数(-p0?-p1?)
参数-p来指定从第几层开始比较。比如有一个patch文件的补丁头是这样的:
<blockquote>
--- old/lib/TWiki Aug 17 11:03:56 2008
+++ new/lib/TWiki Aug 19 20:05:41 2008
</blockquote>
如果使用参数-p0,就表示从当前目录,找一个叫作new的目录,在它下面找一个叫lib的目录,再在它下面找一个叫TWiki的目录。
如果使用参数-p1,就表示忽略第一层,从当前目录找一个叫lib的目录,在它下面找一个叫TWiki的目录。这样会忽略掉补丁头提到的new目录。
依此类推。

三、patch文件的结构
1,补丁头
补丁头是分别由---/+++开头的两行,用来表示要打补丁的文件。
一个补丁文件中的多个补丁
一个补丁文件中可能包含以---/+++开头的很多节,每一节用来打一个补丁。所以在一个补丁文件中可以包含好多个补丁。
2,块
块是补丁中要修改的地方。它通常由一部分不用修改的东西开始和结束。他们只是用来表示要修改的位置。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头。
3,块的缩进
块会缩进一列,而这一列是用来表示这一行是要增加还是要删除的。
4,块的第一列
+号表示这一行是要加上的。
-号表示这一行是要删除的。
没有加号也没有减号表示这里只是引用的而不需要修改。

Categories

| | 评论(0)

Post a comment

关于此日记

此日记由Cnangel发表于2008年8月21日 13:52

此Blog上的上一篇日记修正Twiki4.2.2的一个Bug

此Blog上的下一篇日记今天竟然遇到我的高中同学了

主索引归档页可以看到最新的日记和所有日记。

2008年10月

Sun Mon Tue Wed Thu Fri Sat
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
Powered by Movable Type 4.21-zh-cn