Remove group command (#14056)

# Description

Removes the `group` command that was deprecated back in 0.96.0 with
#13377.

# User-Facing Changes

Breaking change, removed `group` command.
This commit is contained in:
Ian Manske 2024-10-11 04:43:12 -07:00 committed by GitHub
parent 2df91e7f92
commit a95c2198a6
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 1 additions and 136 deletions

View file

@ -46,7 +46,6 @@ pub fn add_shell_command_context(mut engine_state: EngineState) -> EngineState {
First, First,
Flatten, Flatten,
Get, Get,
Group,
GroupBy, GroupBy,
Headers, Headers,
Insert, Insert,

View file

@ -1,132 +0,0 @@
use nu_engine::command_prelude::*;
use nu_protocol::{report_shell_warning, ValueIterator};
#[derive(Clone)]
pub struct Group;
impl Command for Group {
fn name(&self) -> &str {
"group"
}
fn signature(&self) -> Signature {
Signature::build("group")
// TODO: It accepts Table also, but currently there is no Table
// example. Perhaps Table should be a subtype of List, in which case
// the current signature would suffice even when a Table example
// exists.
.input_output_types(vec![(
Type::List(Box::new(Type::Any)),
Type::List(Box::new(Type::List(Box::new(Type::Any)))),
)])
.required("group_size", SyntaxShape::Int, "The size of each group.")
.category(Category::Filters)
}
fn description(&self) -> &str {
"Groups input into groups of `group_size`."
}
fn examples(&self) -> Vec<Example> {
let stream_test_1 = vec![
Value::list(
vec![Value::test_int(1), Value::test_int(2)],
Span::test_data(),
),
Value::list(
vec![Value::test_int(3), Value::test_int(4)],
Span::test_data(),
),
];
vec![Example {
example: "[1 2 3 4] | group 2",
description: "Group the a list by pairs",
result: Some(Value::list(stream_test_1, Span::test_data())),
}]
}
fn run(
&self,
engine_state: &EngineState,
stack: &mut Stack,
call: &Call,
input: PipelineData,
) -> Result<PipelineData, ShellError> {
let head = call.head;
report_shell_warning(
engine_state,
&ShellError::Deprecated {
old_command: "group".into(),
new_suggestion: "the new `chunks` command".into(),
span: head,
url: "`help chunks`".into(),
},
);
let group_size: Spanned<usize> = call.req(engine_state, stack, 0)?;
let metadata = input.metadata();
let each_group_iterator = EachGroupIterator {
group_size: group_size.item,
input: Box::new(input.into_iter()),
span: head,
};
Ok(each_group_iterator.into_pipeline_data_with_metadata(
head,
engine_state.signals().clone(),
metadata,
))
}
}
struct EachGroupIterator {
group_size: usize,
input: ValueIterator,
span: Span,
}
impl Iterator for EachGroupIterator {
type Item = Value;
fn next(&mut self) -> Option<Self::Item> {
let mut group = vec![];
let mut current_count = 0;
loop {
let item = self.input.next();
match item {
Some(v) => {
group.push(v);
current_count += 1;
if current_count >= self.group_size {
break;
}
}
None => break,
}
}
if group.is_empty() {
return None;
}
Some(Value::list(group, self.span))
}
}
#[cfg(test)]
mod test {
use super::*;
#[test]
fn test_examples() {
use crate::test_examples;
test_examples(Group {})
}
}

View file

@ -15,7 +15,6 @@ mod find;
mod first; mod first;
mod flatten; mod flatten;
mod get; mod get;
mod group;
mod group_by; mod group_by;
mod headers; mod headers;
mod insert; mod insert;
@ -73,7 +72,6 @@ pub use find::Find;
pub use first::First; pub use first::First;
pub use flatten::Flatten; pub use flatten::Flatten;
pub use get::Get; pub use get::Get;
pub use group::Group;
pub use group_by::GroupBy; pub use group_by::GroupBy;
pub use headers::Headers; pub use headers::Headers;
pub use insert::Insert; pub use insert::Insert;

View file

@ -9,7 +9,7 @@ fn each_works_separately() {
#[test] #[test]
fn each_group_works() { fn each_group_works() {
let actual = nu!("echo [1 2 3 4 5 6] | group 3 | to json --raw"); let actual = nu!("echo [1 2 3 4 5 6] | chunks 3 | to json --raw");
assert_eq!(actual.out, "[[1,2,3],[4,5,6]]"); assert_eq!(actual.out, "[[1,2,3],[4,5,6]]");
} }