用 diff 建立 patch 檔案上補丁

2017-01-02 Other

前陣子修了 nginx 的 bugfix 剛好用上 diff 建立 patch 補丁檔,這邊記錄一下如何用 diff 和 patch 這兩個工具。

 

用 diff 產生 patch 補丁

首先你必須先擁有 新/舊檔案 (file.old / file.new),然後用 diff 比較兩隻檔案的差異

$ diff -Naur file.old file.new > file.patch

-a 將所有檔案都視為文字檔
-u 輸出預設三行的相同文字行
-r 遞迴比較所有的子目錄
-N 將缺少的檔案視為空檔案

所產生的 file.patch 就是 patch 補丁檔。

 

如何使用 Patch 工具進行補丁更新

由我之前所產生的 patch 檔案當做範例

diff -Naur nginx_old/src/event/ngx_event_openssl.c nginx_new/src/event/ngx_event_openssl.c           
--- nginx_old/src/event/ngx_event_openssl.c 2016-12-13 23:21:24.000000000 +0800
+++ nginx_new/src/event/ngx_event_openssl.c 2016-12-26 11:21:23.256483991 +0800
@@ -4069,7 +4069,7 @@

     BIO_write(bio, "Tue ", sizeof("Tue ") - 1);
     ASN1_TIME_print(bio, asn1time);
-    len = BIO_get_mem_data(bio, &value);
+    len = BIO_get_mem_data(bio, (char **) &value);

     time = ngx_parse_http_time(value, len);

diff -Naur nginx_old/src/event/ngx_event_openssl_stapling.c nginx_new/src/event/ngx_event_openssl_stapling.c
--- nginx_old/src/event/ngx_event_openssl_stapling.c  2016-12-13 23:21:24.000000000 +0800
+++ nginx_new/src/event/ngx_event_openssl_stapling.c  2016-12-26 11:21:43.014381862 +0800
@@ -793,7 +793,7 @@

     BIO_write(bio, "Tue ", sizeof("Tue ") - 1);
     ASN1_GENERALIZEDTIME_print(bio, asn1time);
-    len = BIO_get_mem_data(bio, &value);
+    len = BIO_get_mem_data(bio, (char **) &value);

     time = ngx_parse_http_time(value, len);

由於我在產生 patch 檔的時候 nginx_old 和 nginx_new 都不是真實 nginx 原始碼路徑,由 src 這邊開始才是,所以 patch 提供了 -p 的參數

 

$ cd nginx/
$ patch -p1 < nginx.patch

到要 patch 的 nginx 原始碼包的根目錄,然後使用 -p1 的參數,略過 nginx_old 和 nginx_new 這一層,這樣就會從 src 底下開始進行 patch 比較

 

 

給 Mr. 沙先生一點建議

彙整

分類

展開全部 | 收合全部

License

訂閱 Mr. 沙先生 的文章

輸入你的 email 用於訂閱