author | Pierre Habouzit <madcoder@debian.org> | |
Sat, 26 Jan 2008 11:26:57 +0000 (12:26 +0100) | ||
committer | Junio C Hamano <gitster@pobox.com> | |
Sat, 26 Jan 2008 18:53:31 +0000 (10:53 -0800) | ||
commit | 3a9f0f41db87e197708f84aeb2487bc983f99c9c | |
tree | ab4786304593bb88c652c0fa1c348b9bf9343792 | tree | snapshot |
parent | 923e3ec84a4e792ca277aac08e52ec2f9b47a8eb | commit | diff |
parse-options: catch likely typo in presense of aggregated options.
If options are aggregated, and that the whole token is an exact
prefix of a long option that is longer than 2 letters, reject
it. This is to prevent a common typo:
$ git commit -amend
to get interpreted as "commit all with message 'end'".
The typo check isn't performed if there is no aggregation,
because the stuck form is the recommended one. If we have `-o`
being a valid short option that takes an argument, and --option
a long one, then we _MUST_ accept -option as "'o' option with
argument 'ption'", which is our official recommended form.
Signed-off-by: Pierre Habouzit <madcoder@debian.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
If options are aggregated, and that the whole token is an exact
prefix of a long option that is longer than 2 letters, reject
it. This is to prevent a common typo:
$ git commit -amend
to get interpreted as "commit all with message 'end'".
The typo check isn't performed if there is no aggregation,
because the stuck form is the recommended one. If we have `-o`
being a valid short option that takes an argument, and --option
a long one, then we _MUST_ accept -option as "'o' option with
argument 'ption'", which is our official recommended form.
Signed-off-by: Pierre Habouzit <madcoder@debian.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
parse-options.c | diff | blob | history | |
t/t0040-parse-options.sh | diff | blob | history | |
test-parse-options.c | diff | blob | history |