use crate::commands::WholeStreamCommand; use crate::data::Value; use crate::errors::ShellError; use crate::parser::CommandRegistry; use crate::prelude::*; use futures::stream::StreamExt; pub struct Count; #[derive(Deserialize)] pub struct CountArgs {} impl WholeStreamCommand for Count { fn name(&self) -> &str { "count" } fn signature(&self) -> Signature { Signature::build("count") } fn usage(&self) -> &str { "Show the total number of rows." } fn run( &self, args: CommandArgs, registry: &CommandRegistry, ) -> Result { args.process(registry, count)?.run() } } pub fn count( CountArgs {}: CountArgs, RunnableContext { input, name, .. }: RunnableContext, ) -> Result { let stream = async_stream! { let rows: Vec = input.values.collect().await; yield ReturnSuccess::value(UntaggedValue::int(rows.len()).into_value(name)) }; Ok(stream.to_output_stream()) }