2019-08-24 20:32:48 +02:00
|
|
|
use crate::commands::WholeStreamCommand;
|
|
|
|
use crate::errors::ShellError;
|
|
|
|
use crate::parser::CommandRegistry;
|
|
|
|
use crate::prelude::*;
|
|
|
|
|
|
|
|
pub struct Last;
|
|
|
|
|
2019-09-01 18:20:31 +02:00
|
|
|
#[derive(Deserialize)]
|
|
|
|
pub struct LastArgs {
|
2019-10-15 12:41:34 +02:00
|
|
|
rows: Option<Tagged<u64>>,
|
2019-09-01 18:20:31 +02:00
|
|
|
}
|
|
|
|
|
2019-08-24 20:32:48 +02:00
|
|
|
impl WholeStreamCommand for Last {
|
2019-08-30 00:52:32 +02:00
|
|
|
fn name(&self) -> &str {
|
|
|
|
"last"
|
|
|
|
}
|
|
|
|
|
|
|
|
fn signature(&self) -> Signature {
|
2019-10-15 12:41:34 +02:00
|
|
|
Signature::build("last").optional("rows", SyntaxShape::Number)
|
2019-08-30 00:52:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn usage(&self) -> &str {
|
|
|
|
"Show only the last number of rows."
|
|
|
|
}
|
|
|
|
|
2019-08-24 20:32:48 +02:00
|
|
|
fn run(
|
|
|
|
&self,
|
|
|
|
args: CommandArgs,
|
|
|
|
registry: &CommandRegistry,
|
|
|
|
) -> Result<OutputStream, ShellError> {
|
2019-09-01 18:20:31 +02:00
|
|
|
args.process(registry, last)?.run()
|
2019-08-24 20:32:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-15 12:41:34 +02:00
|
|
|
fn last(LastArgs { rows }: LastArgs, context: RunnableContext) -> Result<OutputStream, ShellError> {
|
2019-09-26 02:22:17 +02:00
|
|
|
let stream = async_stream! {
|
2019-09-01 18:20:31 +02:00
|
|
|
let v: Vec<_> = context.input.into_vec().await;
|
2019-10-15 12:41:34 +02:00
|
|
|
|
|
|
|
let rows_desired = if let Some(quantity) = rows {
|
|
|
|
*quantity
|
|
|
|
} else {
|
|
|
|
1
|
|
|
|
};
|
|
|
|
|
|
|
|
let count = (rows_desired as usize);
|
2019-09-30 05:20:18 +02:00
|
|
|
if count < v.len() {
|
|
|
|
let k = v.len() - count;
|
|
|
|
for x in v[k..].iter() {
|
|
|
|
let y: Tagged<Value> = x.clone();
|
|
|
|
yield ReturnSuccess::value(y)
|
|
|
|
}
|
2019-08-24 20:32:48 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
Ok(stream.to_output_stream())
|
|
|
|
}
|