天天看點

patch -p0 和patch -p1的差別

今天上QQ的時候發現eva不能用了,後來又看到了解決方法,是以想打個更新檔,不過不會:-)。後來查了查明白了,寫了個總結,分享一下,也不知道以前有沒有這方面的東西,希望我這個不是多餘的。

<b>建立更新檔檔案:</b>

代碼:

diff -Naur 舊的目錄 新的目錄 &gt; patch檔案或者 diff -Naur 舊的檔案 新的檔案 &gt; patch檔案

<b>對于目錄層數的一些限制</b>

在建立patch的時候檔案夾的層數應當是一樣的,比如

--- old/modules/pcitableMon Sep 27 11:03:56 1999 +++ new/modules/pcitableTue Dec 19 20:05:41 2000

這樣是可以的。

--- old/try1/other/modules/pcitableMon Sep 27 11:03:56 1999 +++ new/modules/pcitableTue Dec 19 20:05:41 2000

這樣做可能會有一些問題。

<b>如何使用patch</b>

對于一個patch檔案,有兩種常用使用方法:

1.

cat new-patch | patch -p0

2.

patch -p0 &lt; new-patch

<b>patch指令裡面的層數(-p0?-p1?)</b>

參數-p來指定從第幾層開始比較。比如有一個patch檔案的更新檔頭是這樣的:

如果使用參數-p0,就表示從目前目錄,找一個叫作new的目錄,在它下面找一個叫modules的目錄,再在它下面找一個叫pcitableMon的目錄。

如果使用參數-p1,就表示忽略第一層,從目前目錄找一個叫modules的目錄,在它下面找一個叫modules的目錄。這樣會忽略掉更新檔頭提到的new目錄。

依此類推。

<b>patch檔案的結構</b>

<b>更新檔頭</b>

更新檔頭是分别由---/+++開頭的兩行,用來表示要打更新檔的檔案。

<b>一個更新檔檔案中的多個更新檔</b>

一個更新檔檔案中可能包含以---/+++開頭的很多節,每一節用來打一個更新檔。是以在一個更新檔檔案中可以包含好多個更新檔。

<b>塊</b>

塊是更新檔中要修改的地方。它通常由一部分不用修改的東西開始和結束。他們隻是用來表示要修改的位置。他們通常以@@開始,結束于另一個塊的開始或者一個新的更新檔頭。

<b>塊的縮進</b>

塊會縮進一列,而這一列是用來表示這一行是要增加還是要删除的。

<b>塊的第一列</b>

+号表示這一行是要加上的。

-号表示這一行是要删除的。

沒有加号也沒有減号表示這裡隻是引用的而不需要修改。

<b>一個patch的例子</b>

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

<b>分析</b>

這個例子是由指令

diff -u old/modules/pcitable new/modules/pcitable

建立的。不過最好是用指令diff -Naur來代替diff -u。

它修改了兩個檔案,new/modules/pcitable和new/usr/share/kudzu/pcitable。

第一個更新檔頭包含兩個塊,分别增加了兩行和一行。

    本文轉自vcdog 51CTO部落格,原文連結:http://blog.51cto.com/255361/837799,如需轉載請自行聯系原作者