コミットのスカッシュについて
ブランチの履歴にある複数のコミットをスカッシュして1つのコミットに結合できます。 これにより、リポジトリの履歴が、読みやすく、わかりやすくなります。
コミットの圧縮
-
GitHub Desktop で、 [Current Branch] をクリックします。
![リポジトリ バーのスクリーンショット。 ドロップダウン メニューを示す下向き矢印が付いた [Current Branch] というボタンがオレンジ色の枠線で囲まれています。](/assets/cb-30169/images/help/desktop/current-branch-menu.png)
-
ブランチのリストで、スカッシュしたいコミットがあるブランチを選びます。
-
左サイドバーにある [履歴] をクリックします。
![サイドバーの [履歴] タブのスクリーンショット。 コミット一覧の上にある [履歴] というタブ ボタンがオレンジ色の枠線で強調表示されています。](/assets/cb-130280/images/help/desktop/history-tab-in-commit-sidebar.png)
-
スカッシュするコミットを選び、結合先のコミットにドロップします。
<kbd>Command</kbd> キーまたは <kbd>Shift</kbd> キーを使って、1 つのコミットを選んだり、複数のコミットを選んだりすることができます。<kbd>Ctrl</kbd> キーまたは <kbd>Shift</kbd> キーを使って、1 つのコミットを選んだり、複数のコミットを選んだりすることができます。![[履歴] タブのコミットの一覧のスクリーンショット。カーソルは青色で強調表示されたコミットの上にあります。 ホバーオーバー ボックスに "2 件のコミットをスカッシュ" と表示されています。](/assets/cb-144242/images/help/desktop/squash-drag-and-drop.png)
-
新しいコミットのコミット メッセージを変更します。 スカッシュするために選んだコミットのコミット メッセージは、 "概要" フィールドと "説明" フィールドに自動入力されます。
-
**スカッシュ コミット**をクリックします。
コミットをスカッシュするときのエラー メッセージ
コミットをスカッシュするときに、次のような通知やエラー メッセージが表示されることがあります。
- 通知は、ブランチに対してリクエストされている変更で、リモート ブランチを更新するために強制プッシュが必要となることを示しています。 強制的にプッシュすると、ブランチのコミット履歴が変更され、そのブランチで作業している他のコラボレーターが影響を受けます。 [スカッシュ開始] を選んでスカッシュを開始し、その後 [Origin に強制プッシュ] をクリックして変更をプッシュします。
- エラーメッセージには、スカッシュされたコミット間にマージコミットがあるため、スカッシュが失敗したと記載されています。
- 現在のブランチにコミットされていない変更が存在していることを示す通知が表示されます。 [変更を一時退避して続ける] を選び、変更を保存して続けるか、 [閉じる] を選び、メッセージを閉じて変更をコミットします。 コミットされていない変更がなくなったら、コミットをスカッシュできます。