kledgeb UbuntuやLinuxの最新情報を紹介

Ubuntu Git その234 - Recursiveマージストラテジーで、すべての空白文字を無視してマージする(git merge)

Recursiveマージストラテジーで、すべての空白文字を無視してマージする

  「Recursiveマージストラテジー」では、ファイルの比較を行って差分を作成する際、すべての空白文字を無視して差分を作成し、マージを行うことができます。

  空白文字とは、半角スペースやタブのことです。

  どちらのブランチのファイルの差分が適用されるか

    もし、マージするブランチのファイルの差分が空白文字のみで構成される場合、現在のブランチの差分が採用されます。

    もし、現在のブランチのファイルの差分に空白文字が含まれており、かつ、マージするブランチのファイルの差分に変更内容があれば、マージするブランチの差分が採用されます。

    上記のいずれの条件にも該当しない場合、通常の方法でマージされます。
    いずれも、差分単位で処理されます。
    また、マージ後、空白文字の削除は行われません。

通常のマージ例

  比較のため、まず通常の方法でマージを行います。

  1.ブランチの確認

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


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

  2.ブランチの状態

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


  3.masterブランチのcommon.txtの中身

    「master」ブランチのcommon.txtの中身は、以下のようになっています。
    グレーの「・」は、半角スペースを表しています。


  4.fixブランチのcommon.txtの中身

    「fix」ブランチのcommon.txtの中身は、以下のようになっています。
    グレーの「・」は、半角スペースを表しています。


  5.マージを行う

    「master」ブランチに「fix」ブランチをマージします。
    マージすると、以下のように「common.txt」ファイルで「マージコンフリクト」が発生します。


  6.common.txtの中身

    「マージコンフリクト」が発生した「common.txt」ファイルの中身を見ると、コンフリクトが発生した差分に「コンフリクトマーカー」が挿入されています。


すべての空白文字を無視して、マージする 

  上記の例を利用して、すべての空白文字を無視してマージしてみます。
  上記の「4.」までは同じです。

  5.マージを行う

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

ショートオプション ロングオプション オプションの値
-X --strategy-option= ignore-all-space

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

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

git merge --verbose --strategy=recursive --strategy-option=ignore-all-space fix


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

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

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


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

  7.コマンドの実行結果

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


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

  8.common.txtファイルの中身

    上記の例で「マージコンフリクト」が発生した「common.txt」ファイルの中身は、以下のようになっています。


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

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


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

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

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



Git
スポンサー
コメント
コメントポリシー
コメントをする前に UbuntuのCode of Conduct(CoC/行動規範) を確認し、CoCに沿ったコメントをお願いします。
コメントの使い方は、コメントの使い方を参照してください。
同一カテゴリーの記事
SNS
人気の記事
  • Ubuntu 22.04 その120 - UbuntuのブートローダーをBoot Repairで修復するには・Ubuntuが起動しないトラブルを解決
    UbuntuのブートローダーをBoot Repairで修復するには 「Boot Repair」はOSのブートローダーに起因するOSが起動しない問題を簡単に解決してくれるアプリです。
  • Ubuntu 22.04 その79 - 画面ロックの有効・無効を設定するには・画面ロック時の設定をカスタマイズするには
    画面ロックの有効・無効を設定するには 一定時間ユーザーによる操作がない時に、自動的に画面をロックしパスワードで保護したり、画面をブランク状態にできます。
  • Ubuntu 22.04 その95 - ディスプレイサーバーを切り替えるには・XorgとWayland
    ディスプレイサーバーを切り替えるには 「Ubuntu」はデフォルトで2種類のディスプレイサーバーを提供しています。
  • VirtualBox その125 - ゲストOSのUbuntuにLinux Guest Additionsをインストールするには
    ゲストOSのUbuntuにLinux Guest Additionsをインストールするには 仮想マシンにインストールしたゲストOSの「Ubuntu」に、「Linux Guest Additions」をインストールする方法です。
  • Linux その309 - This Week in Plasma の貢献者の募集と投稿頻度の抑制
    This Week in Plasma の貢献者の募集と投稿頻度の低下 KDE で This Week in Plasma の貢献者が募集されています。
  • Ubuntu 26.04 その5 - デイリービルドのディスクイメージが利用可能に・ディスクイメージのダウンロード
    デイリービルドのディスクイメージ Ubuntu 26.04 LTS のデイリービルドのディスクイメージが利用できるようになりました。
  • Ubuntu 26.04 その9 - Ubuntu Desktop 26.04 LTS の開発方針・プリインストールアプリの変更やソフトウェア管理の一元化など
    Ubuntu Desktop 26.04 LTS の開発方針 2025年11月26日、Ubuntu Desktop 26.04 LTS の開発方針がアナウンスされました。
  • Ubuntu nano その5 - 文字列を検索する
    文字列を検索する(Where Is)   文字列の検索は、部分一致と正規表現による検索が可能です。 検索の開始始点   現在カーソルのある位置から検索を行います。   もし、テキストの最後まで検索して文字が見つからない場合、   nanoはテキストの先頭から検索...
  • Ubuntuのバージョンと開発コードの対応表
    UbuntuのバージョンとUbuntuの開発コード 「Ubuntu」には各バージョンごとに開発コードが設定されます。
  • Ubuntu 22.04 LTSのインストール その5 - UEFI環境でパーティションの作成と構成 〜 ブートローダーのインストール先の選択
    UEFI環境でパーティションの作成と構成を行う UEFI環境でパーティションの作成と構成を行います。
記事のピックアップ
オプション