Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> writes: > On Wed, Jan 27, 2016 at 2:15 PM, Michael S. Tsirkin <mst@xxxxxxxxxx> wrote: >>> >>> Anyway, pulled. Just curious about how that thing happened. >> >> That's because apparently diffstat obeys orderfile rules: > > Ugh. I guess that makes sense, but it's still very annoying for > something like a pull request, where now different people end up > having different diffstats. And the reason I never noticed it is that > likely there aren't that many people who use an orderfile. > > I guess something like "-O /dev/null" in the pull-request would undo > it, but it is a bit annoying. > > I've never actually met anybody (knowingly) that used that option. I > thought it was a Junio-only use case (it's been around forever as a > command line option, but the config file entry seems to be somewhat > recent and I wasn't even aware of it). > > Adding Junio just as background to see what he thinks. Looks like the > diff.orderfile config option hits not just porcelain, but plumbing > too. Note: without enough context, I am guessing that you are annoyed that diffstat graph in a pull request did not match what you got locally after pulling. I've never actually met anybody who uses the orderfile, either. And I tend to agree that it probably is a mistake if the configuration is not limited to diff_ui_config(). Wait. It _is_ limited to diff_ui_config(). The thing is, "git request-pull" does use the Porcelain "git diff" to emit the final diffstat. So there is nothing to fix in diff.c, at least ;-) I am of two minds about the configuration affecting the output from "git request-pull" command as a whole. In a sense, "request-pull" command itself _is_ a UI level thing, i.e. Porcelain, and if a project chooses to standardize on a certain patch/diff presentation order using the diff.orderfile facility, there should be a way to tell your project participants to use the same order when they send in their patches and their pull requests, but with the hardcoded "git diff --stat" invocation at the end of "git request-pull", such a per-project customization must happen via _some_ configuration variable. We _could_ make up request-pull.difforderfile that is read by that script and gets turned into "-O $file" arguments to the "git diff" invocation, but if projects really wants to standardize on a single patch/diff presentation order, I do not think such a split configuration buys us anything. We'd be better off using a single diff.orderfile and have it consistently honoured by tools everybody who participates in the project uses. You obviously can declare "With MY project, the standard order in which you must present patch/diff is with this empty file", and tell your project participants to set diff.orderfile to /dev/null in the repository config when they work on the kernel. That would be what any such hypothetical project would do, when it has a specific preference of the patch/diff presentation order. After all, you do have a specific preference, which is "do not futz with the order in which Git gives the paths by default", so... -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html