mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-15 22:44:01 +00:00
Rename sort --invert to sort --reverse/-r
To match sort(1).
This commit is contained in:
parent
c5aa796d91
commit
67b0860fe7
3 changed files with 20 additions and 8 deletions
|
@ -20,7 +20,7 @@ Synopsis
|
||||||
path normalize GENERAL_OPTIONS [PATH ...]
|
path normalize GENERAL_OPTIONS [PATH ...]
|
||||||
path resolve GENERAL_OPTIONS [PATH ...]
|
path resolve GENERAL_OPTIONS [PATH ...]
|
||||||
path change-extension GENERAL_OPTIONS EXTENSION [PATH ...]
|
path change-extension GENERAL_OPTIONS EXTENSION [PATH ...]
|
||||||
path sort GENERAL_OPTIONS [-v | --invert]
|
path sort GENERAL_OPTIONS [-r | --reverse]
|
||||||
[-u | --unique] [--key=basename|dirname|path] [PATH ...]
|
[-u | --unique] [--key=basename|dirname|path] [PATH ...]
|
||||||
|
|
||||||
GENERAL_OPTIONS := [-z | --null-in] [-Z | --null-out] [-q | --quiet]
|
GENERAL_OPTIONS := [-z | --null-in] [-Z | --null-out] [-q | --quiet]
|
||||||
|
@ -345,13 +345,13 @@ Examples
|
||||||
::
|
::
|
||||||
|
|
||||||
path sort [-z | --null-in] [-Z | --null-out] \
|
path sort [-z | --null-in] [-Z | --null-out] \
|
||||||
[-q | --quiet] [-v | --invert] \
|
[-q | --quiet] [-r | --reverse] \
|
||||||
[--key=basename|dirname|path] [PATH ...]
|
[--key=basename|dirname|path] [PATH ...]
|
||||||
|
|
||||||
|
|
||||||
``path sort`` returns the given paths in sorted order. They are sorted in the same order as globs - alphabetically, but with runs of numerical digits compared numerically.
|
``path sort`` returns the given paths in sorted order. They are sorted in the same order as globs - alphabetically, but with runs of numerical digits compared numerically.
|
||||||
|
|
||||||
With ``--invert`` or ``-v`` the sort is reversed.
|
With ``--reverse`` or ``-r`` the sort is reversed.
|
||||||
|
|
||||||
With ``--key=`` only the given path of the path is compared, e.g. ``--key=dirname`` causes only the dirname to be compared, ``--key=basename`` only the basename and ``--key=path`` causes the entire path to be compared (this is the default).
|
With ``--key=`` only the given path of the path is compared, e.g. ``--key=dirname`` causes only the dirname to be compared, ``--key=basename`` only the basename and ``--key=path`` causes the entire path to be compared (this is the default).
|
||||||
|
|
||||||
|
|
|
@ -158,6 +158,7 @@ struct options_t { //!OCLINT(too many fields)
|
||||||
bool perm_valid = false;
|
bool perm_valid = false;
|
||||||
bool type_valid = false;
|
bool type_valid = false;
|
||||||
bool invert_valid = false;
|
bool invert_valid = false;
|
||||||
|
bool reverse_valid = false;
|
||||||
bool key_valid = false;
|
bool key_valid = false;
|
||||||
bool unique_valid = false;
|
bool unique_valid = false;
|
||||||
bool unique = false;
|
bool unique = false;
|
||||||
|
@ -177,6 +178,7 @@ struct options_t { //!OCLINT(too many fields)
|
||||||
path_perm_flags_t perm = 0;
|
path_perm_flags_t perm = 0;
|
||||||
|
|
||||||
bool invert = false;
|
bool invert = false;
|
||||||
|
bool reverse = false;
|
||||||
|
|
||||||
const wchar_t *arg1 = nullptr;
|
const wchar_t *arg1 = nullptr;
|
||||||
};
|
};
|
||||||
|
@ -306,8 +308,16 @@ static int handle_flag_perms(const wchar_t **argv, parser_t &parser, io_streams_
|
||||||
|
|
||||||
static int handle_flag_r(const wchar_t **argv, parser_t &parser, io_streams_t &streams,
|
static int handle_flag_r(const wchar_t **argv, parser_t &parser, io_streams_t &streams,
|
||||||
const wgetopter_t &w, options_t *opts) {
|
const wgetopter_t &w, options_t *opts) {
|
||||||
|
if (opts->reverse_valid) {
|
||||||
|
opts->reverse = true;
|
||||||
|
return STATUS_CMD_OK;
|
||||||
|
} else if (opts->perm_valid) {
|
||||||
return handle_flag_perms(argv, parser, streams, w, opts, PERM_READ);
|
return handle_flag_perms(argv, parser, streams, w, opts, PERM_READ);
|
||||||
|
}
|
||||||
|
path_unknown_option(parser, streams, argv[0], argv[w.woptind - 1]);
|
||||||
|
return STATUS_INVALID_ARGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int handle_flag_w(const wchar_t **argv, parser_t &parser, io_streams_t &streams,
|
static int handle_flag_w(const wchar_t **argv, parser_t &parser, io_streams_t &streams,
|
||||||
const wgetopter_t &w, options_t *opts) {
|
const wgetopter_t &w, options_t *opts) {
|
||||||
return handle_flag_perms(argv, parser, streams, w, opts, PERM_WRITE);
|
return handle_flag_perms(argv, parser, streams, w, opts, PERM_WRITE);
|
||||||
|
@ -387,6 +397,7 @@ static wcstring construct_short_opts(options_t *opts) { //!OCLINT(high npath co
|
||||||
short_opts.append(L"fld");
|
short_opts.append(L"fld");
|
||||||
}
|
}
|
||||||
if (opts->invert_valid) short_opts.append(L"v");
|
if (opts->invert_valid) short_opts.append(L"v");
|
||||||
|
if (opts->reverse_valid) short_opts.append(L"r");
|
||||||
if (opts->unique_valid) short_opts.append(L"u");
|
if (opts->unique_valid) short_opts.append(L"u");
|
||||||
return short_opts;
|
return short_opts;
|
||||||
}
|
}
|
||||||
|
@ -401,6 +412,7 @@ static const struct woption long_options[] = {
|
||||||
{L"perm", required_argument, nullptr, 'p'},
|
{L"perm", required_argument, nullptr, 'p'},
|
||||||
{L"type", required_argument, nullptr, 't'},
|
{L"type", required_argument, nullptr, 't'},
|
||||||
{L"invert", no_argument, nullptr, 'v'},
|
{L"invert", no_argument, nullptr, 'v'},
|
||||||
|
{L"reverse", no_argument, nullptr, 'r'},
|
||||||
{L"unique", no_argument, nullptr, 'u'},
|
{L"unique", no_argument, nullptr, 'u'},
|
||||||
{L"key", required_argument, nullptr, 1},
|
{L"key", required_argument, nullptr, 1},
|
||||||
{}};
|
{}};
|
||||||
|
@ -716,7 +728,7 @@ static int path_resolve(parser_t &parser, io_streams_t &streams, int argc, const
|
||||||
|
|
||||||
static int path_sort(parser_t &parser, io_streams_t &streams, int argc, const wchar_t **argv) {
|
static int path_sort(parser_t &parser, io_streams_t &streams, int argc, const wchar_t **argv) {
|
||||||
options_t opts;
|
options_t opts;
|
||||||
opts.invert_valid = true;
|
opts.reverse_valid = true;
|
||||||
opts.key_valid = true;
|
opts.key_valid = true;
|
||||||
opts.unique_valid = true;
|
opts.unique_valid = true;
|
||||||
int optind;
|
int optind;
|
||||||
|
@ -759,7 +771,7 @@ static int path_sort(parser_t &parser, io_streams_t &streams, int argc, const wc
|
||||||
// to avoid changing the order so you can chain calls.
|
// to avoid changing the order so you can chain calls.
|
||||||
std::stable_sort(list.begin(), list.end(),
|
std::stable_sort(list.begin(), list.end(),
|
||||||
[&](const wcstring &a, const wcstring &b) {
|
[&](const wcstring &a, const wcstring &b) {
|
||||||
if (!opts.invert)
|
if (!opts.reverse)
|
||||||
return (wcsfilecmp_glob(key[a].c_str(), key[b].c_str()) < 0);
|
return (wcsfilecmp_glob(key[a].c_str(), key[b].c_str()) < 0);
|
||||||
else
|
else
|
||||||
return (wcsfilecmp_glob(key[a].c_str(), key[b].c_str()) > 0);
|
return (wcsfilecmp_glob(key[a].c_str(), key[b].c_str()) > 0);
|
||||||
|
@ -776,7 +788,7 @@ static int path_sort(parser_t &parser, io_streams_t &streams, int argc, const wc
|
||||||
// so we have no need to transform and such.
|
// so we have no need to transform and such.
|
||||||
std::stable_sort(list.begin(), list.end(),
|
std::stable_sort(list.begin(), list.end(),
|
||||||
[&](const wcstring &a, const wcstring &b) {
|
[&](const wcstring &a, const wcstring &b) {
|
||||||
if (!opts.invert)
|
if (!opts.reverse)
|
||||||
return (wcsfilecmp_glob(a.c_str(), b.c_str()) < 0);
|
return (wcsfilecmp_glob(a.c_str(), b.c_str()) < 0);
|
||||||
else
|
else
|
||||||
return (wcsfilecmp_glob(a.c_str(), b.c_str()) > 0);
|
return (wcsfilecmp_glob(a.c_str(), b.c_str()) > 0);
|
||||||
|
|
|
@ -158,7 +158,7 @@ string replace -r "^"(pwd -P | string escape --style=regex)'/' "" -- $path
|
||||||
path resolve /banana//terracota/terracota/booooo/../pie
|
path resolve /banana//terracota/terracota/booooo/../pie
|
||||||
# CHECK: /banana/terracota/terracota/pie
|
# CHECK: /banana/terracota/terracota/pie
|
||||||
|
|
||||||
path sort --key=basename {def,abc}/{456,123,789,abc,def,0} | path sort --key=dirname -v
|
path sort --key=basename {def,abc}/{456,123,789,abc,def,0} | path sort --key=dirname -r
|
||||||
# CHECK: def/0
|
# CHECK: def/0
|
||||||
# CHECK: def/123
|
# CHECK: def/123
|
||||||
# CHECK: def/456
|
# CHECK: def/456
|
||||||
|
|
Loading…
Reference in a new issue