Hi Buga, Igor Djordjevic <igor.d.djordjevic@xxxxxxxxx> writes: > Hi Sergey, [...] >> As I said, putting myself on the user side, I'd prefer entirely separate >> first step of the algorithm, exactly as written, with its own conflict >> resolution, all running entirely the same way as it does with non-merge >> commits. I'm used to it and don't want to learn something new without >> necessity. I.e., I'd prefer to actually see it in two separate stages, >> like this: >> >> Rebasing mainline of the merge... >> [.. possible conflicts resolution ..] >> Merging in changes to side branch(es)... >> [.. possible conflicts resolution ..] >> >> And if the second stage gives non-trivial conflicts, I'd like to have a >> simple way to just do "merge -s ours <heads>" on top of already rebased >> mainline of the merge and go with it. Note that the latter is >> significantly different than re-merging everything from scratch, that >> would be the only choice with "all-in-one" approach, and it essentially >> gives me back those simple "rebase first parent and just record other >> parents" semantics when needed. > > I`m undecided here, and while I do see a point in what you`re saying, > this being new to general public I dont`t think you being accustomed > to it is a very strong argument :) Sure. It's mostly that having already familiar step separate seems to be a good idea, as well as resulting isolation of the new stuff, where I readily agree not to granulate it further. As if the latter actually makes any difference... Octopus merges? I mean, really? > Yes, having more steps would mean more power/options to the user, but > more complexity to explain to and guide him through as well, not really > sure where the line should be drawn - for the first time, at least. A good thing is that while it runs smoothly it still runs smoothly both ways. > Also note that, for example, in case side branch(es) dropped some > commits (interactively or otherwise), first step alone would still > reintroduce those dropped changes, thus later possible `merge -s ours > <heads>` would be a pretty bad "evil merge" case and a wrong thing to > do in general. Except that my presumption is that the second step has been run already and has stopped due to conflicts, so I see the conflicting result of dropping those commits on side branch(es), check the previous state of the right side of the conflicting merge, and decide those state, being the result of the fist step after possibly demanding conflicts resolution, is fine after all. Thus I just re-merge -x ours the branch(es), instead of re-merging everythig from scratch only to finally get back to the same result, be it evil or not, the hard way. -- Sergey