mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
parent
e260c42a13
commit
9adf500cf3
2 changed files with 35 additions and 1 deletions
|
@ -53,6 +53,8 @@ enum { COMMAND_NOT_BUILTIN, BUILTIN_REGULAR, BUILTIN_FUNCTION };
|
||||||
/// Error message for unexpected args.
|
/// Error message for unexpected args.
|
||||||
#define BUILTIN_ERR_ARG_COUNT1 _(L"%ls: expected %d args, got %d\n")
|
#define BUILTIN_ERR_ARG_COUNT1 _(L"%ls: expected %d args, got %d\n")
|
||||||
#define BUILTIN_ERR_ARG_COUNT2 _(L"%ls: %ls expected %d args, got %d\n")
|
#define BUILTIN_ERR_ARG_COUNT2 _(L"%ls: %ls expected %d args, got %d\n")
|
||||||
|
#define BUILTIN_ERR_MIN_ARG_COUNT1 _(L"%ls: Expected at least %d args, got only %d\n")
|
||||||
|
#define BUILTIN_ERR_MAX_ARG_COUNT1 _(L"%ls: Expected at most %d args, got %d\n")
|
||||||
|
|
||||||
/// Error message for invalid variable name.
|
/// Error message for invalid variable name.
|
||||||
#define BUILTIN_ERR_VARNAME _(L"%ls: Variable name '%ls' is not valid. See `help identifiers`.\n")
|
#define BUILTIN_ERR_VARNAME _(L"%ls: Variable name '%ls' is not valid. See `help identifiers`.\n")
|
||||||
|
|
|
@ -50,6 +50,8 @@ class argparse_cmd_opts_t {
|
||||||
public:
|
public:
|
||||||
bool print_help = false;
|
bool print_help = false;
|
||||||
bool require_order = false;
|
bool require_order = false;
|
||||||
|
size_t min_args = 0;
|
||||||
|
size_t max_args = SIZE_T_MAX;
|
||||||
wcstring name = L"argparse";
|
wcstring name = L"argparse";
|
||||||
wcstring_list_t raw_exclusive_flags;
|
wcstring_list_t raw_exclusive_flags;
|
||||||
wcstring_list_t argv;
|
wcstring_list_t argv;
|
||||||
|
@ -64,11 +66,13 @@ class argparse_cmd_opts_t {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static const wchar_t *short_options = L"+:hn:rx:";
|
static const wchar_t *short_options = L"+:hn:rx:N:X:";
|
||||||
static const struct woption long_options[] = {{L"require-order", no_argument, NULL, 'r'},
|
static const struct woption long_options[] = {{L"require-order", no_argument, NULL, 'r'},
|
||||||
{L"name", required_argument, NULL, 'n'},
|
{L"name", required_argument, NULL, 'n'},
|
||||||
{L"exclusive", required_argument, NULL, 'x'},
|
{L"exclusive", required_argument, NULL, 'x'},
|
||||||
{L"help", no_argument, NULL, 'h'},
|
{L"help", no_argument, NULL, 'h'},
|
||||||
|
{L"min-args", required_argument, NULL, 'N'},
|
||||||
|
{L"max-args", required_argument, NULL, 'X'},
|
||||||
{NULL, 0, NULL, 0}};
|
{NULL, 0, NULL, 0}};
|
||||||
|
|
||||||
// Check if any pair of mutually exclusive options was seen. Note that since every option must have
|
// Check if any pair of mutually exclusive options was seen. Note that since every option must have
|
||||||
|
@ -273,6 +277,26 @@ static int parse_cmd_opts(argparse_cmd_opts_t &opts, int *optind, //!OCLINT(hig
|
||||||
opts.print_help = true;
|
opts.print_help = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case 'N': {
|
||||||
|
long x = fish_wcstol(w.woptarg);
|
||||||
|
if (errno || x < 0) {
|
||||||
|
streams.err.append_format(_(L"%ls: Invalid --min-args value '%ls'\n"), cmd,
|
||||||
|
w.woptarg);
|
||||||
|
return STATUS_INVALID_ARGS;
|
||||||
|
}
|
||||||
|
opts.min_args = x;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 'X': {
|
||||||
|
long x = fish_wcstol(w.woptarg);
|
||||||
|
if (errno || x < 0) {
|
||||||
|
streams.err.append_format(_(L"%ls: Invalid --max-args value '%ls'\n"), cmd,
|
||||||
|
w.woptarg);
|
||||||
|
return STATUS_INVALID_ARGS;
|
||||||
|
}
|
||||||
|
opts.max_args = x;
|
||||||
|
break;
|
||||||
|
}
|
||||||
case ':': {
|
case ':': {
|
||||||
builtin_missing_argument(parser, streams, cmd, argv[w.woptind - 1]);
|
builtin_missing_argument(parser, streams, cmd, argv[w.woptind - 1]);
|
||||||
return STATUS_INVALID_ARGS;
|
return STATUS_INVALID_ARGS;
|
||||||
|
@ -404,6 +428,14 @@ static int argparse_parse_args(argparse_cmd_opts_t &opts, const wcstring_list_t
|
||||||
update_bool_flag_counts(opts);
|
update_bool_flag_counts(opts);
|
||||||
|
|
||||||
for (int i = optind; argv[i]; i++) opts.argv.push_back(argv[i]);
|
for (int i = optind; argv[i]; i++) opts.argv.push_back(argv[i]);
|
||||||
|
if (opts.min_args > 0 && opts.argv.size() < opts.min_args) {
|
||||||
|
streams.err.append_format(BUILTIN_ERR_MIN_ARG_COUNT1, cmd, opts.min_args, opts.argv.size());
|
||||||
|
return STATUS_CMD_ERROR;
|
||||||
|
}
|
||||||
|
if (opts.max_args != SIZE_T_MAX && opts.argv.size() > opts.max_args) {
|
||||||
|
streams.err.append_format(BUILTIN_ERR_MAX_ARG_COUNT1, cmd, opts.max_args, opts.argv.size());
|
||||||
|
return STATUS_CMD_ERROR;
|
||||||
|
}
|
||||||
return STATUS_CMD_OK;
|
return STATUS_CMD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue