Git 打補丁-- patch 和 diff 的使用(詳細)


一、 patch 和diff 的區別

Git 提供了兩種補丁方案,一是用git diff生成的UNIX標准補丁.diff文件,二是git format-patch生成的Git專用.patch 文件。
.diff文件只是記錄文件改變的內容,不帶有commit記錄信息,多個commit可以合並成一個diff文件。
.patch文件帶有記錄文件改變的內容,也帶有commit記錄信息,每個commit對應一個patch文件。

在Git下,我們可以使用.diff文件也可以使用.patch 文件來打補丁,主要應用場景有:CodeReview、代碼遷移等。

二、創建patch和diff

1、創建patch 文件的常用命令行

*某次提交(含)之前的幾次提交:
git format-patch 【commit sha1 id】-n

n指從sha1 id對應的commit開始算起n個提交。
eg:

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8 -2
*某個提交的patch:
git format-patch 【commit sha1 id】 -1

eg:

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8 -1
*某兩次提交之間的所有patch:
git format-patch 【commit sha1 id】..【commit sha1 id】 

eg:

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8..89aebfcc73bdac8054be1a242598610d8ed5f3c8
2、創建diff文件的常用方法
使用命令行
git diff  【commit sha1 id】 【commit sha1 id】 >  【diff文件名】

eg:

git diff  2a2fb4539925bfa4a141fe492d9828d030f7c8a8  89aebfcc73bdac8054be1a242598610d8ed5f3c8 > patch.diff
使用SourceTree

選中要目標commit ,右擊,選擇create patch

img

3、如何獲取commit sha1 id

git 中的每個commit都有對應的一個sha1 id,我們可以通過在終端輸入git log,然后找到對應的commit sha1 id:

img

如圖中2a2fb4539925bfa4a141fe492d9828d030f7c8a8便是sha1 id

如果用Sourcetree的話也很方便,右擊對應的commit,選擇copy SHA-1 toclipboard便復制sha1 id到剪切板中:

img

三、應用patch 和 diff

相關命令行

檢查patch/diff是否能正常打入:
git apply --check 【path/to/xxx.patch】
git apply --check 【path/to/xxx.diff】
打入patch/diff:
git apply 【path/to/xxx.patch】
git apply 【path/to/xxx.diff】

或者

git  am 【path/to/xxx.patch】

使用SourceTree

選擇SourceTree,在屏幕頂部選擇Aciotn-Apply patch

img

選擇patch或者diff的路徑,然后點OK

img

四、沖突解決

在打補丁過程中有時候會出現沖突的情況,有沖突時會打入失敗,如圖:

img

此時需要解決沖突:
1、首先使用 以下命令行,自動合入 patch 中不沖突的代碼改動,同時保留沖突的部分:

git  apply --reject  xxxx.patch

可以在終端中顯示出沖突的大致代碼:

img

同時會生成后綴為 .rej 的文件,保存沒有合並進去的部分的內容,可以參考這個進行沖突解決。
2、解決完沖突后刪除后綴為 .rej 的文件,並執行git add.添加改動到暫存區.
3、接着執行git am --resolved或者git am --continue

說明:在打入patch沖突時,可以執行git am --skip跳過此次沖突,也可以執行git am --abort回退打入patch的動作,還原到操作前的狀態。

關於沖突解決詳情可以參考git am沖突解決

參考鏈接

https://blog.csdn.net/liuhaomatou/article/details/54410361
https://blog.csdn.net/maybe_windleave/article/details/8703778
https://www.cnblogs.com/y041039/articles/2411600.html
https://www.jianshu.com/p/ec04de3f95cc


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM