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

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

ただいまの
回答率

89.20%

Gitでコミットをまとめたい

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,098

imocl

score 13

イメージ説明
Gitでファストフォワードせずにマージしたブランチ上のコミットを、マージコミットとまとめたいです。
具体的には画像で2の緑のコミットと3の青のマージコミットは同じ内容のため、3にまとめて見た目上緑を消したいと思うのですが、後からそういったことは可能でしょうか?
緑のブランチは既に削除している状態です。
ローカルで起きていることで、リモートへはプッシュしていません。

色々調べて、
git rebase -i -p で1のコミットを指定してスカッシュなど試してみましたが、うまくいきません。

独学でGitを触り始めた超初心者です。
主にSourceTree上でGitを触っています。
よろしくお願いいたします。

頂いた回答を試した結果

私の理解が不十分すぎるため、変なことをしていたらすみません。

>ikedasさん

  1. git rebase -i で1のマージコミットを指定
  2. 2のコミットをdropに指定
    でやってみました。すると、
    イメージ説明
    このようになりました。
    ここで緑になったコミットと上部の青のコミットは同じ内容です。

>tamotoさん
仮定通りの状況のため、
git rebase --onto 2のコミット 3のコミット
を行うと、
イメージ説明
このようになりました。
ここでも、上から4つの緑のコミットは青のコミットと同じ内容です。

>Meganezaruさん
5.のcherry pickで躓いてまだ試せていません、すみません(; ;)

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • ikedas

    2018/11/27 18:16

    git rebase -i で、squash以外にdropなどというのもありますが、試してみられましたか。

    キャンセル

  • imocl

    2018/11/28 10:59

    ありがとうございます! squashとfixupしか見ていませんでした…drop試した結果を質問に追記しました。ご覧いただけますと幸いです。

    キャンセル

回答 2

checkベストアンサー

0

こんにちは。

現状は3から伸びた先端に居て、ワーキングはクリーンであると仮定します。
こういうやり方があります。

git rebase --onto <2のハッシュ> <3のハッシュ>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/28 13:20

    Meganezaruさん
    そのイメージで間違いないです。3を根本としてその先にあるチェーンを、2を根本とした位置に全て付け直します。3についてはそれを辿れるラベルがなくなれば追跡できなくなります。

    imoclさん
    この回答で意図した通りの結果になっています。先端のブランチのみを見れば、「該当のマージコミットが消えただけのログ」となっているはずです。
    rebaseは付け直すと言っても「新しいコミットのチェーンを作り直す」というものになるので、rebase前のブランチが別のブランチにマージされていたりしても、それらのログには変化はありません。先端付近で赤のブランチにマージされているチェーンは、rebaseで作り直す前のものから変化しないからです。こういう状況まで進んでしまったブランチを書き換えることは困難です。
    gitは本質的に履歴の改変が不可能なようにできているので(改変できたら履歴管理の意味をなさない)、やるなら、意図したコミットツリーの形を「再度構築しなおす」という心積もりで着手する必要があります。
    (pushしていないということなので、困難ではありますが、不可能ではないです。)

    キャンセル

  • 2018/11/28 14:16

    確かに、先端ブランチのログはマージコミットがないだけの完全なものになっています…!履歴の書き換えはこのように行うのですね。
    “本質的に履歴の改変が不可能”というところを理解していませんでした。
    私がイメージしていたツリーの形にするのは困難なようですが、大変勉強になりました。ありがとうございました!

    キャンセル

  • 2018/11/28 14:59

    tamotoさん
    返信ありがとうございました!
    勉強になりました。

    キャンセル

0

squashでいける気もしますが・・・

あえて別方法で・・・

  1. 2でbranch作成→branch-a(マージ前ブランチを復活)
  2. 青の先頭でbranch作成→branch-b(青ブランチを複製)
  3. 青を1までhard-reset
  4. branch-aを青にffマージ
  5. branch-bの3番(マージコミット)の一つ上コミット以降を、青にcherry pick(rebaseでもできそう)
  6. branch-bを削除

各操作は、調べてみてください!

青のブランチを複製(blue-orgとか)しておけば、やり直しが効くので、安心して試せると思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/28 14:23

    最初の投稿時から添付画像を先頭コミットまでの画像にしておくべきでした、すみません…
    歴史の書き換えを行うのはオリジナルではない、というところを理解していませんでした。コピーで正しくする、というイメージですね。
    cherry pickなどはじめて使ってみて、大変勉強になりました。
    ありがとうございました!

    キャンセル

  • 2018/11/28 15:08

    cherry-pickを駆使すれば(笑)、赤のブランチも含めて戻せると思います。
    時間がある時に、自分の思うがままに歴史を操作してみてください(笑)

    リモートに上がっているブランチのrebaseが厳禁なのは、rebaseで複製されたコミットがリモートのオリジナルコミットと混在してしまうからです。複製されることがわかっていれば、なんとなく理解できますよね。

    キャンセル

  • 2018/11/28 16:42

    確かに、これだとリモートにプッシュした履歴を手元で変更すると大変なことになりそうですね(*_*)
    一度、失敗できる環境でいろいろな機能を試してみようと思います!

    キャンセル

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

  • ただいまの回答率 89.20%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る