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