欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解如何使用git 生成patch 和打入patch

 更新時(shí)間:2020年07月23日 11:41:40   作者:六號(hào)碼頭  
這篇文章主要介紹了詳解如何使用git 生成patch 和打入patch,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

平時(shí)我們?cè)谑褂胓it 管理項(xiàng)目的時(shí)候,會(huì)遇到這樣一種情況,那就是客戶使用git 生成patch 給到我們,那我們就需要把客戶給到patch 打入到我們的project ,基于這樣一個(gè)場景,我把git 如何生成patch 和如何打入patch 做總結(jié)

生成patch 的方法:(我這里描述的生成patch 是根據(jù)commit 記錄生成的)

1.例如首先先通過git log 查看有哪一些commit


2.把第一次commit 提交以后的(不包括第一次提交)都生成patch 

如上圖所示:使用命令:git format-patche795fefabc

然后生成的patch 文件如下圖所示


打入patch 的方法:

把生成的patch 文件copy 到一個(gè)文件夾中來(這里我創(chuàng)建了patch 文件夾)。如下圖所示


由于這些patch顯然是用git format-patch來生成的,所以用git的工具應(yīng)該就可以很好的做好。git am 就是作這件事情。

在使用git am之前, 你要首先git am --abort 一次,來放棄掉以前的am信息,這樣才可以進(jìn)行一次全新的am。
不然會(huì)遇到這樣的錯(cuò)誤。

.git/rebase-apply still exists but mbox given.

git am 可以一次合并一個(gè)文件,或者一個(gè)目錄下所有的patch,如下圖所示:


1 使用git format-patch生成所需要的patch:

當(dāng)前分支所有超前master的提交:

git format-patch -M master

某次提交以后的所有patch:

git format-patch 4e16 --4e16指的是commit名

從根到指定提交的所有patch:

git format-patch --root 4e16

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

git format-patch 365a..4e16 --365a和4e16分別對(duì)應(yīng)兩次提交的名稱

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

git format-patch –n 07fe --n指patch數(shù),07fe對(duì)應(yīng)提交的名稱

故,單次提交即為:

git format-patch -1 07fe

git format-patch生成的補(bǔ)丁文件默認(rèn)從1開始順序編號(hào),并使用對(duì)應(yīng)提交信息中的第一行作為文件名。如果使用了-- numbered-files選項(xiàng),則文件名只有編號(hào),不包含提交信息;如果指定了--stdout選項(xiàng),可指定輸出位置,如當(dāng)所有patch輸出到一個(gè)文件;可指定-o <dir>指定patch的存放目錄;

2應(yīng)用patch:

先檢查patch文件:git apply --stat newpatch.patch
檢查能否應(yīng)用成功:git apply --check newpatch.patch
打補(bǔ)?。篻it am --signoff < newpatch.patch

(使用-s或--signoff選項(xiàng),可以commit信息中加入Signed-off-by信息)

如果應(yīng)用patch出現(xiàn)問題:

比如,一個(gè)典型的git am失敗,可能是這樣的:

$ git am PATCH
Applying: PACTH DESCRIPTION
error: patch failed: file.c:137
error: file.c: patch does not apply
error: patch failed: Makefile:24
error: libavfilter/Makefile: patch does not apply
Patch failed at 0001 PATCH DESCRIPTION
When you have resolved this problem run "git am --resolved".
If you would prefer to skip this patch, instead run "git am --skip".
To restore the original branch and stop patching run "git am --abort".

正如你所見,如果沖突發(fā)生,git只是輸出上述信息,然后就停下來。一個(gè)小沖突會(huì)導(dǎo)致整個(gè)patch都不會(huì)被集成。

處理這種問題的最簡單方法是先使用 git am --abort,然后手動(dòng)的添加此patch, patch -p1 < PATCH,手動(dòng)解決掉代碼沖突,最后使用 git commit -a 提交代碼。但是這樣做有個(gè)問題就是你會(huì)失去PATCH中原本包含的commit信息(比如From,Date,Subject,Signed-off-by等)。應(yīng)該有一種更聰明的方法。

在 .git/rebase-apply 目錄下,存放著相應(yīng)的補(bǔ)丁文件,名字是“0001” (在更新的git版本中,存放補(bǔ)丁文件的目錄名有所改變,這里使用的git版本是 1.7.4.1)。

