diff和patch是一對工具,在數學上來說,diff是對兩個集合的差運算,patch是對兩個集合的和運算。
diff比較兩個檔案或檔案集合的差異,並記錄下來,生成乙個diff檔案,這也是我們常說的patch檔案,即補丁檔案。
patch能將diff檔案運用於 原來的兩個集合之一,從而得到另乙個集合。舉個例子來說檔案a和檔案b,經過diff之後生成了補丁檔案c,那麼著個過程相當於 a -b = c ,那麼patch的過程就是b+c = a 或a-c =b。
因此我們只要能得到a, b, c三個檔案中的任何兩個,就能用diff和patch這對工具生成另外乙個檔案。
這就是diff和patch的妙處。下面分別介紹一下兩個工具的用法:
1. diff的用法
diff後面可以接兩個檔名或兩個目錄名。 如果是乙個目錄名加乙個檔名,那麼只作用在那麼個目錄下的同名檔案。
如果是兩個目錄的話,作用於該目錄下的所有檔案,不遞迴。如果我們希望遞迴執行,需要使用-r引數。
命令diff a b >c ,一般a是原始檔案,b是修改後的檔案,c稱為a的補丁檔案。
不加任何引數生成的diff檔案格式是一種簡單的格式,這種格式只標出了不一樣的行數和內容。我們需要一種更詳細的格式,可以標識出不同之處的上下文環境,這樣更有利於提高patch命令的識別能力。這個時候可以用-c開關。
2. patch的用法
patch用於根據原檔案和補丁檔案生成目標檔案。還是拿上個例子來說
patch a c 就能得到b, 這一步叫做對a打上了b的名字為c的補丁。
之一步之後,你的檔案a就變成了檔案b。如果你打完補丁之後想恢復到a怎麼辦呢?
patch -r b c 就可以重新還原到a了。
所以不用擔心會失去a的問題。
其實patch在具體使用的時候是不用指定原檔案的,因為補丁檔案中都已經記載了原檔案的路徑和名稱。patch足夠聰明可以認出來。但是有時候會有點小問題。比如一般對兩個目錄diff的時候可能已經包含了原目錄的名字,但是我們打補丁的時候會進入到目錄中再使用patch,著個時候就需要你告訴 patch命令怎麼處理補丁檔案中的路徑。可以利用-pn開關,告訴patch命令忽略的路徑分隔符的個數。舉例如下:
a檔案在 dir_a下,修改後的b檔案在dir_b下,一般dir_a和dir_b在同一級目錄。我們為了對整個目錄下的所有檔案一次性diff,我們一般會到dir_a和dir_b的父目錄下執行以下命令
diff -rc dir_a dir_b >c
這個時候補丁檔案c中會記錄了原始檔案的路徑為 dir_a/a
現在另乙個使用者得到了a檔案和c檔案,其中a檔案所在的目錄也是dir_a。 一般,他會比較喜歡在dir_a目錄下面進行patch操作,它會執行
patch
但是這個時候patch分析c檔案中的記錄,認為原始檔案是./dir_a/a,但實際上是./a,此時patch會找不到原始檔案。為了避免這種情況我們可以使用-p1引數如下
patch -p1
此時,patch會忽略掉第1個」/」之前的內容,認為原始檔案是 ./a,這樣就正確了。
最後有以下幾點注意:
1. 一次打多個patch的話,一般這些patch有先後順序,得按次序打才行。
2. 在patch之前不要對原檔案進行任何修改
3. 如果patch中記錄的原始檔案和你得到的原始檔案版本不匹配(很容易出現),那麼你可以嘗試使用patch, 如果幸運的話,可以成功。大部分情況下,會有不匹配的情況,此時patch會生成rej檔案,記錄失敗的地方,你可以手工修改。
打完補丁後,需要檢查一下有沒有拒絕執行的檔案,即檢查.rej檔案的存在。使用命令:
$find . -name *.rej
如果發現,會將其輸出到標準輸出終端,預設螢幕。當然,你也可以採用重定向,輸出到指定檔案,比如reject。
$fine . -name *.rej >reject
然後可以檢視reject的內容了。
總結一下:
單個檔案
diff –un from-file to-file >to-file.patch
patch –p0 < to-file.patch
patch –re –p0 < to-file.patch
多個檔案
diff –unr from-docu to-docu >to-docu.patch
patch –p1 < to-docu.patch
patch –r –p1
diff和patch使用指南
diff和patch是一對工具,在數學上來說,diff是對兩個集合的差運算,patch是對兩個集合的和運算。diff比較兩個檔案或檔案集合的差異,並記錄下來,生成乙個diff檔案,這也是我們常說的patch檔案,即補丁檔案。patch能將diff檔案運用於 原來的兩個集合之一,從而得到另乙個集合。舉...
diff和patch使用指南
diff和patch是一對工具,在數學上來說,diff是對兩個集合的差運算,patch是對兩個集合的和運算。diff比較兩個檔案或檔案集合的差異,並記錄下來,生成乙個diff檔案,這也是我們常說的patch檔案,即補丁檔案。patch能將diff檔案運用於 原來的兩個集合之一,從而得到另乙個集合。舉...
diff和patch使用指南
diff和patch是一對工具,在數學上來說,diff是對兩個集合的差運算,patch是對兩個集合的和運算。diff比較兩個檔案或檔案集合的差異,並記錄下來,生成乙個diff檔案,這也是我們常說的patch檔案,即補丁檔案。patch能將diff檔案運用於 原來的兩個集合之一,從而得到另乙個集合。舉...