天天看點

Linux下patch檔案的制作

  首先介紹一下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的路徑,而非讓更新檔自己去找。

繼續閱讀