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

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

  「Subtreeマージストラテジー」でマージを行います。

  1.ブランチの確認

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


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

  2.ブランチの状態

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


  3.masterブランチのワーキングディレクトリー

    「master」ブランチの「ワーキングディレクトリー」を見てみます。

    以下のように、「fix」サブフォルダーがあり、このサブフォルダー内に「fix」ブランチのファイルの一部を配置しています。


    「fix」サブフォルダー内のファイルは、以下のようになっています。


  4.fixブランチのワーキングディレクトリー

    「fix」ブランチの「ワーキングディレクトリー」を見てみます。
    「fix.txt」ファイルは、「master」ブランチに存在しないファイルです。


  5.コマンドの実行

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

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

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

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

git merge --verbose --strategy=subtree fix


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

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

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


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

  7.コマンドの実行結果

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


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

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

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


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

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

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


  10.マージ後のワーキングディレクトリー

    マージ後の「ワーキングディレクトリー」を見ると、以下のようになっています。

    「fix」サブフォルダー内のファイル群と、「fix」ブランチのファイル群がマージされています。


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