mirror of
https://github.com/git/git.git
synced 2025-01-22 15:33:59 +08:00
parseopt: add PARSE_OPT_KEEP_UNKNOWN
Add a parseopt flag, PARSE_OPT_KEEP_UNKNOWN, that can be used to keep unknown options in argv, similar to the existing KEEP flags. Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
934f788981
commit
b5ce3a5430
@ -274,7 +274,7 @@ int parse_options_step(struct parse_opt_ctx_t *ctx,
|
||||
case -1:
|
||||
return parse_options_usage(usagestr, options);
|
||||
case -2:
|
||||
return PARSE_OPT_UNKNOWN;
|
||||
goto unknown;
|
||||
}
|
||||
if (ctx->opt)
|
||||
check_typos(arg + 1, options);
|
||||
@ -292,7 +292,7 @@ int parse_options_step(struct parse_opt_ctx_t *ctx,
|
||||
*/
|
||||
ctx->argv[0] = xstrdup(ctx->opt - 1);
|
||||
*(char *)ctx->argv[0] = '-';
|
||||
return PARSE_OPT_UNKNOWN;
|
||||
goto unknown;
|
||||
}
|
||||
}
|
||||
continue;
|
||||
@ -314,8 +314,14 @@ int parse_options_step(struct parse_opt_ctx_t *ctx,
|
||||
case -1:
|
||||
return parse_options_usage(usagestr, options);
|
||||
case -2:
|
||||
return PARSE_OPT_UNKNOWN;
|
||||
goto unknown;
|
||||
}
|
||||
continue;
|
||||
unknown:
|
||||
if (!(ctx->flags & PARSE_OPT_KEEP_UNKNOWN))
|
||||
return PARSE_OPT_UNKNOWN;
|
||||
ctx->out[ctx->cpidx++] = ctx->argv[0];
|
||||
ctx->opt = NULL;
|
||||
}
|
||||
return PARSE_OPT_DONE;
|
||||
}
|
||||
|
@ -21,6 +21,7 @@ enum parse_opt_flags {
|
||||
PARSE_OPT_KEEP_DASHDASH = 1,
|
||||
PARSE_OPT_STOP_AT_NON_OPTION = 2,
|
||||
PARSE_OPT_KEEP_ARGV0 = 4,
|
||||
PARSE_OPT_KEEP_UNKNOWN = 8,
|
||||
};
|
||||
|
||||
enum parse_opt_option_flags {
|
||||
|
Loading…
Reference in New Issue
Block a user