Rename sort --invert to sort --reverse/-r

To match sort(1).
This commit is contained in:
Fabian Homborg 2022-05-29 17:47:25 +02:00
parent c5aa796d91
commit 67b0860fe7
3 changed files with 20 additions and 8 deletions

View file

@ -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).

View file

@ -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) {
return handle_flag_perms(argv, parser, streams, w, opts, PERM_READ); 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);
}
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);

View file

@ -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