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

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

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

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

Q&A

解決済

2回答

1499閲覧

git cherry-pickの使い方

zcbm

総合スコア11

Git

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

0グッド

0クリップ

投稿2019/06/03 04:53

gitのmergeとcherry-pickをどのように使えばいいのかわからないため、質問させてください。

ある複数の変更を行ったブランチから変更分を取り込むにあたり、

1.各コミットをcherry-pickで選択して変更分全てを取り込む
2.mergeで全ての変更分を取り込む

この2つの対応が考えられる状況では、一般的には2のmergeを使うべきなのだと思いますが、cherry-pickを避ける理由がわかりません。
2つのケースのメリットとデメリットを教えてもらえないでしょうか?

また、どのようなケースで、git cherry-pickを使うのですか?

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

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

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

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

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

guest

回答2

0

ベストアンサー

基本的に git cherry-pickgit rebaseの用途特化版です。なので他のbranchにある変更だけど今すぐにこれだけほしい、みたいなときに使います。お示しの1のような使い方はありえません、それはgit rebaseするべきです。

で本来あるべき問であるgit rebasegit mergeどちらがマージに望ましいかですがgit mergeです。
なぜ git rebase をやめるべきか - Frasco

git rebaseによるマージは歴史を直線的にしてしまうがゆえに、問題が多いです。git mergeするまえに冗長な歴史をまとめるためにgit rebaseすることはあるかもしれませんが。


Git - git でコミットの一部を別ブランチに反映させたい|teratail
ちょうど並行で質問でてたこれがまさにgit cherry-pickするべき事案ですね。

投稿2019/06/03 05:31

編集2019/06/03 05:35
yumetodo

総合スコア5850

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

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

zcbm

2019/06/03 06:18

回答ありがとうございました。
guest

0

この2つの対応が考えられる状況では、一般的には2のmergeを使うべきなのだと思いますが、cherry-pickを避ける理由がわかりません。

そもそも論として、git rebaseという選択肢が適切な場合もありえます。

投稿2019/06/03 05:30

maisumakun

総合スコア145184

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問