From b1b93931cb243d80938d255d83d5ea9b7a453e2b Mon Sep 17 00:00:00 2001 From: "Joseph T. Lyons" Date: Thu, 9 Jul 2020 09:07:51 -0400 Subject: [PATCH] Return an iter from `last` command (#2143) --- crates/nu-cli/src/commands/last.rs | 22 ++++++++-------------- 1 file changed, 8 insertions(+), 14 deletions(-) diff --git a/crates/nu-cli/src/commands/last.rs b/crates/nu-cli/src/commands/last.rs index 2b51fb93dc..46630f7e18 100644 --- a/crates/nu-cli/src/commands/last.rs +++ b/crates/nu-cli/src/commands/last.rs @@ -2,7 +2,7 @@ use crate::commands::WholeStreamCommand; use crate::context::CommandRegistry; use crate::prelude::*; use nu_errors::ShellError; -use nu_protocol::{ReturnSuccess, Signature, SyntaxShape, UntaggedValue, Value}; +use nu_protocol::{Signature, SyntaxShape, UntaggedValue, Value}; use nu_source::Tagged; pub struct Last; @@ -63,27 +63,21 @@ async fn last(args: CommandArgs, registry: &CommandRegistry) -> Result = input.into_vec().await; - let rows_desired = if let Some(quantity) = rows { - *quantity + let end_rows_desired = if let Some(quantity) = rows { + *quantity as usize } else { 1 }; - let count = rows_desired as usize; - - let k = if count < v.len() { - v.len() - count + let beginning_rows_to_skip = if end_rows_desired < v.len() { + v.len() - end_rows_desired } else { - return Ok(futures::stream::iter(v).to_output_stream()); + 0 }; - let mut values_vec_deque = VecDeque::new(); + let iter = v.into_iter().skip(beginning_rows_to_skip); - for x in v[k..].iter() { - values_vec_deque.push_back(ReturnSuccess::value(x.clone())); - } - - Ok(futures::stream::iter(values_vec_deque).to_output_stream()) + Ok(futures::stream::iter(iter).to_output_stream()) } #[cfg(test)]