轉載:https://blog.csdn.net/liuhaomatou/article/details/54410361git
平時咱們在使用git 管理項目的時候,會遇到這樣一種狀況,那就是客戶使用git 生成patch 給到咱們,那咱們就須要把客戶給到patch 打入到咱們的project ,基於這樣一個場景,我把git 如何生成patch 和如何打入patch 作總結app
生成patch 的方法:(我這裏描述的生成patch 是根據commit 記錄生成的)工具
1.例如首先先經過git log 查看有哪一些commit.net
2.把第一次commit 提交之後的(不包括第一次提交)都生成patch orm
如上圖所示:使用命令:git format-patche795fefabcblog
而後生成的patch 文件以下圖所示it
打入patch 的方法:ast
把生成的patch 文件copy 到一個文件夾中來(這裏我建立了patch 文件夾)。以下圖所示form
因爲這些patch顯然是用git format-patch來生成的,因此用git的工具應該就能夠很好的作好。git am 就是做這件事情。file
在使用git am以前, 你要首先git am --abort 一次,來放棄掉之前的am信息,這樣才能夠進行一次全新的am。
否則會遇到這樣的錯誤。
.git/rebase-apply still exists but mbox given.
git am 能夠一次合併一個文件,或者一個目錄下全部的patch,以下圖所示:
---------------------------------------------------------------------------------------總結:---------------------------------------------------------------------------------------------------------------------------------------------
1 使用git format-patch生成所須要的patch:
當前分支全部超前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分別對應兩次提交的名稱
某次提交(含)以前的幾回提交:
git format-patch –n 07fe --n指patch數,07fe對應提交的名稱
故,單次提交即爲:
git format-patch -1 07fe
git format-patch生成的補丁文件默認從1開始順序編號,並使用對應提交信息中的第一行做爲文件名。若是使用了-- numbered-files選項,則文件名只有編號,不包含提交信息;若是指定了--stdout選項,可指定輸出位置,如當全部patch輸出到一個文件;可指定-o <dir>指定patch的存放目錄;
新增:若是隻想爲最後第N次提交產生補丁,則能夠執行下列命令:
git format-patch -N
爲最後一次提交產生一個補丁:
git format-patch -1
2應用patch:
先檢查patch文件:git apply --stat newpatch.patch
檢查可否應用成功:git apply --check newpatch.patch
打補丁:git am --signoff < newpatch.patch
(使用-s或--signoff選項,能夠commit信息中加入Signed-off-by信息)