Junio C Hamano wrote: > Felipe Contreras <felipe.contreras@xxxxxxxxx> writes: > > > Junio C Hamano wrote: > >> Seth House <seth@xxxxxxxxx> writes: > >> > >> > I think where we're not seeing eye-to-eye is that you're focusing on > >> > potential "negative" consequences whereas I'm talking about having more > >> > information about the merge rather than less. > >> > > >> > There is very likely no negative consequences for most, if not all, > >> > mergetools. I wrote the initial version of diffconflicts ten years ago > >> > and I've been using it nearly every day since. I'm fairly confident in > >> > the end result. What is a fact is there is undisputedly less information > >> > about the merge if we overwrite LOCAL and REMOTE; as I've written, > >> > I think the tradeoff is worthwhile for most tools but a per-tool > >> > configuration will allow people that feel differently to choose > >> > differently. > >> > >> Thanks for stressing this point. > >> > >> When a user or developer asks for a reasonable feature (e.g. > >> configurability to suit personal taste), especially when there is no > >> obvious downside for adding it, the burden of proof is on the party > >> who refuses to add it > > > > Sorry, but no. > > > > You may be the final word in the git project, but the burden of proof is > > an essential part of logic, not project-dependent, and that's just not > > the case. > > > > *Anyone* that makes any claim has the burden of proof. > > Yes, and in this case, Seth already said he prefers to be able to > see the original, and not necessarily all the users of his mergetool > backend prefer the same thing. That is enough "proof" to me that > the need exists. That's not proof. That's one person stating his opinion. He did not present evidence of *why* one of his users would prefer to turn this flag off in his tool, but not others. Here, allow me to show what diffconflicts does: diff --git a/mergetools/vimdiff b/mergetools/vimdiff index abc8ce4ec4..a8fd8e4a84 100644 --- a/mergetools/vimdiff +++ b/mergetools/vimdiff @@ -29,6 +29,10 @@ merge_cmd () { "$LOCAL" "$REMOTE" "$MERGED" fi ;; + *vimdiff4) + cp "$LOCAL" "$MERGED" + "$merge_tool_path" -f -d "$MERGED" "$REMOTE" + ;; esac } "mergetool.automerge=true" plus the code above replicates the main functionality of the diffconflicts plugin. Why would anyone want to turn off automerge for vimdiff4, but not for vimdiff2? Nobody has explained that. > It is your turn to prove your (implicit) claim that it does more harm > than it helps to allow such a preference expressed by end users. No. The burden of proof is still on the side that claims such preference is desirable. "I think X" is not evidence of X. > > Is there a conflict in this example? > > > > echo Hello > BASE > > echo Hello > LOCAL > > echo Hello. > REMOTE > > git merge-file -p LOCAL BASE REMOTE > > Sorry, but I do not see why that example matters. But I do. That's why I asked the question. > Would such a case even come into the picture to be resolved by "git > mergetool" in the first place? That is precisely the point. It is not a conflict because that line only has changes in REMOTE, but not in LOCAL. Correct? git doesn't bother the user because there's no merge conflict. But if there is an *actual conflict* some lines below, why should git, or git-mergetool, or the mergetool now bother the user presenting it the diff of the "Hello." line? Why does that line that according to you "wouldn't not even come into the picture" becomes suddenly relevant when there's an actual conflict below? Either the "Hello." change is relevant or it isn't. But more importantly; its relevance doesn't depend on the mergetool. Choosing vimdiff4 doesn't magically make it a conflict. Cheer. -- Felipe Contreras