理論
それでは、リベースとは何かという理論的な知識を更新しましょう。 簡単に説明すると、 マスターと機能の 2つのブランチがあります 。両方ともローカルです。機能は状態Aのマスターから作成され、コミットC、D、およびEが含まれます。 。
data:image/s3,"s3://crabby-images/43cba/43cba03cac23dbc6f1503d79383a23d999e3b207" alt=""
機能ブランチでリベースマスター操作を適用すると、コミットツリーは次のようになります。
data:image/s3,"s3://crabby-images/fbe13/fbe1363a7e363e2980cf34b66875ae8e338d0ca6" alt=""
コミットC '、D'、およびE 'は、C、D、およびEとは異なり、ハッシュが異なりますが、それらの内部で実行される変更(デルタ)は理想的には同じであることに注意してください。 コミットの違いは、ベースが異なるという事実(最初の場合-A、2番目-B)によるものであり、デルタの違いは、リベース中に発生した競合状況の解決によるものです。 これについては後で詳しく説明します。
この状態には、最初の状態よりも重要な利点が1つあります。機能ブランチをマスターブランチにマージする場合、早送りでマージできます。これにより、この操作中の競合がなくなります。コミットBのマスター
リベースプロセスの詳細
さて、このプロセスの仕組みを見てみましょう。ツリー1はどのようにツリー2に変化したのでしょうか?
リベースする前に、機能ブランチにいることを思い出させてください。つまり、HEADは機能ポインターを確認し、その機能ポインターはコミットEを確認します。マスターブランチの識別子を引数としてコマンドに渡します。
git rebase master
git — . A. HEAD git , A , ΔAC. master. , C', C' = B + ΔAC. master feature , , HEAD (C'), « » (detached HEAD).
data:image/s3,"s3://crabby-images/e79fb/e79fb738327d73d58b60d4a2ecc141549cda518a" alt=""
C', git — ΔCD. , C' . rebase ( , git status , detached HEAD). , ΔCD ( ) ( stage-):
data:image/s3,"s3://crabby-images/4e2e8/4e2e8d2693d6578de2e9c0c727a3d0086a410678" alt=""
:
1. rebase
git rebase --abort
HEAD, feature, ( ) .
2. merge-tool', ,
git add %filename%
. , rebase-
git rebase --continue
, , D' rebase , .
3. , B D , «» B,
git rebase --continue
, , . D',
git rebase --skip
ΔDE E', feature E', HEAD feature — , , rebase . C, D E .
data:image/s3,"s3://crabby-images/74f0d/74f0d4912d60f2e0397be6a9455e1e61528b791d" alt=""
, rebase-, (Author), , rebase (Commiter):
commit 0244215614ce6886c9e7d75755601f94b8e19729 Author: sloot69 <***@****.com> AuthorDate: Mon Nov 26 13:19:08 2012 +0400 Commit: Alex <***@****.com> CommitDate: Mon Nov 26 13:33:27 2012 +0400
— rebase
, : master, origin/master, feature origin/feature. rebase origin-, feature origin/feature, feature master.
Rebase origin-
rebase, . , , , - merge. :
data:image/s3,"s3://crabby-images/de9d4/de9d4b77d695bc17b9c4a9fa6c421e83811a6594" alt=""
— 3 master . 1 . .
git push origin master
, , . (2 3)
git pull origin master
, merge- . git push . git pull, merge-. ,
git push origin master
. github, network, :
data:image/s3,"s3://crabby-images/76795/76795fea62e1e451e2503fe0923aeed45b58448c" alt=""
6 ( ), , , , . , , , :
data:image/s3,"s3://crabby-images/e83dd/e83ddd45f235aa1ea634607f454ffb2dd7568082" alt=""
. rebase?
git pull origin master
git pull --rebase origin master
, , C, D E origin/master,
git push origin master
. :
data:image/s3,"s3://crabby-images/600fd/600fdbbd42857f58b870ae460b8b2ad44645f764" alt=""
, «» merge- , C C'. C , C'.
git pull --rebase
, .
, rebase
rebase- master . , rebase . , merge, (master). rebase . , ? push , fast-forward, , , :
data:image/s3,"s3://crabby-images/57bc5/57bc56e986ce671daa78f19b2a44200876edf153" alt=""
, :
git push origin feature --force
Force- feature origin , .
! , force-push , . , . , origin-. , — . — , . push, origin. , .
, pull, push. feature origin/feature .
git pull origin feature
, merge. , . :
git pull --rebase origin feature
feature .
git pull --rebase origin feature
— , rebase , fast-forward.
master
rebase. master git merge feature. , rebase- master fast-forward, .
, — merge fast-forward , , , . — merge --no-ff. merge-, master, — feature. , fast-forward () c merge-, --no-ff ():
data:image/s3,"s3://crabby-images/7c28b/7c28b0e2e3d4b10f7d39f3f4921bccd802a365ea" alt=""
data:image/s3,"s3://crabby-images/39b72/39b72743b4a40c8e23ee460cb033b71bd0bab152" alt=""
, , merge- . , .
, , .
git rebase , , , merge- , rebase ( -, ) , , , git pull --rebase.
. — master , . , rebase- . .
, merge rebase . , , . , . rebase-, . , , rebase .
PS. , , .