轉自:http://blog.csdn.net/aaronzzq/article/details/6955893php
git version 1.6.0.4git
幾個新手剛剛開始接觸 Git,爲了維護核心倉庫的「純潔」,避免太多無關信息被誤提交進倉庫(再次批評一些圖形化工具默認的「Select All」),採用了核心倉庫只讀,郵件提交 patch,審覈後再提交的工做流程。app
期間有時會遇到合併衝突,正常的緣由通常是未及時下載新版本產生了衝突,特殊一點的緣由是手工修改 patch 內容致使的。有時候看註釋寫得不夠準確,忍不住就改了,有時候是 Geany 保存時自動去除了 patch 原文中的行尾空格,有時候是文件回車格式、BOM 等變更了,總之合併 patch 的時候,若是生成 patch 的「原稿」找不到,通常就產生了衝突,好比:工具
$ git am 0001-BUG-Sybase.patch Applying: CHG: 讀取Sybase若是時間爲空,設置默認時間的修改 error: patch failed: source.php:38 error: source.php: patch does not apply Patch failed at 0001. 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".
剛開始一看有些懵,由於沒有任何衝突在哪裏的提示,後來找到一種方法,am 操做出問題後先手工 apply:this
$ git apply --reject 0001-BUG-Sybase.patch Checking patch source.php... error: while searching for: // 註釋 // 如下爲幾行代碼片段 error: patch failed: source.php:38 Applying patch source.php with 1 rejects... Rejected hunk #1.
這樣,就把沒有衝突的文件先合併了,剩下有衝突的做了標記。先看輸出,error: while searching for: 說明是這段代碼有衝突,error: patch failed: source.php:38 指明瞭產生衝突的代碼片段的開始行號,相應的,patch 中應該有這麼一段:.net
diff --git a/source.php b/source.php index 8770441..4e77b8a 100644 --- a/source.php +++ b/source.php @@ -38,27 +38,23 @@ class Site extends Module // 註釋 // 如下爲幾行代碼片段
同時,還會產生一個 source.php.rej 文件,裏面也是上面這段由於衝突沒法合併的代碼片段。rest
如今,在這段代碼中查找衝突緣由,並對文件進行修改,source.php.rej 參考完了能夠刪掉。改好以後,用 git add 把 source.php 添加到緩衝區,同時也要把其餘沒有衝突合併成功了的文件也加進來,由於在做 apply 操做的時候他們也發生了變化:code
$ git add source.php $ git add 其餘 apply 進來的文件們
最後:blog
$ git am --resolved Applying: CHG: 讀取Sybase若是時間爲空,設置默認時間的修改
大功告成。ip
中間若是處理亂了,用 git reset 恢復便可,因此合併 patch 在一個「乾淨」的分支上處理更好。