使用git命令打補丁

一、 patch 和diff 的區別

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

二、創建patch和diff

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

*某次提交(含)之前的幾次提交:

git format-patch 【commit sha1 id】-n

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

example:

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8 -2

*某個提交的patch:

git format-patch 【commit sha1 id】 -1

example:

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8 -1

*某兩次提交之間的所有patch:

git format-patch 【commit sha1 id】..【commit sha1 id】 

example:

git format-patch  2a2fb4539925bfa4a141fe492d9828d030f7c8a8..89aebfcc73bdac8054be1a242598610d8ed5f3c8

2、創建diff文件的常用方法

git diff  【commit sha1 id】 【commit sha1 id】 >  【diff文件名】

example:

git diff  2a2fb4539925bfa4a141fe492d9828d030f7c8a8  89aebfcc73bdac8054be1a242598610d8ed5f3c8 > patch.diff

3、如何獲取commit sha1 id

git log

git log --oneline

 

三、應用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】

四、衝突解決

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

git  apply --reject  xxxx.patch

同時會生成後綴爲 .rej 的文件,保存沒有合併進去的部分的內容,可以參考這個進行衝突解決。

2、解決完衝突後刪除後綴爲 .rej 的文件,並執行git add.添加改動到暫存區.

3、接着執行git am --resolved或者git am --continue

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

 

 

 

 

 

 

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章