icon_git

見間違いなど他人が触っているブランチと間違えてコミットしてしまった時など、直前のコミットを亡き者にしたい時があります。

git pushを取り消すには2つの方法があり、

  1. git revert コミットを打ち消す(履歴は残る)
  2. git reset コミットをなかったことにする(履歴は残らない)

ややこしいことにgit resetには3つの種類があります。

    • reset --hard:全てをマルっと消す。
    • reset --mixed:commitとaddを取り消す。
    • reset --soft:commitのみ取り消す。

--hardは容赦無く消してしまうため現在のファイルの中身が変わって困る場合使えません。

addしたものを忘れられると困る場合は--softを利用します。(おおよその場合--softで十分だと思います)

 

revertは履歴を残すため、誤ったコミットとそれを打ち消すためのコミットの2つが残ります。

通常は圧倒的にrevertの方がいいですが、前述の通り純粋なオペミスなど不意に出来てしまった誤コミットは、revertすると不要な履歴が出来てしまうためresetしてしまったほうが良いと思います。

実行時は作業したいブランチに移動します。

git revert

git reset

 

git log --oneline

を使うことで今いるブランチのコミットログを見る事ができます。

これでresetする前と後で直前のコミットが消えているか確認することができます。

コマンド実行後はLinuxのlessコマンドと同じためqで抜ける事が可能です。

 

Twitterでフォローしよう

おすすめの記事