kledgeb Ubuntuの使い方や日本語化、アプリの使い方を紹介しています。 Ubuntuの最新情報も紹介しています。

Recursiveマージストラテジーでマージを行う

  「Recursiveマージストラテジー」でマージを行います。
  「Recursiveマージストラテジー」は、デフォルトの「マージストラテジー」です。

  1.ブランチの確認

    現在のブランチ構成を確認すると、以下のようになっています。
    現在のブランチは、「master」ブランチであることが分かります。
    同様に、「HEAD」は「master」ブランチを指していることが分かります。


    ここでは例として、「master」ブランチに「fix」ブランチをマージします。

  2.ブランチの状態

    ブランチの状態を図にすると、以下のようになります。


  3.マージベースの確認

    「マージベース」を確認すると、候補が2つあることが分かります。


    出力されている識別子は、「マージベース」の候補になる「コミットオブジェクト」の識別子です。

    「2.」の図で言えば、「Commit2」と「Commit3」になります。
    「Recursiveマージストラテジー」では、これらの「コミットオブジェクト」をマージした結果が「マージベース」になります。

  4.コマンドの実行

    コマンドのオプションは、以下のオプションを指定します。

ショートオプション ロングオプション オプションの値
-s --strategy= recursive

    「端末」から、以下のコマンドを実行します。
    コマンドの詳細は、「ファイルのマージを行うコマンドの説明」を参考にしてください。

    ポイントは、赤字の箇所です。

git merge --verbose --strategy=recursive fix


  5.コミットメッセージの入力

    「3ウェイマージ」によるマージが行われ、かつ、「マージコンフリクト」が発生しなかったため、「マージコミット」が行われます。

    通常のコミットと同様に「コミットメッセージ」を入力します。


    「コミットメッセージ」を入力したら、ファイルを上書き保存してテキストエディターを終了します。

  6.コマンドの実行結果

    「3ウェイマージ」によるマージの結果が表示されます。


    「Recursiveマージストラテジー」でマージを行ったと表示されています。

  7.マージ後のブランチの確認

    マージ後のブランチを確認すると、以下のようになっています。


    「master」ブランチのブランチヘッドが指す「コミットオブジェクト」の識別子は、「マージコミット」で生成した「コミットオブジェクト」を指しています。

  8.マージ後のブランチの状態

    マージ後のブランチの状態を図にすると、以下のようになります。



関連コンテンツ
同一カテゴリーの記事
コメント
オプション