天天看點

git rebase指令

本文為轉載,原文位址是:rebase

假設你現在基于遠端分支"origin",建立一個叫"mywork"的分支。

$ git checkout -b mywork origin
           
git rebase指令

現在我們在這個分支做一些修改,然後生成兩個送出(commit).

$ vi file.txt
$ git commit
$ vi otherfile.txt
$ git commit
...
           

但是與此同時,有些人也在"origin"分支上做了一些修改并且做了送出了. 這就意味着"origin"和"mywork"這兩個分支各自"前進"了,它們之間"分叉"了。

git rebase指令

在這裡,你可以用"pull"指令把"origin"分支上的修改拉下來并且和你的修改合并; 結果看起來就像一個新的"合并的送出"(merge commit):

git rebase指令

但是,如果你想讓"mywork"分支曆史看起來像沒有經過任何合并一樣,你也許可以用 git rebase:

$ git checkout mywork
$ git rebase origin
           

這些指令會把你的"mywork"分支裡的每個送出(commit)取消掉,并且把它們臨時 儲存為更新檔(patch)(這些更新檔放到".git/rebase"目錄中),然後把"mywork"分支更新 到最新的"origin"分支,最後把儲存的這些更新檔應用到"mywork"分支上。

git rebase指令

當'mywork'分支更新之後,它會指向這些新建立的送出(commit),而那些老的送出會被丢棄。 如果運作垃圾收集指令(pruning garbage collection), 這些被丢棄的送出就會删除. (請檢視 git gc)

git rebase指令

現在我們可以看一下用合并(merge)和用rebase所産生的曆史的差別:

git rebase指令

在rebase的過程中,也許會出現沖突(conflict). 在這種情況,Git會停止rebase并會讓你去解決 沖突;在解決完沖突後,用"git-add"指令去更新這些内容的索引(index), 然後,你無需執行 git-commit,隻要執行:

$ git rebase --continue
           

這樣git會繼續應用(apply)餘下的更新檔。

在任何時候,你可以用

--abort

參數來終止rebase的行動,并且"mywork" 分支會回到rebase開始前的狀态。

$ git rebase --abort