summaryrefslogtreecommitdiffstats
path: root/parse-options.c
diff options
context:
space:
mode:
authorRené Scharfe <l.s.r@web.de>2024-03-03 13:19:43 +0100
committerJunio C Hamano <gitster@pobox.com>2024-03-03 18:49:22 +0100
commit28a92478b825a4a2c7c2c0c6b725ce92cd0b83e0 (patch)
tree24bed56192a46eeb78bb8796903fa4342fed21a0 /parse-options.c
parentparse-options: normalize arg and long_name before comparison (diff)
downloadgit-28a92478b825a4a2c7c2c0c6b725ce92cd0b83e0.tar.xz
git-28a92478b825a4a2c7c2c0c6b725ce92cd0b83e0.zip
parse-options: rearrange long_name matching code
Move the code for handling a full match of long_name first and get rid of negations. Reduce the indent of the code for matching abbreviations and remove unnecessary curly braces. Combine the checks for whether negation is allowed and whether arg is "n", "no" or "no-" because they belong together and avoid a continue statement. The result is shorter, more readable code. Signed-off-by: René Scharfe <l.s.r@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'parse-options.c')
-rw-r--r--parse-options.c37
1 files changed, 15 insertions, 22 deletions
diff --git a/parse-options.c b/parse-options.c
index d45efa4e5c..30b9e68f8a 100644
--- a/parse-options.c
+++ b/parse-options.c
@@ -413,30 +413,23 @@ static enum parse_opt_result parse_long_opt(
if (((flags ^ opt_flags) & OPT_UNSET) && !allow_unset)
continue;
- if (!skip_prefix(arg_start, long_name, &rest))
- rest = NULL;
- if (!rest) {
- /* abbreviated? */
- if (!strncmp(long_name, arg_start, arg_end - arg_start)) {
- register_abbrev(p, options, flags ^ opt_flags,
- &abbrev, &ambiguous);
- }
- /* negation allowed? */
- if (options->flags & PARSE_OPT_NONEG)
+ if (skip_prefix(arg_start, long_name, &rest)) {
+ if (*rest == '=')
+ p->opt = rest + 1;
+ else if (*rest)
continue;
- /* negated and abbreviated very much? */
- if (starts_with("no-", arg)) {
- register_abbrev(p, options, OPT_UNSET ^ opt_flags,
- &abbrev, &ambiguous);
- }
- continue;
+ return get_value(p, options, flags ^ opt_flags);
}
- if (*rest) {
- if (*rest != '=')
- continue;
- p->opt = rest + 1;
- }
- return get_value(p, options, flags ^ opt_flags);
+
+ /* abbreviated? */
+ if (!strncmp(long_name, arg_start, arg_end - arg_start))
+ register_abbrev(p, options, flags ^ opt_flags,
+ &abbrev, &ambiguous);
+
+ /* negated and abbreviated very much? */
+ if (allow_unset && starts_with("no-", arg))
+ register_abbrev(p, options, OPT_UNSET ^ opt_flags,
+ &abbrev, &ambiguous);
}
if (disallow_abbreviated_options && (ambiguous.option || abbrev.option))