forked from extern/nushell
Merge pull request #503 from twe4ked/remove-sort-by-reverse-flag
Remove sort-by --reverse flag
This commit is contained in:
commit
94752a3004
@ -202,7 +202,7 @@ Nu adheres closely to a set of goals that make up its design philosophy. As feat
|
|||||||
| pick ...columns | Down-select table to only these columns |
|
| pick ...columns | Down-select table to only these columns |
|
||||||
| reject ...columns | Remove the given columns from the table |
|
| reject ...columns | Remove the given columns from the table |
|
||||||
| get column-or-column-path | Open given cells as text |
|
| get column-or-column-path | Open given cells as text |
|
||||||
| sort-by ...columns (--reverse) | Sort by the given columns |
|
| sort-by ...columns | Sort by the given columns |
|
||||||
| where condition | Filter table to match the condition |
|
| where condition | Filter table to match the condition |
|
||||||
| inc (field) | Increment a value or version. Optional use the field of a table |
|
| inc (field) | Increment a value or version. Optional use the field of a table |
|
||||||
| add field value | Add a new field to the table |
|
| add field value | Add a new field to the table |
|
||||||
|
@ -7,7 +7,6 @@ pub struct SortBy;
|
|||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
pub struct SortByArgs {
|
pub struct SortByArgs {
|
||||||
rest: Vec<Tagged<String>>,
|
rest: Vec<Tagged<String>>,
|
||||||
reverse: bool,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl WholeStreamCommand for SortBy {
|
impl WholeStreamCommand for SortBy {
|
||||||
@ -24,14 +23,12 @@ impl WholeStreamCommand for SortBy {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn signature(&self) -> Signature {
|
fn signature(&self) -> Signature {
|
||||||
Signature::build("sort-by")
|
Signature::build("sort-by").rest(SyntaxType::String)
|
||||||
.rest(SyntaxType::String)
|
|
||||||
.switch("reverse")
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn sort_by(
|
fn sort_by(
|
||||||
SortByArgs { reverse, rest }: SortByArgs,
|
SortByArgs { rest }: SortByArgs,
|
||||||
mut context: RunnableContext,
|
mut context: RunnableContext,
|
||||||
) -> Result<OutputStream, ShellError> {
|
) -> Result<OutputStream, ShellError> {
|
||||||
Ok(OutputStream::new(async_stream_block! {
|
Ok(OutputStream::new(async_stream_block! {
|
||||||
@ -42,11 +39,7 @@ fn sort_by(
|
|||||||
.map(|f| item.get_data_by_key(f).map(|i| i.clone()))
|
.map(|f| item.get_data_by_key(f).map(|i| i.clone()))
|
||||||
.collect::<Vec<Option<Tagged<Value>>>>()
|
.collect::<Vec<Option<Tagged<Value>>>>()
|
||||||
};
|
};
|
||||||
if reverse {
|
vec.sort_by_cached_key(calc_key);
|
||||||
vec.sort_by_cached_key(|item| std::cmp::Reverse(calc_key(item)));
|
|
||||||
} else {
|
|
||||||
vec.sort_by_cached_key(calc_key);
|
|
||||||
};
|
|
||||||
|
|
||||||
for item in vec {
|
for item in vec {
|
||||||
yield item.into();
|
yield item.into();
|
||||||
|
@ -215,17 +215,6 @@ fn can_sort_by_column() {
|
|||||||
assert_eq!(output, "description");
|
assert_eq!(output, "description");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn can_sort_by_column_reverse() {
|
|
||||||
nu!(
|
|
||||||
output,
|
|
||||||
cwd("tests/fixtures/formats"),
|
|
||||||
r#"open cargo_sample.toml --raw | lines | skip 1 | first 4 | split-column "=" | sort-by Column1 --reverse | skip 1 | first 1 | get Column1 | trim | echo $it"#
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(output, "name");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn can_split_by_column() {
|
fn can_split_by_column() {
|
||||||
nu!(
|
nu!(
|
||||||
|
Loading…
Reference in New Issue
Block a user