事實(shí)上,你可以使用 git apply 命令打patch(git apply 是git中的patch命令)。如同使用 patch -p1 命令時(shí)一樣,然后手動(dòng)解決代碼沖突(檢視生成的 .rej 文件,與沖突文件比較,修改沖突內(nèi)容,并最終把文件加入到index中):

$ git apply PATCH --reject
$ edit edit edit
(譯注:根據(jù).rej文件手動(dòng)解決所有沖突)
$ git add FIXED_FILES
$ git am --resolved

就這么簡單!

想多一些解釋,好吧。git am 并不改變index,你需要使用 git apply --reject 打patch(保存在 .git/rebase-apply),手動(dòng)解決代碼沖突,(譯注:使用 git status 列出所有涉及文件),把所有文件(不僅僅是引起沖突的文件)添加到(git add)index,最后告訴 git am 你已經(jīng)解決(--resolved)了問題。這樣做的好處是你不需要重新編輯commit信息。而且,如果你正在打的是一系列patch(就是說你在打的是多個(gè)patch,比如 git am *.patch)你不需要使用 git am --abort,然后又 git am。

參考資料:

Git-format-patch(1) - Linux man page 

How to create and apply a patch with Git 

到此這篇關(guān)于詳解如何使用git 生成patch 和打入patch的文章就介紹到這了,更多相關(guān)git 生成patch 和打入patch內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • git fetch與git pull的區(qū)別詳解

    git fetch與git pull的區(qū)別詳解

    這篇文章主要介紹了git fetch與git pull的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 簡單談?wù)凣ET和POST有什么區(qū)別

    簡單談?wù)凣ET和POST有什么區(qū)別

    本文給大家總結(jié)了下get與post的具體區(qū)別,以及網(wǎng)上的那么多答案為什么都是錯(cuò)誤的,非常的實(shí)用,這里推薦給大家
    2016-06-06
  • Git 2.27.0詳細(xì)安裝步驟詳解

    Git 2.27.0詳細(xì)安裝步驟詳解

    這篇文章主要介紹了Git 2.27.0詳細(xì)安裝步驟,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • IDEA編寫SQL語句沒有提示的解決辦法

    IDEA編寫SQL語句沒有提示的解決辦法

    這篇文章主要給大家介紹了關(guān)于IDEA編寫SQL語句沒有提示的解決辦法,在IDEA中如果你在編寫SQL語句時(shí)沒有得到語法提示,可能是因?yàn)闆]有正確配置數(shù)據(jù)庫連接或者缺少相應(yīng)的插件,需要的朋友可以參考下
    2023-08-08
  • git stash的正確用法詳解

    git stash的正確用法詳解

    這篇文章主要為大家介紹了git stash的正確用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • SonarQube實(shí)現(xiàn)自動(dòng)化代碼掃描的安裝及使用集成方式

    SonarQube實(shí)現(xiàn)自動(dòng)化代碼掃描的安裝及使用集成方式

    Sonar是一個(gè)用于代碼質(zhì)量管理的開源平臺(tái),通過插件機(jī)制,Sonar可與第三方工具進(jìn)行集成。將Sonar引入到代碼開發(fā)的過程中,提供靜態(tài)源代碼安全掃描能力,這無疑是安全左移的一次很好的嘗試和探索
    2021-10-10
  • VS2019如何查看類圖的方法實(shí)現(xiàn)

    VS2019如何查看類圖的方法實(shí)現(xiàn)

    這篇文章主要介紹了VS2019如何查看類圖的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • s49?磁盤存儲(chǔ)文件系統(tǒng)管理詳解

    s49?磁盤存儲(chǔ)文件系統(tǒng)管理詳解

    這篇文章主要為大家介紹了s49?磁盤存儲(chǔ)文件系統(tǒng)管理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • git提交空目錄的方法

    git提交空目錄的方法

    大家有時(shí)候希望從git倉庫中拉取代碼時(shí)目錄就已經(jīng)存在了,不需要再手動(dòng)創(chuàng)建,但是git并不允許git提交空目錄,應(yīng)該怎么辦呢?這篇文章通過可能遇到的兩個(gè)情況來分別介紹如何解決,有需要的朋友們可以參考借鑒。
    2016-09-09
  • 網(wǎng)絡(luò)編程之get與post的區(qū)別與聯(lián)系

    網(wǎng)絡(luò)編程之get與post的區(qū)別與聯(lián)系

    這里來說說get與post的區(qū)別與聯(lián)系,對(duì)這方面不懂的鵬喲可以參考下。
    2011-04-04

最新評(píng)論