私はGitに慣れていないので、大きな問題が私の周りに落ちています。git mergeを元に戻す
は、ここに私の現在のブランチがどのように見えるかです:
feature /---F1-----F2----\
/ \
master -----M0-----M1-----M2-----M3-----M4
\ /
bugfix \--B1-----B2-----------/
状況:
誰かが非常に悪いことをしたし、本当に悪いマージ(M3)を押しました。 B1とB2をM4にマージした後、私たちのモデル(ソースコードではない)がロードされないとき、私は悪いマージに気づいただけです。幸いにも、私はまだM4をプッシュしていません。
問題:
私は再び右のものを設定するにはどうすればよいですか?私はM0、M1、M2、F1、F2、B1、およびB2が欲しいです。しかし、私はM3とM4を望んでいません(M4は明らかに壊れているので)。私は、変更を放棄するを持っている場合は、F1とF2を犠牲にすることができます:)
私はgit revert
に見えたが、私は完全にそれがどのように動作するかを理解すると確信していませんよ。だから...私は本当にこれを解決する方法の助けを望んでいる。
ありがとうございます。
「機能」、「マスター」、「バグ修正」は実際にはブランチではありませんが、混乱していると思われます。つまり、3 pplはマスターブランチの独自の変更にコミットしました。 1人の男が悪い併合をして押しました。私は悪い合併を引っ張った。今私は個々の変更をすべて維持しながら、悪いマージを排除する方法を望んでいます... – aberrant80
'feature'と' bugfix'はブランチではありませんか?確かに 'フィーチャー'の作者は自分のレポにブランチを持っています。あなたはマスターをM2にリセットし、 'feature'の作者に同じことを(ブランチの' feature'を失わないように)頼んで、今度はマージをやり直してください。自分で更新したい場合は、私の更新を参照してください。 – Gauthier
あなたは本当に 'master'ブランチのないレポを持っていますか? – Gauthier