[解決済み] GITで2つのブランチをマージする
2022-03-01 01:35:27
質問
GITを使い始めたばかりで、そのすばらしさを実感しているところです。
merge
コマンドは何をするのですか?
例えば、作業中のプロジェクトが "A" というブランチにあるとします。
私は家に帰ってこのブランチに変更を加え、"B" として保存します。 別のプログラマが "A" に変更を加え、"C" という名前で保存します。
2つのブランチ "B" と "C" をマージして、その変更を新しいブランチ、例えば "D" としてコミットする方法はありますか?
それとも、「マージ」のポイントがずれているのでしょうか?
解決方法は?
merge
は、2つ(またはそれ以上)の枝をまとめるために使用します。
を少し例として挙げます。
# on branch A:
# create new branch B
$ git checkout -b B
# hack hack
$ git commit -am "commit on branch B"
# create new branch C from A
$ git checkout -b C A
# hack hack
$ git commit -am "commit on branch C"
# go back to branch A
$ git checkout A
# hack hack
$ git commit -am "commit on branch A"
これで3つのブランチ(A、B、C)ができ、それぞれ異なるヘッドを持つことになります。
B と C の変更を A に戻すには、A をチェックアウトして (この例ではすでに済んでいます)、merge コマンドを使用します。
# create an octopus merge
$ git merge B C
すると、履歴は次のようになります。
…-o-o-x-------A
|\ /|
| B---/ |
\ /
C---/
リポジトリやコンピュータの境界を越えてマージしたい場合は、次のものを参照してください。
git pull
コマンドを、たとえば A ブランチのある PC から実行します (この例では、新しいコミットが二つ作成されます)。
# pull branch B
$ git pull ssh://host/… B
# pull branch C
$ git pull ssh://host/… C
関連
-
[解決済み] Git で直近のローカルコミットを取り消すには?
-
[解決済み] Gitブランチをローカルやリモートで削除するには?
-
[解決済み] git pull」と「git fetch」の違いは何ですか?
-
[解決済み] コミット前に 'git add' を取り消すにはどうすればよいですか?
-
[解決済み] Git ですべてのリモートブランチをクローンする方法
-
[解決済み] Git でブランチからコミットを削除する
-
[解決済み] git rebase の取り消し
-
[解決済み] Gitブランチをmasterにマージする最も良い(そして最も安全な)方法は何ですか?
-
[解決済み] Git のブランチの一覧を最新のコミット順に表示するにはどうしたらよいですか?
-
[解決済み】ローカルのGitブランチの名前を変更するには?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】マージの競合が発生した git stash pop の取り消し
-
[解決済み】Gitのエラー。リモートリポジトリへの接続時に「Host Key Verification Failed」。
-
[解決済み】git rev-parseは何をするのですか?
-
[解決済み】gitが「変更をコミットするか、マージする前にstashしてください」と言うのを解決するには?
-
[解決済み】Git Extensions。Win32 エラー 487: cygwinのヒープ用に領域を確保できなかった、Win32エラー0
-
[gitコミット失敗の解決] 現在のブランチの先端が後ろにあるため、更新が拒否されました。
-
git push reports an error ! [リモート拒否] master -> master (受信前のフックが拒否されました)
-
[解決済み] [Solved] originにプッシュしようとすると、Gitが「No such remote 'origin'」と言うのはなぜですか?
-
[解決済み] このリポジトリで別の git プロセスが実行されているようです。
-
[解決済み] git が「Pull is not possible because you have unmerged files」と表示するのはなぜですか?