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

1、 patch 和diff 的區別

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

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

2、建立patch和diff

一、建立patch 文件的經常使用命令行

*某次提交(含)以前的幾回提交:
git format-patch 【commit sha1 id】-n
複製代碼

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

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

eg:bash

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8 -1
複製代碼
*某兩次提交之間的全部patch:
git format-patch 【commit sha1 id】..【commit sha1 id】 
複製代碼

eg:app

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8..89aebfcc73bdac8054be1a242598610d8ed5f3c8
複製代碼
二、建立diff文件的經常使用方法
使用命令行
git diff  【commit sha1 id】 【commit sha1 id】 >  【diff文件名】
複製代碼

eg:spa

git diff  2a2fb4539925bfa4a141fe492d9828d030f7c8a8  89aebfcc73bdac8054be1a242598610d8ed5f3c8 > patch.diff
複製代碼
使用SourceTree

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

三、如何獲取commit sha1 id

git 中的每一個commit都有對應的一個sha1 id,咱們能夠經過在終端輸入git log,而後找到對應的commit sha1 id: 命令行

如圖中 2a2fb4539925bfa4a141fe492d9828d030f7c8a8即是sha1 id

若是用Sourcetree的話也很方便,右擊對應的commit,選擇copy SHA-1 toclipboard便複製sha1 id到剪切板中:code

3、應用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】
複製代碼

或者orm

git  am 【path/to/xxx.patch】
複製代碼

使用SourceTree

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

選擇patch或者diff的路徑,而後點OK

4、衝突解決

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

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

git  apply --reject  xxxx.patch
複製代碼

能夠在終端中顯示出衝突的大體代碼:

同時會生成後綴爲 .rej 的文件,保存沒有合併進去的部分的內容,能夠參考這個進行衝突解決。 二、解決完衝突後刪除後綴爲 .rej 的文件,並執行 git add.添加改動到暫存區. 三、接着執行 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

相關文章
相關標籤/搜索