LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 4300|回复: 4

关于patch的总结,希望对不太了解的朋友有用

[复制链接]
发表于 2006-1-25 00:11:41 | 显示全部楼层 |阅读模式
今天上QQ的时候发现eva不能用了,后来又看到了解决方法,所以想打个补丁,不过不会:-)。后来查了查明白了,写了个总结,分享一下,也不知道以前有没有这方面的东西,希望我这个不是多余的。

创建补丁文件:
  1. diff -Naur 旧的目录 新的目录 > patch文件
  2. 或者
  3. diff -Naur 旧的文件 新的文件 > patch文件
复制代码


对于目录层数的一些限制


在创建patch的时候文件夹的层数应当是一样的,比如
  1. --- old/modules/pcitableMon Sep 27 11:03:56 1999
  2. +++ new/modules/pcitableTue Dec 19 20:05:41 2000
复制代码

这样是可以的。

  1. --- old/try1/other/modules/pcitableMon Sep 27 11:03:56 1999
  2. +++ new/modules/pcitableTue Dec 19 20:05:41 2000
复制代码

这样做可能会有一些问题。

如何使用patch
对于一个patch文件,有两种常用使用方法:
1.
  1. cat new-patch | patch -p0
复制代码

2.
  1. patch -p0 < new-patch
复制代码


patch命令里面的层数(-p0?-p1?)
参数-p来指定从第几层开始比较。比如有一个patch文件的补丁头是这样的:
  1. --- old/modules/pcitableMon Sep 27 11:03:56 1999
  2. +++ new/modules/pcitableTue Dec 19 20:05:41 2000
复制代码

如果使用参数-p0,就表示从当前目录,找一个叫作new的目录,在它下面找一个叫modules的目录,再在它下面找一个叫pcitableMon的目录。
如果使用参数-p1,就表示忽略第一层,从当前目录找一个叫modules的目录,在它下面找一个叫modules的目录。这样会忽略掉补丁头提到的new目录。
依此类推。

patch文件的结构
补丁头
补丁头是分别由---/+++开头的两行,用来表示要打补丁的文件。
一个补丁文件中的多个补丁
一个补丁文件中可能包含以---/+++开头的很多节,每一节用来打一个补丁。所以在一个补丁文件中可以包含好多个补丁。

块是补丁中要修改的地方。它通常由一部分不用修改的东西开始和结束。他们只是用来表示要修改的位置。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头。
块的缩进
块会缩进一列,而这一列是用来表示这一行是要增加还是要删除的。
块的第一列
+号表示这一行是要加上的。
-号表示这一行是要删除的。
没有加号也没有减号表示这里只是引用的而不需要修改。

一个patch的例子

  1. diff -u old/modules/pcitable new/modules/pcitable
  2. --- old/modules/pcitableMon Sep 27 11:03:56 1999
  3. +++ new/modules/pcitableTue Dec 19 20:05:41 2000
  4. @@ -1,4 +1,6 @@
  5. 0x0e110xae10"cpqarray""Compaq|Smart-2/P RAID Controller"
  6. +0x10000x0010"cpqarray""Compaq|Integrated Array Controller"
  7. +0x10110x0046"cpqarray""Compaq|Smart-2/P RAID Controller"
  8. 0x0e110xae32"tlan""Compaq|Netelligent 10/100"
  9. 0x0e110xae34"tlan""Compaq|Netelligent 10"
  10. 0x0e110xae35"tlan""Compaq|Integrated NetFlex-3/P"
  11. @@ -21,6 +23,7 @@
  12. 0x10000x000f"ncr53c8xx""Symbios|53c875"
  13. 0x10000x0012"ncr53c8xx""Symbios|53c895a"
  14. 0x10000x008f"ncr53c8xx""Symbios|53c875J"
  15. +0x10000x000a"sym53c8xx""Symbios|53c1510"
  16. 0x10000x0701"yellowfin""Symbios|83C885 gigabit ethernet"
  17. 0x10000x0702"yellowfin""Symbios|Yellowfin G-NIC gigabit ethernet"
  18. 0x10110x0001"tulip""DEC|DECchip 21050"
  19. --- old/usr/share/kudzu/pcitableSun Sep 26 17:11:23 1999
  20. +++ new/usr/share/kudzu/pcitableTue Dec 19 20:05:41 2000
  21. @@ -15,6 +15,8 @@
  22. 0x0e110x3034"unknown""Compaq|QVision 1280/p"
  23. 0x0e110x4000"unknown""Compaq|4000 [Triflex]"
  24. 0x0e110xa0f3"ignore""Compaq|Triflex PCI to ISA Bridge"
  25. +0x10000x0010"cpqarray""Compaq|Integrated Array Controller"
  26. +0x10110x0046"cpqarray""Compaq|Smart-2/P RAID Controller"
  27. 0x0e110xae10"cpqarray""Compaq|Smart-2/P RAID Controller"
  28. 0x0e110xae29"unknown""Compaq|MIS-L"
  29. 0x0e110xae2a"unknown""Compaq|MPC"
  30. @@ -46,6 +48,7 @@
  31. 0x10000x000f"ncr53c8xx""Symbios|53c875"
  32. 0x10000x0012"ncr53c8xx""Symbios|53c895a"
  33. 0x10000x008f"ncr53c8xx""Symbios|53c875J"
  34. +0x10000x000a"sym53c8xx""Symbios|53c1510"
  35. 0x10000x0701"yellowfin""Symbios|83C885 gigabit ethernet"
  36. 0x10000x0702"yellowfin""Symbios|Yellowfin G-NIC gigabit ethernet"
  37. 0x10000x0901"unknown""Symbios|61C102"
复制代码


分析
这个例子是由命令
  1. diff -u old/modules/pcitable new/modules/pcitable
复制代码

创建的。不过最好是用命令diff -Naur来代替diff -u。
它修改了两个文件,new/modules/pcitable和new/usr/share/kudzu/pcitable。
第一个补丁头包含两个块,分别增加了两行和一行。





这个是参考了这篇文章http://www.cpqlinux.com/patch.html来总结翻译。由于刚刚接触这些东西,很多地方可能翻译的不恰当,尤其是一些术语,如有发现问题,请给我留言说明,以便我来改正,谢谢。
发表于 2006-1-25 09:21:46 | 显示全部楼层
好文,赞:2cool
回复 支持 反对

使用道具 举报

发表于 2006-1-26 15:37:50 | 显示全部楼层
高级。不过用不到
回复 支持 反对

使用道具 举报

发表于 2006-2-3 20:36:07 | 显示全部楼层
好文,收藏了。(最近刚好用到)
回复 支持 反对

使用道具 举报

发表于 2006-2-3 22:02:41 | 显示全部楼层
我也是最近用到 谢谢
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表