Возьмем следующий случай:
У меня есть какая-то работа в ветке темы, и теперь я готов вернуться к мастеру:
* eb3b733 3 [master] [origin/master]
| * b62cae6 2 [topic]
|/
* 38abeae 1
Я выполняю слияние с мастером, разрешаю конфликты и теперь у меня:
* 8101fe3 Merge branch 'topic' [master]
|\
| * b62cae6 2 [topic]
* | eb3b733 3 [origin/master]
|/
* 38abeae 1
Теперь для слияния потребовалось некоторое время, поэтому я делаю еще один выбор и замечаю, что ветвь удаленного мастера имеет новые изменения:
* 8101fe3 Merge branch 'topic' [master]
|\
| * b62cae6 2 [topic]
| | * e7affba 4 [origin/master]
| |/
|/|
* | eb3b733 3
|/
* 38abeae 1
Если я попробую 'git rebase origin/master' от master, я вынужден снова разрешить все конфликты, а также потеряю фиксацию слияния:
* d4de423 2 [master]
* e7affba 4 [origin/master]
* eb3b733 3
| * b62cae6 2 [topic]
|/
* 38abeae 1
Есть ли чистый способ переустановить фиксацию слияния, поэтому я получаю историю, подобную той, которую я показываю ниже?
* 51984c7 Merge branch 'topic' [master]
|\
| * b62cae6 2 [topic]
* | e7affba 4 [origin/master]
* | eb3b733 3
|/
* 38abeae 1