diff
比較兩個文件的不同,然后記錄下來,也就是所謂的 diff 補(bǔ)丁。
diff [options] from-file to-file
from-file:源文件
to-file:根據(jù)源文件修改后的文件
option:
-u 顯示有差異行的前后幾行(上下文), 默認(rèn)是前后各 3 行, 這樣, patch 中帶有更多的信息
-p 顯示代碼所在的 c 函數(shù)的信息
-N 選項確保補(bǔ)丁文件將正確地處理已經(jīng)創(chuàng)建或刪除文件的情況
-a 逐行比較文本文件
-r 比較子目錄中的文件
打 patch
兩個文件:需要打補(bǔ)丁的文件 a.c 和 patch 文件 test.patch
打補(bǔ)丁命令如下:
patch a.c < test.patch
實際操作如下:
補(bǔ)充:
patch -RE < test.patch 取消 patch 對源文件的修改
patch -p1 < test.patch
p 表示跳過幾級目錄,0 標(biāo)識不去掉為全路徑,1 標(biāo)識去掉第一層路徑。路徑信息包含了你的 Linux 源碼根目錄的名稱,但其他人的源碼根目錄可能是其它名字,所以,打補(bǔ)丁時,要進(jìn)入你的 Linux 源碼根目錄,并且告訴 patch 工具,請忽略補(bǔ)丁中的路徑的第一級目錄。
注意:patch -p 后面是不能帶負(fù)數(shù) 的。不使用 p 參數(shù)的時候,patch 命令會 忽略 任何目錄,直接使用文件。
多文件打 patch
本文是兩個文件做比較,打 patch,比較簡單。如果是一個工程,有多個文件修改,需要在 diff 后面增加兩個屬性:
-r 遞歸地對比一個目錄和它的所有子目錄(即整個目錄樹).
-N 如果某個文件缺少了,就當(dāng)作是空文件來對比. 如果不使用本選項,當(dāng) diff 發(fā)現(xiàn)舊代碼或者新代碼缺少文件時,只簡單的提示缺少文件。如果使用本選項,會將新添加的文件全新打印出來作為新增的部分。
-
嵌入式
+關(guān)注
關(guān)注
5088文章
19159瀏覽量
306519 -
Linux
+關(guān)注
關(guān)注
87文章
11330瀏覽量
209978 -
patch
+關(guān)注
關(guān)注
0文章
14瀏覽量
8339
發(fā)布評論請先 登錄
相關(guān)推薦
評論