ubuntu下diff patch打補丁

來源:互聯網
上載者:User

ubuntu下diff patch打補丁 首先把個人總結寫出來,然後你們有空的話就繼續往下看: a:最原始檔案             b:修改過後的檔案 diff   -uN  b   a  >  c.patch   補丁出來了,在當前檔案夾下,一定要看清楚檔案的順序 patch  -p0  <  c.patch  給b打上了補丁,讓其變為了a  patch  -RE -p0 < c.patch   將上面做好的還原回去,相當於之前你什麼都沒幹 aa:最原始的檔案夾       bb:修改過後的檔案夾 diff  -ruN   bb   aa  > cc.patch   補丁出來了,在當前檔案,一定要看清楚檔案夾的順序 cp  cc.patch  bb     給檔案夾打補丁,要將補丁拷貝到bb檔案夾的才行哦 patch  -p1  < cc.patch  現在bb檔案夾裡面的所以內容都和aa一樣了 patch  -RE -p1 < cc.patch   將上面做好的還原回去,相當於之前你什麼都沒幹 ubuntu下patch打補丁的詳細解釋! 有空的話就看看吧,沒空就把上面記住就行了,我學這個的目的就是為了將我的android核心每次修改都打個補丁,要好幾百M,所以得搞清楚才行!   首先介紹一下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 選項說明在補丁檔案中的“新”檔案和“舊”檔案現在要調換過來了(實際上就是給新版本打補丁,讓它變成老版本) 下面結合具體執行個體來分析和解決,分為兩種類型:為單個檔案打補丁和為檔案夾內的多個檔案打補丁。     環境:在RedHat 9.0下面以armlinux使用者登陸。 分類樹如下:    |-- bootloader   |-- debug   |-- images   |-- kernel   |-- program   |-- rootfiles   |-- software   |-- source   |-- sysapps   |-- tmp `-- tools   下面在program檔案夾下面建立patch檔案夾作為實驗用,然後進入patch檔案夾。  一、為單個檔案進行補丁操作 1、建立測試檔案test0、test1    [armlinux @feng patch]$ cat >>test0<<EOF         > 111111         > 111111         > 111111         > EOF    [armlinux @feng patch]$ more test0         111111         111111         111111    [armlinux @feng patch]$ cat >>test1<<EOF         > 222222         > 111111         > 222222         > 111111         > EOF    [armlinux @feng patch]$ more test1         222222         111111         222222         111111    2、使用diff建立補丁test1.patch    [armlinux @feng patch]$ diff -uN test0 test1 > test1.patch   【註:因為單個檔案,所以不需要-r選項。選項順序沒有關係,即可以是-uN,也可以是-Nu。】    [armlinux @feng patch]$ ls test0 test1 test1.patch    [armlinux @feng patch]$ more test1.patch   ************************************************************ patch檔案的結構 補丁頭   補丁頭是分別由---/+++開頭的兩行,用來表示要打補丁的檔案。---開頭表示舊檔案,+++開頭表示新檔案。   一個補丁檔案中的多個補丁   一個補丁檔案中可能包含以---/+++開頭的很多節,每一節用來打一個補丁。所以在一個補丁檔案中可以包含好多個補丁。 塊   塊是補丁中要修改的地方。它通常由一部分不用修改的東西開始和結束。他們只是用來表示要修改的位置。他們通常以@ @開始 ,  結束於另一個塊的開始或者一個新的補丁頭。 塊的縮排   塊會縮排一列,而這一列是用來表示這一行是要增加還是要刪除的。 塊的第一列   +號表示這一行是要加上的。 -號表示這一行是要刪除的。   沒有加號也沒有減號表示這裡只是引用的而不需要修改。   **************************   diff命令會在補丁檔案中記錄這兩個檔案的首次建立時間,如下***         --- test0       2006-08-18 09:12:01.000000000 +0800         +++ test1       2006-08-18 09:13:09.000000000 +0800         @@ -1,3 +1,4 @@         +222222         111111         -111111         +222222         111111    [armlinux @feng patch]$ patch -p0 < test1.patch         patching file test0    [armlinux @feng patch]$ ls test0 test1 test1.patch    [armlinux @feng patch]$ cat test0         222222         111111         222222         111111    3、可以去除補丁,恢複舊版本    [armlinux @feng patch]$ patch -RE -p0 < test1.patch         patching file test0    [armlinux @feng patch]$ ls test0 test1 test1.patch    [armlinux @feng patch]$ cat test0         111111         111111         111111    二、為多個檔案進行補丁操作 1、建立測試檔案夾    [armlinux @feng patch]$ mkdir prj0    [armlinux @feng patch]$ cp test0 prj0    [armlinux @feng patch]$ ls prj0 test0 test1 test1.patch    [armlinux @feng patch]$ cd prj0/    [armlinux @feng prj0]$ ls test0    [armlinux @feng prj0]$ cat >>prj0name<<EOF         > --------         > prj0/prj0name         > --------         > EOF    [armlinux @feng prj0]$ ls prj0name test0    [armlinux @feng prj0]$ cat prj0name --------   prj0/prj0name --------    [armlinux @feng prj0]$ cd ..    [armlinux @feng patch]$ mkdir prj1    [armlinux @feng patch]$ cp test1 prj1    [armlinux @feng patch]$ cd prj1    [armlinux @feng prj1]$ cat >>prj1name<<EOF         > ---------         > prj1/prj1name         > ---------         > EOF    [armlinux @feng prj1]$ cat prj1name ---------         prj1/prj1name ---------    [armlinux @feng prj1]$ cd ..   2、建立補丁    [armlinux @feng patch]$ diff -uNr prj0 prj1 > prj1.patch    [armlinux @feng patch]$ more prj1.patch         diff -uNr prj0/prj0name prj1/prj0name         --- prj0/prj0name       2006-08-18 09:25:11.000000000 +0800         +++ prj1/prj0name       1970-01-01 08:00:00.000000000 +0800         @@ -1,3 +0,0 @@         ---------                 -prj0/prj0name ---------                 diff -uNr prj0/prj1name prj1/prj1name         --- prj0/prj1name       1970-01-01 08:00:00.000000000 +0800         +++ prj1/prj1name       2006-08-18 09:26:36.000000000 +0800         @@ -0,0 +1,3 @@         +---------         +prj1/prj1name         +---------                 diff -uNr prj0/test0 prj1/test0         --- prj0/test0 2006-08-18 09:23:53.000000000 +0800         +++ prj1/test0 1970-01-01 08:00:00.000000000 +0800         @@ -1,3 +0,0 @@         -111111         -111111         -111111                 diff -uNr prj0/test1 prj1/test1         --- prj0/test1 1970-01-01 08:00:00.000000000 +0800         +++ prj1/test1 2006-08-18 09:26:00.000000000 +0800         @@ -0,0 +1,4 @@         +222222         +111111         +222222         +111111    [armlinux @feng patch]$ ls         prj0 prj1 prj1.patch test0 test1 test1.patch    [armlinux @feng patch]$ cp prj1.patch ./prj0    [armlinux @feng patch]$ cd prj0    [armlinux @feng prj0]$ patch -p1 < prj1.patch         patching file prj0name         patching file prj1name         patching file test0         patching file test1    [armlinux @feng prj0]$ ls prj1name prj1.patch test1    [armlinux @feng prj0]$ patch -R -p1 < prj1.patch         patching file prj0name         patching file prj1name         patching file test0         patching file test1    [armlinux @feng prj0]$ ls prj0name prj1.patch test0   ------------------- 總結一下:    單個檔案   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 <to-docu.patch   -----------------  

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.