mirror of
https://github.com/nushell/nushell
synced 2025-01-14 22:24:54 +00:00
Engine-p style in compact (#3325)
* Engine-p style in compact * Remove unused import * Use filter in compact, thanks to clippy for spotting it :]
This commit is contained in:
parent
d8e105fe34
commit
033df9457b
1 changed files with 23 additions and 30 deletions
|
@ -2,14 +2,13 @@ use crate::prelude::*;
|
|||
|
||||
use nu_engine::WholeStreamCommand;
|
||||
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 Compact;
|
||||
|
||||
#[derive(Deserialize)]
|
||||
pub struct CompactArgs {
|
||||
rest: Vec<Tagged<String>>,
|
||||
columns: Vec<Tagged<String>>,
|
||||
}
|
||||
|
||||
impl WholeStreamCommand for Compact {
|
||||
|
@ -25,7 +24,7 @@ impl WholeStreamCommand for Compact {
|
|||
"Creates a table with non-empty rows."
|
||||
}
|
||||
|
||||
fn run_with_actions(&self, args: CommandArgs) -> Result<ActionStream, ShellError> {
|
||||
fn run(&self, args: CommandArgs) -> Result<OutputStream, ShellError> {
|
||||
compact(args)
|
||||
}
|
||||
|
||||
|
@ -38,36 +37,30 @@ impl WholeStreamCommand for Compact {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn compact(args: CommandArgs) -> Result<ActionStream, ShellError> {
|
||||
let (CompactArgs { rest: columns }, input) = args.process()?;
|
||||
pub fn compact(args: CommandArgs) -> Result<OutputStream, ShellError> {
|
||||
let (args, input) = args.extract(|params| {
|
||||
Ok(CompactArgs {
|
||||
columns: params.rest(0)?,
|
||||
})
|
||||
})?;
|
||||
|
||||
Ok(input
|
||||
.filter_map(move |item| {
|
||||
if columns.is_empty() {
|
||||
if !item.is_empty() {
|
||||
Some(ReturnSuccess::value(item))
|
||||
} else {
|
||||
None
|
||||
}
|
||||
} else {
|
||||
match item {
|
||||
Value {
|
||||
.filter(move |item| {
|
||||
if args.columns.is_empty() {
|
||||
!item.is_empty()
|
||||
} else if let Value {
|
||||
value: UntaggedValue::Row(ref r),
|
||||
..
|
||||
} => {
|
||||
if columns
|
||||
} = item
|
||||
{
|
||||
args.columns
|
||||
.iter()
|
||||
.all(|field| r.get_data(field).borrow().is_some())
|
||||
{
|
||||
Some(ReturnSuccess::value(item))
|
||||
} else {
|
||||
None
|
||||
}
|
||||
}
|
||||
_ => None,
|
||||
}
|
||||
false
|
||||
}
|
||||
})
|
||||
.to_action_stream())
|
||||
.to_output_stream())
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
|
|
Loading…
Reference in a new issue