Browse Source

parse-opt: do not print errors on unknown options, return -2 intead.

This way we can catch "unknown" options more easily.

Signed-off-by: Pierre Habouzit <madcoder@debian.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Pierre Habouzit 17 years ago committed by Junio C Hamano
parent
commit
07fe54db3c
  1. 43
      parse-options.c

43
parse-options.c

@ -94,14 +94,14 @@ static int get_value(struct parse_opt_ctx_t *p,


case OPTION_CALLBACK: case OPTION_CALLBACK:
if (unset) if (unset)
return (*opt->callback)(opt, NULL, 1); return (*opt->callback)(opt, NULL, 1) ? (-1) : 0;
if (opt->flags & PARSE_OPT_NOARG) if (opt->flags & PARSE_OPT_NOARG)
return (*opt->callback)(opt, NULL, 0); return (*opt->callback)(opt, NULL, 0) ? (-1) : 0;
if (opt->flags & PARSE_OPT_OPTARG && !p->opt) if (opt->flags & PARSE_OPT_OPTARG && !p->opt)
return (*opt->callback)(opt, NULL, 0); return (*opt->callback)(opt, NULL, 0) ? (-1) : 0;
if (!arg) if (!arg)
return opterror(opt, "requires a value", flags); return opterror(opt, "requires a value", flags);
return (*opt->callback)(opt, get_arg(p), 0); return (*opt->callback)(opt, get_arg(p), 0) ? (-1) : 0;


case OPTION_INTEGER: case OPTION_INTEGER:
if (unset) { if (unset) {
@ -132,7 +132,7 @@ static int parse_short_opt(struct parse_opt_ctx_t *p, const struct option *optio
return get_value(p, options, OPT_SHORT); return get_value(p, options, OPT_SHORT);
} }
} }
return error("unknown switch `%c'", *p->opt); return -2;
} }


static int parse_long_opt(struct parse_opt_ctx_t *p, const char *arg, static int parse_long_opt(struct parse_opt_ctx_t *p, const char *arg,
@ -217,7 +217,7 @@ is_abbreviated:
abbrev_option->long_name); abbrev_option->long_name);
if (abbrev_option) if (abbrev_option)
return get_value(p, abbrev_option, abbrev_flags); return get_value(p, abbrev_option, abbrev_flags);
return error("unknown option `%s'", arg); return -2;
} }


void check_typos(const char *arg, const struct option *options) void check_typos(const char *arg, const struct option *options)
@ -271,15 +271,23 @@ int parse_options_step(struct parse_opt_ctx_t *ctx,
ctx->opt = arg + 1; ctx->opt = arg + 1;
if (*ctx->opt == 'h') if (*ctx->opt == 'h')
return parse_options_usage(usagestr, options); return parse_options_usage(usagestr, options);
if (parse_short_opt(ctx, options) < 0) switch (parse_short_opt(ctx, options)) {
usage_with_options(usagestr, options); case -1:
return parse_options_usage(usagestr, options);
case -2:
return PARSE_OPT_UNKNOWN;
}
if (ctx->opt) if (ctx->opt)
check_typos(arg + 1, options); check_typos(arg + 1, options);
while (ctx->opt) { while (ctx->opt) {
if (*ctx->opt == 'h') if (*ctx->opt == 'h')
return parse_options_usage(usagestr, options); return parse_options_usage(usagestr, options);
if (parse_short_opt(ctx, options) < 0) switch (parse_short_opt(ctx, options)) {
usage_with_options(usagestr, options); case -1:
return parse_options_usage(usagestr, options);
case -2:
return PARSE_OPT_UNKNOWN;
}
} }
continue; continue;
} }
@ -296,8 +304,12 @@ int parse_options_step(struct parse_opt_ctx_t *ctx,
return usage_with_options_internal(usagestr, options, 1); return usage_with_options_internal(usagestr, options, 1);
if (!strcmp(arg + 2, "help")) if (!strcmp(arg + 2, "help"))
return parse_options_usage(usagestr, options); return parse_options_usage(usagestr, options);
if (parse_long_opt(ctx, arg + 2, options)) switch (parse_long_opt(ctx, arg + 2, options)) {
usage_with_options(usagestr, options); case -1:
return parse_options_usage(usagestr, options);
case -2:
return PARSE_OPT_UNKNOWN;
}
} }
return PARSE_OPT_DONE; return PARSE_OPT_DONE;
} }
@ -321,7 +333,12 @@ int parse_options(int argc, const char **argv, const struct option *options,
case PARSE_OPT_DONE: case PARSE_OPT_DONE:
break; break;
default: /* PARSE_OPT_UNKNOWN */ default: /* PARSE_OPT_UNKNOWN */
abort(); /* unreached yet */ if (ctx.argv[0][1] == '-') {
error("unknown option `%s'", ctx.argv[0] + 2);
} else {
error("unknown switch `%c'", *ctx.opt);
}
usage_with_options(usagestr, options);
} }


return parse_options_end(&ctx); return parse_options_end(&ctx);

Loading…
Cancel
Save