内容
Gitでプッシュ後にリベースする方法を記載してます。
経緯
最近ブランチの共有が何回かありました。
- この部分作ってあるから後よろしくね。という感じでプッシュされたブランチをローカルに落として残りを自分が対応する。※マージはされてない
- 自分が途中まで作ったけど別作業入ったので、プッシュだけして他の人が残りを対応することになったけど、早く終わったので続きを自分が対応する。
など
前までいたPJでは中途半端に作業が終わるのであればきりがいいとこまでやってマージし、残りを他の人が対応という感じでした。
Gitを触り始めたころプッシュ後にリベースやマージをやって別ブランチの変更内容がコミット履歴に入ってきてコミット履歴が見づらいとなったことがあり(あったはず)、プッシュ後のリベース・マージは個人的に抵抗がありました。
対策は1個持ってたのですが、別の方法も気になったので動作確認してみたという感じです。
そもそもリベースとは
マージは何となくイメージ付くと思います。
ローカルブランチから最新のdevelpブランチを取り込むことで、他の人が変更した内容をローカルブランチにも取り込むことができるという感じです。
リベースはマージしつつ、ローカルのコミットをまとめてくれるというものです。
「コミット」と記載がある場所が最新のmainです。
※developに置き換えてください
- ブランチA・Bを作成
- ブランチAで「a-1」コミット
- ブランチBで「b-1」コミットし、マージ
- ブランチAで「a-2」コミット
リベースだとコミット履歴は下図になります。
※ブランチ名違いますがやってることは最新を取り込む前の状態と同じ内容です。
リベースを使うことでローカルブランチ(ブランチX)でのコミットがばらばらにならずに、まとまっているのを確認できます。
動作確認
ここからプッシュ後にマージやリベースをしてみます。
プッシュ後にリベース
結果
コミット履歴がよくわからんことになった。
プッシュ後にマージ
結果
マージのコミットが入ってきた。
期待していたのと違ってた。プッシュ後にマージしたら他の変更差分もブランチa-1コミットみたいに表示されて、ローカルコミットと他ブランチのコミットが混ざってたような記憶があるんだけど、今回みたいにマージしましたよみたいな感じで見やすいコミット履歴ではなかった気がする。あと変更ファイルが1件(x1.txt)になっているけど、記憶だとコミット履歴が混ざるためx2.txtも含まれて2件になるはず。
何かの手順が抜けていたか夢でも見てたのかもしれない。
プッシュ後にリモートブランチを削除してリベース
-
ブランチXをプッシュする。
結果
最新を取り込みつつコミット履歴が整理されていて、Github側のプッシュ内容もローカルコミットのみ表示されている。
プッシュ後にリモートブランチを削除してマージ
結果
普通にマージするのと変わらず
プッシュ後に別ブランチを作成してリベース
結果
コミット履歴がローカルの差分だけ表示される。
まとめ
プッシュ後にコミット履歴を気にしないならマージ
コミット履歴を気にするならリモートブランチを削除してリベースするか、
プッシュ元の派生ブランチからリベースすることでコミット履歴に他の差分が入らないようになります。
自分は派生ブランチ作成派です。履歴きれいになるし、不要なリモートブランチを最後にまとめて消せるため。