Evil merges in git - where do they come from?

后端 未结 3 1889
隐瞒了意图╮
隐瞒了意图╮ 2021-01-06 03:34

I\'ve read this question and the answers, but what isn\'t clear to me is WHO creates the \"changes that do not appear in any parent\".

Is it the git merge algorithm

3条回答
  •  栀梦
    栀梦 (楼主)
    2021-01-06 04:05

    That comment was an interesting illustration of how an "evil" merge can occur:

    Sometimes the minimal manual resolution results in lines that weren't there.
    Eg.

    • 'ours' changes the name of a function,
    • 'theirs' changes the return value,
    • we need a method with new name and new return val).

    Is this an evil one? IOW: are evil merges sometimes necessary

    Note that this article mentions "evil merges" in another context (unintented merges), and advocate for always rebasing, rather than merging... but that would ignore the danger of a git pull --rebase.


    Junio C Hamano, main maintainer for git, precise in his April 2013 blog post:

    A canonical example of where "evil merge" happens in real life (and is a good thing) is to adjust for semantic conflicts. It almost never have anything to do with textual conflicts.

    (typically an API change, for instance: you add a parameter, while another developer add a call to that function... but without any extra parameter)

    That means you have to fix the semantic conflict (like a missing argument for a function which now takes one) at the time of the merge, which means creating a line which:

    • doesn't exist in your code (where you did correctly made API changes)
    • doesn't exist in the remote branch you are now merging (where the other developer wasn't aware of the API change)

    That makes the merge an "evil merge".

    With "git log -c/--cc", such a line will show with double-plus in the multi-way patch output to show that "this did not exist in either parent".

    From git log man page:

    Diff Formatting

    -c::
    

    With this option, diff output for a merge commit shows the differences from each of the parents to the merge result simultaneously instead of showing pairwise diff between a parent and the result one at a time.
    Furthermore, it lists only files which were modified from all parents.

提交回复
热议问题