Thanks for having a look at my patches!
On 18.12.2019 19:52, Junio C Hamano wrote:
Simplify the code by dropping `argcount` and useless `argc` / `argv`
manipulations.
I am not sure if this is a good change, though. It goes against the
reasoning that makes the above "dash-dash-pos" change is a good one,
doesn't it? When the code changes over time, wouldn't it make the
code more clear to keep track of the count of args it saw in a
separate variable, than relying on the invariant that currently
happens to hold which is "if dash-dash is after the first argument,
return 2 and otherwise return 1"?
My bad that I forgot to write a detailed explanation for that. In V3 in
other topic [2] I have separated this change as a separate commit with a
good message.
+ if (opts->accept_pathspec) {
+ if (dash_dash_pos == 0)
+ return 1; /* case (2) */
+ else if (dash_dash_pos == 1)
+ has_dash_dash = 1; /* case (3) or (1) */
+ else if (dash_dash_pos >= 2)
+ die(_("only one reference expected, %d given."), dash_dash_pos);
Non-standard indentation? In our code, a level of indent is another
horizontal tab.
Sorry, my Visual Studio was acting up again. It's doing pretty weird
things when I have tab size 4 (due to other projects), which is
overridden by git repo settings to 8.
Fixed it in V3 in other topic [2]
----
[1] Commit 09ebad6f ("checkout: split off a function to peel away
branchname arg", 2011-02-08)
[2]
https://lore.kernel.org/git/pull.490.v3.git.1576778515.gitgitgadget@xxxxxxxxx/