From: Linus Torvalds Date: Mon, 13 Jun 2005 18:14:20 +0000 (-0700) Subject: Teach git-rev-parse about revision-specifying arguments X-Git-Tag: v0.99~269 X-Git-Url: https://git.tokkee.org/?a=commitdiff_plain;h=921d865ea24ffea6452f9b24302e651a347d7905;p=git.git Teach git-rev-parse about revision-specifying arguments Things like "--max-count=xxx" are "rev-only". --- diff --git a/rev-parse.c b/rev-parse.c index f4a6cc2c2..fd5f2ddca 100644 --- a/rev-parse.c +++ b/rev-parse.c @@ -5,6 +5,33 @@ */ #include "cache.h" +/* + * Some arguments are relevant "revision" arguments, + * others are about output format or other details. + * This sorts it all out. + */ +static int is_rev_argument(const char *arg) +{ + static const char *rev_args[] = { + "--max-count=", + "--max-age=", + "--min-age=", + "--merge-order", + NULL + }; + const char **p = rev_args; + + for (;;) { + const char *str = *p++; + int len; + if (!str) + return 0; + len = strlen(str); + if (!strncmp(arg, str, len)) + return 1; + } +} + int main(int argc, char **argv) { int i, as_is = 0, revs_only = 0, no_revs = 0; @@ -44,8 +71,10 @@ int main(int argc, char **argv) no_revs = 1; continue; } - if (revs_only) - continue; + if (revs_only | no_revs) { + if (is_rev_argument(arg) != revs_only) + continue; + } printf("%s\n", arg); continue; }