Junio C Hamano <gitster@xxxxxxxxx> writes: > Sergey Organov <sorganov@xxxxxxxxx> writes: > >>> We need to note that the "-m" implied by "--first-parent" is "if we >>> were to show some comparison, do so also for merge commits", not the >>> "if the user says '-m', it must mean that the user wants to see >>> comparison, period, so make it imply '-p'". The latter is what was >>> reverted. >> >> Yes, there is minor backward incompatibility indeed, and that was >> expected. This could be seen from the patch in the same series that >> fixes "git stash" by removing unneeded -m. >> >> The fix for the scripts is as simple as removing -m from "--first-parent >> -m". It's a one-time change. >> ... >>> I agree that we both (and if there were other reviewers, they too) >>> mistakenly thought that the change in behaviour was innocuous enough >>> when we queued the patch, but our mistakes were caught while the >>> topic was still cooking in 'next', and I have Jonathan to thank for >>> being extra careful. >> >> So, what would be the procedure to get this change back, as this minor >> backward incompatibility shouldn't be the show-stopper for the change >> that otherwise is an improvement? > > Your repeating "minor" does not make it minor. Anything you force > existing users and scripts to change is "fixing the scripts", but > "working around the breakage you brought to them", which is closer > to being a show-stopper. Backward compatibility is important, no questions, but later on you start to say that this change is a *design* mistake, so discussing backward compatibility issues gets rather useless. That said, scripts that still have "log --first-parent -m" are remnants of former sub-optimal design that was improved by "--first-parent imply -m" change about a year ago, and with current Git these scripts are confusing anyway, so fixing them by removing the work around they historically have would be a good idea no matter if the change in question is accepted or not. I mean your "working around the breakage you brought to them" is simply wrong. These changes to the scripts in question are not work-arounds they are rather improvements. It's "log --first-parent -m" in the scripts that is a work-around, and getting rid of -m there is getting rid of work-around that is not needed anymore (for about a year already.) > I understand that you like this feature a lot, but you'd need to be a > bit more considerate to your users and other people. First, I believe I *am* considerate, and second, I don't either "like" or "dislike" the feature, personally. It's a matter of consistency of UI, and the fact that such requests appear on the list (not from me) only supports this view. There are other people here who do think this is an improvement. > I think it is a design mistake to make a plain vanilla "-m" to imply > "-p" (or any "output of result of comparison"), simply because the > implication goes in the other direction, so there will never be "get > this change back", period, but see below. Well, I thought we've already discussed this to death and agreed this is an improvement, before I even started to implement the patches, and now what? I'm confused. I still believe it's reasonable for "git log -m" to output diffs without need to explicitly specify -p, and I still see no design mistake here, especially if it were implemented this way from the beginning, especially given that "git log --cc" and and "git log -c" already behave exactly this way. > > "git log" when showing a commit and asked to "output result of > comparison" like patch, combined diff, raw diff, etc. would: > > - show the comparison for non-merge commits and when > "--first-parent" is specified (the latter is natural since it > makes us consistently pretend that the merges were squash > merges). > > - shows the comparison for merge commits when -m is given. > > but because "--cc" and "-c" (which are used to specify how the > result of comparison is shown; they are not about specifying if > "normally we show only non-merges" is disabled) do not make sense in > the context of non-merge commits (in other words, the user is better > off giving "-p" if merges are not to be shown), they are made to > imply "-m". And that is a sensible design choice. No, sorry, they are made to imply -p, not -m. > On the other > hand, "--raw" (which is used to specify how the result of comparison > is shown; it not about specifying if "normally we show only > non-merges" is disabled) does make sense in the context of non-merge > commits, so unlike "--cc"/"-c", it does not imply "-m". And that > also is a sensible design choice. "-p" falls into the same bucket > as "--raw", so it should not imply "-m". Yes, but this has nothing to do with the patch in question, as -p still doesn't imply -m with this patch. It's another way around: the patch makes -m imply -p, the same way -c/--cc imply -p. > > But some folks may not like "log -p" to be silent about comparison > for merge commits (like you are). No, not me, and I didn't see anybody who insisted on it yet. It's fine with me it's silent by default. > To accomodate them, it might make sense to have a configuration that > says "I like -m, so when -p or --raw or any 'how to show comparison > result' option is given, please make it imply '-m'", but it should not > be the default. This has nothing to do with the patch in question, and I actually don't like the idea, sorry. Overall, my opinion is still that there is nothing wrong with "-m implies -p", as implemented by the patch, as if user asks to output diffs even for merge commits, it's likely they need diffs for *all* of them. This is again consistent with how -c/--cc work. Now, only provided we *again* and *finally* agree that -m should better imply -p, we can get back to discussing backward incompatibility this change does introduce, and how to get transition smoother if it needs to be. Thanks, -- Sergey Organov