> [Pierre, you have the bogus MFT header that people are often complaining > about. Either I have to do extra work to fix the headers, or more people > end up in the To: field. I don't personally care about the latter, but > it seems that others organize their mail based on To versus Cc] [ err if you do a list reply, nobody ends up in To:... but oh well I can probably remove it, it'll just make my own mutt git folder awkwardly colorized. ] On Thu, Jul 31, 2008 at 09:34:10AM +0000, Jeff King wrote: > On Thu, Jul 31, 2008 at 11:15:15AM +0200, Pierre Habouzit wrote: > > --no-walk alters how add_pending_object_with_mode works, which is called > > by handle_revision_arg. IOW, <ref1> --no-walk <ref2> is not the same as > > --no-walk <ref1> <ref2>. IOW reference arguments and --no-walk ordering > > must be preserved, IOW --no-walk is a pseudo-argument like --all --tags > > or --remote are. > > Ah, OK. Then that makes sense, then. And I definitely feel that the > patch I posted is the right thing to do, Yeah I was convinced the first time I saw it already :) -- >8 -- allow "non-option" revision options in parse_option-enabled commands Commands which use parse_options but also call setup_revisions must do their parsing in a two step process: 1. first, they parse all options. Anything unknown goes to parse_revision_opt (which calls handle_revision_opt), which may claim the option or say "I don't recognize this" 2. the non-option remainder goes to setup_revisions to actually get turned into revisions Some revision options are "non-options" in that they must be parsed in order with their revision counterparts in setup_revisions. For example, "--all" functions as a pseudo-option expanding to all refs, and "--no-walk" affects refs after it on the command line, but not before. The revision option parser in step 1 recognizes such options and sets them aside for later parsing by setup_revisions. However, the return value used from handle_revision_opt indicated "I didn't recognize this", which was wrong. It did, and it took appropriate action (even though that action was just deferring it for later parsing). Thus it should return "yes, I recognized this." Previously, these pseudo-options generated an error when used with parse_options parsers (currently just blame and shortlog). With this patch, they should work fine, enabling things like "git shortlog --all". Signed-off-by: Jeff King <peff@xxxxxxxx> Acked-By: Pierre Habouzit <madcoder@xxxxxxxxxx> --- revision.c | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/revision.c b/revision.c index a843c42..eaa5572 100644 --- a/revision.c +++ b/revision.c @@ -1002,7 +1002,7 @@ static int handle_revision_opt(struct rev_info *revs, int argc, const char **arg !strcmp(arg, "--no-walk") || !strcmp(arg, "--do-walk")) { unkv[(*unkc)++] = arg; - return 0; + return 1; } if (!prefixcmp(arg, "--max-count=")) { -- 1.6.0.rc1.197.gc57ac6
Attachment:
pgp2j8ZSYtr0z.pgp
Description: PGP signature