直近のコミットメッセージの書き換え
git commit --amend
コマンドで、直近のコミットメッセージを変更できます。
Git では、コミットメッセージのテキストはコミットの一部として扱われます。 コミットメッセージを変更すると、コミット ID (コミットの SHA1 チェックサ� ) も変更されます。 実質的には、古いコミットに代わる新しいコミットを作成することになります。
オンラインにプッシュされていないコミット
コミットがローカルリポジトリにのみ存在し、your GitHub Enterprise Server instanceにプッシュされていない� �合、git commit --amend
コマンドでコミットメッセージを修正できます。
- コマンドラインで、修正したいコミットのあるリポジトリに移動します。
git commit --amend
と入力し、Enter を押します。- テキストエディタでコミットメッセージを編集し、コミットを保存します。
- コミットにトレーラーを追� することで、共作者を追� できます。 詳しい情� �については、「複数の作者を持つコミットを作成する」を参照してく� さい。
次回のプッシュ時に、your GitHub Enterprise Server instanceに新たなコミットとメッセージが表示されます。
Git で使うデフォルトのテキストエディタは、core.editor
の設定で変更できます。 詳しい情� �については、Git のマニュアルにある「基本クライアント設定」を参照してく� さい。
古いまたは複数のコミットメッセージの修正
すでにコミットを your GitHub Enterprise Server instanceにプッシュしている� �合、修正済みのメッセージでコミットをフォースプッシュする必要があります。
リポジトリの履歴が変更されるため、フォースプッシュは推奨されません。 フォースプッシュを行った� �合、リポジトリをすでにクローンした人はローカルの履歴を手動で修正する必要があります。 詳しい情� �については、Git のマニュアルにある「上流リベースからのリカバリ」を参照してく� さい。
直近でプッシュされたコミットのメッセージを変更する
- 上記の手� �に従って、コミットメッセージを修正します。
- Use the
push --force-with-lease
command to force push over the old commit.$ git push --force-with-lease example-branch
古いまたは複数のコミットメッセージを変更する
複数のコミットまたは古いコミットの、メッセージを修正する必要がある� �合は、インタラクティブなリベースを利用した後にフォースプッシュして、コミットの履歴を変更できます。
-
コマンドラインで、修正したいコミットのあるリポジトリに移動します。
-
git rebase -i HEAD~n
コマンドで、デフォルトのテキストエディタに直近n
コミットの一覧を表示できます。# 現在のブランチの最後の 3 つのコミットのリストを表示する $ git rebase -i HEAD~3
リストは、以下のようになります。
pick e499d89 Delete CNAME pick 0c39034 Better README pick f7fde4a Change the commit message but push the same commit. # Rebase 9fdb3bd..f7fde4a onto 9fdb3bd # # Commands: # p, pick = use commit # r, reword = use commit, but edit the commit message # e, edit = use commit, but stop for amending # s, squash = use commit, but meld into previous commit # f, fixup = like "squash", but discard this commit's log message # x, exec = run command (the rest of the line) using shell # # These lines can be re-ordered; they are executed from top to bottom. # # If you remove a line here THAT COMMIT WILL BE LOST. # # However, if you remove everything, the rebase will be aborted. # # Note that empty commits are commented out
-
変更する各コミットメッセージの前の
pick
をreword
に置き換えます。pick e499d89 Delete CNAME reword 0c39034 Better README reword f7fde4a Change the commit message but push the same commit.
-
コミット一覧のファイルを保存して閉じます。
-
生成された各コミットコミットファイルに、新しいコミットメッセージを入力し、ファイルを保存して閉じます。
-
変更を GitHub にプッシュする準備ができたら、push --force コマンドを使用して、古いコミットを強制的にプッシュします。
$ git push --force example-branch
インタラクティブリベースに関する詳しい情� �については、Git のマニュアルにある「インタラクティブモード」を参照してく� さい。
この方法でも、コミットメッセージを修正すると、ID が新しい新たなコミットメッセージが作成されます。 た� しこの方法では、修正したコミットに続く各コミットも新しい ID を取得します。各コミットには、親の ID が含まれているためです。
修正したコミットをフォースプッシュしても元のコミットは GitHub Enterprise Serverから削除されない� �合がありますので、元のコミットメッセージに機密情� �が含まれている� �合は注意してく� さい。 古いコミットは、以降のクローンには含まれませんが、GitHub Enterprise Serverにキャッシュされ、コミット ID でアクセスできます。 リモートリポジトリから古いコミットメッセージをパージするには、古いコミット ID を添えて your site administratorにお問い合わせく� さい。