はじめに
今回はGitHubDesktopでやりがちなミスをしてしまった時の対処法を紹介します。
ブランチを作成するのを忘れていた場合
うっかりmasterブランチのままコードを書いてしまっていた時の対処法です。
上のような状態になってしまった時ですね。
このような場合はそのまま新しくブランチを作ります。
ここで新しいブランチ名を入力して作ります。
今回は「事前準備ブランチ」という名前のブランチにしました。
するとこのような画面になります。
ここでの説明は以下の通りです。
- Leave my changes on master は変更したコードの内容を無かったことにします。
- **Bring my changes to 事前準備ブランチ(ブランチ名)**は変更したコードの内容をそのまま引き継ぎます。
なので下の**Bring my changes to 事前準備ブランチ(ブランチ名)**を選択しましょう。
するとこうなります。
無事に新しく作成した事前準備ブランチに変更したコードの内容がそのまま引き継いだままになってます。めでたし、めでたしですね。
(実はLeave my changes on masterを選択しても元のコードを引き継ぐ方法はありますが少し手間が増えますのでここでは割愛します。)
間違えてコミットしてしまった場合
では次に間違えてコミットしてしまった時の対処法です。
先程の画像の事前準備ブランチをコミットしました。
(コミットメッセージは**「messageコントローラーの作成」**としました。)
するとこのようになります。
ですがここで本当はまだコミットすべきでは無かったと気づいたらどうすればいいか?
(例えばまだ修正すべき箇所が残っていた時など)
そのような場合は左下にある「Undo」というボタンを押します。
するとこうなります。
無事に戻りましたね。
イメージとしてはブラウザの戻るボタンなどと同じ感じですね。
注意して頂きたいのが「Undo」を使えるのは**「push」**する前までなので気をつけてください。
ではpushしてしまった場合はどうするか?
このような状態ですね。
「Create Pull Request」となっていることからも分かるようにpushしてしまった状態です。
先程もお伝えした通り「Undo」は使えないのでこの場合はどうするかといいますと、
このような時は**「Revert」**という機能を使います。
以下の画像を見てください。
今回の戻したい誤ったコミットは**「messageコントローラーの作成」です。
なので該当のコミットメッセージのところで右クリックをすると表示される項目に「Revert this Commit」というのがあるのでそれをクリックしてください。
すると「Revert"messageコントローラーの作成"」というコミットが新しく追加されていると思います。
この「Revert"messageコントローラーの作成"」というコミットは「messageコントローラーの作成」**のコミットを戻すというよりはそのコミット内容のコードと同じ内容のコードを削除修正するコミットを自動的に作ってくれる機能になります。
少し説明だと分かりにくいと思いますので以下の画像を見てください。
これは**「Revert"messageコントローラーの作成"」のコミットの内容なのですが全て赤くなって「ー (マイナス)」になってると思います。
赤くなっている表示はコードから削除修正した内容という意味になります。
よってこの削除修正した内容のコミットを改めて「push」**することで該当のコードをリモートリポジトリから削除することが出来ました。
おわりに
いかがでしたでしょうか。
今回はとても初歩的なエラー時の対処法について書かせて頂きました。
ですが自分もまだまだ全然初心者ですのでなにか間違いなどありましたら教えて頂ければ幸いです。ここまでお付き合い頂きありがとうございました。
余談
今回で2記事目の投稿になるのですが前回はただ文字だけでしたが今回は画像やGIFを入れたり文字色を変えたり出来たのでだんだんと書いてるのが楽しくなってきました。笑