parse-options: remove PARSE_OPT_NEGHELP

PARSE_OPT_NEGHELP is confusing because short options defined with that
flag do the opposite of what the helptext says. It is also not needed
anymore now that options starting with no- can be negated by removing
that prefix. Convert its only two users to OPT_NEGBIT() and OPT_BOOL()
and then remove support for PARSE_OPT_NEGHELP.

Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx>
Acked-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
René Scharfe 2012-02-28 20:06:09 +01:00 committed by Junio C Hamano
parent 0f1930c587
commit cbb08c2e0b
4 changed files with 5 additions and 13 deletions

View File

@ -647,9 +647,7 @@ int cmd_fast_export(int argc, const char **argv, const char *prefix)
"Output full tree for each commit"), "Output full tree for each commit"),
OPT_BOOLEAN(0, "use-done-feature", &use_done_feature, OPT_BOOLEAN(0, "use-done-feature", &use_done_feature,
"Use the done feature to terminate the stream"), "Use the done feature to terminate the stream"),
{ OPTION_NEGBIT, 0, "data", &no_data, NULL, OPT_BOOL(0, "no-data", &no_data, "Skip output of blob data"),
"Skip output of blob data",
PARSE_OPT_NOARG | PARSE_OPT_NEGHELP, NULL, 1 },
OPT_END() OPT_END()
}; };

View File

@ -777,8 +777,8 @@ int cmd_grep(int argc, const char **argv, const char *prefix)
struct option options[] = { struct option options[] = {
OPT_BOOLEAN(0, "cached", &cached, OPT_BOOLEAN(0, "cached", &cached,
"search in index instead of in the work tree"), "search in index instead of in the work tree"),
OPT_BOOLEAN(0, "index", &use_index, OPT_NEGBIT(0, "no-index", &use_index,
"--no-index finds in contents not managed by git"), "finds in contents not managed by git", 1),
OPT_GROUP(""), OPT_GROUP(""),
OPT_BOOLEAN('v', "invert-match", &opt.invert, OPT_BOOLEAN('v', "invert-match", &opt.invert,
"show non-matching lines"), "show non-matching lines"),

View File

@ -533,7 +533,7 @@ static int usage_with_options_internal(struct parse_opt_ctx_t *ctx,
continue; continue;
pos = fprintf(outfile, " "); pos = fprintf(outfile, " ");
if (opts->short_name && !(opts->flags & PARSE_OPT_NEGHELP)) { if (opts->short_name) {
if (opts->flags & PARSE_OPT_NODASH) if (opts->flags & PARSE_OPT_NODASH)
pos += fprintf(outfile, "%c", opts->short_name); pos += fprintf(outfile, "%c", opts->short_name);
else else
@ -542,9 +542,7 @@ static int usage_with_options_internal(struct parse_opt_ctx_t *ctx,
if (opts->long_name && opts->short_name) if (opts->long_name && opts->short_name)
pos += fprintf(outfile, ", "); pos += fprintf(outfile, ", ");
if (opts->long_name) if (opts->long_name)
pos += fprintf(outfile, "--%s%s", pos += fprintf(outfile, "--%s", opts->long_name);
(opts->flags & PARSE_OPT_NEGHELP) ? "no-" : "",
opts->long_name);
if (opts->type == OPTION_NUMBER) if (opts->type == OPTION_NUMBER)
pos += fprintf(outfile, "-NUM"); pos += fprintf(outfile, "-NUM");

View File

@ -40,7 +40,6 @@ enum parse_opt_option_flags {
PARSE_OPT_LASTARG_DEFAULT = 16, PARSE_OPT_LASTARG_DEFAULT = 16,
PARSE_OPT_NODASH = 32, PARSE_OPT_NODASH = 32,
PARSE_OPT_LITERAL_ARGHELP = 64, PARSE_OPT_LITERAL_ARGHELP = 64,
PARSE_OPT_NEGHELP = 128,
PARSE_OPT_SHELL_EVAL = 256 PARSE_OPT_SHELL_EVAL = 256
}; };
@ -90,9 +89,6 @@ typedef int parse_opt_ll_cb(struct parse_opt_ctx_t *ctx,
* PARSE_OPT_LITERAL_ARGHELP: says that argh shouldn't be enclosed in brackets * PARSE_OPT_LITERAL_ARGHELP: says that argh shouldn't be enclosed in brackets
* (i.e. '<argh>') in the help message. * (i.e. '<argh>') in the help message.
* Useful for options with multiple parameters. * Useful for options with multiple parameters.
* PARSE_OPT_NEGHELP: says that the long option should always be shown with
* the --no prefix in the usage message. Sometimes
* useful for users of OPTION_NEGBIT.
* *
* `callback`:: * `callback`::
* pointer to the callback to use for OPTION_CALLBACK or * pointer to the callback to use for OPTION_CALLBACK or