質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

Q&A

解決済

1回答

5247閲覧

ブランチを間違えて編集してしまった場合に変更を別ブランチに移す方法

namenamenameko

総合スコア234

Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

0グッド

2クリップ

投稿2017/07/07 06:02

編集2017/07/07 06:13

a, bという二つのブランチがあり、aで開発すべきだった編集をbで行ってしまっていることに気づきました。
bの変更を元に戻して、それらをaに移行する一番簡単なやり方は何でしょうか?

追記: 手作業でやるしかないですかね^^;

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

状況に応じて何通りか考えられます。

bで編集を始めたけど、まだコミットしていない場合

そのまま(cleanせずに)ブランチをaに切り替えられれば、あとは続けられます(切り替えようとして変更が干渉する場合はいったんbにコミットしてから、下の節に進んで下さい)。

ローカルのbブランチにコミットしてから気づいた場合

現状の状況をいったんbブランチにコミットしてから、aブランチに切り替えて、git cherry-pickでbブランチから必要なコミットを回収しましょう(あまりに多い場合はgit rebase --ontoでつなぎ替える方法も、なくはないです)。bブランチは必要なコミットを回収した上でgit reset --hardでもとに戻せばいいでしょう。

リモートのbブランチにプッシュしてしまった場合

基本的に、一度リモートにプッシュしてしまったものは覆水盆に返らずです。諦めて、aブランチでmergeなりcherry-pickなりで取り込みましょう。bブランチは(必要なら)今までの編集を打ち消すコミットをpushして下さい。

投稿2017/07/07 06:16

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

namenamenameko

2017/07/07 08:28

大変わかりやすくありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問