diff options
author | Junio C Hamano <gitster@pobox.com> | 2014-02-27 23:01:23 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-02-27 23:01:23 +0100 |
commit | 28006fb046ddeaf15f8fe9c7cf2a122e2091451b (patch) | |
tree | c5ef16266723aa3d78d85b7ab8bec15168e1b0ec /builtin/rev-parse.c | |
parent | Merge branch 'nd/diff-quiet-stat-dirty' (diff) | |
parent | rev-parse: check i before using argv[i] against argc (diff) | |
download | git-28006fb046ddeaf15f8fe9c7cf2a122e2091451b.tar.xz git-28006fb046ddeaf15f8fe9c7cf2a122e2091451b.zip |
Merge branch 'ds/rev-parse-required-args'
"git rev-parse --default" without the required option argument did
not diagnose it as an error.
* ds/rev-parse-required-args:
rev-parse: check i before using argv[i] against argc
Diffstat (limited to 'builtin/rev-parse.c')
-rw-r--r-- | builtin/rev-parse.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/builtin/rev-parse.c b/builtin/rev-parse.c index aaeb611a97..45901df371 100644 --- a/builtin/rev-parse.c +++ b/builtin/rev-parse.c @@ -547,15 +547,17 @@ int cmd_rev_parse(int argc, const char **argv, const char *prefix) continue; } if (!strcmp(arg, "--default")) { - def = argv[i+1]; - i++; + def = argv[++i]; + if (!def) + die("--default requires an argument"); continue; } if (!strcmp(arg, "--prefix")) { - prefix = argv[i+1]; + prefix = argv[++i]; + if (!prefix) + die("--prefix requires an argument"); startup_info->prefix = prefix; output_prefix = 1; - i++; continue; } if (!strcmp(arg, "--revs-only")) { @@ -738,9 +740,12 @@ int cmd_rev_parse(int argc, const char **argv, const char *prefix) continue; } if (!strcmp(arg, "--resolve-git-dir")) { - const char *gitdir = resolve_gitdir(argv[i+1]); + const char *gitdir = argv[++i]; if (!gitdir) - die("not a gitdir '%s'", argv[i+1]); + die("--resolve-git-dir requires an argument"); + gitdir = resolve_gitdir(gitdir); + if (!gitdir) + die("not a gitdir '%s'", argv[i]); puts(gitdir); continue; } |