mirror of
https://github.com/nushell/nushell
synced 2025-01-10 12:19:14 +00:00
51 lines
1.2 KiB
Rust
51 lines
1.2 KiB
Rust
use crate::commands::WholeStreamCommand;
|
|
use crate::context::CommandRegistry;
|
|
use crate::errors::ShellError;
|
|
use crate::object::base::select_fields;
|
|
use crate::prelude::*;
|
|
|
|
#[derive(Deserialize)]
|
|
struct PickArgs {
|
|
rest: Vec<Tagged<String>>,
|
|
}
|
|
|
|
pub struct Pick;
|
|
|
|
impl WholeStreamCommand for Pick {
|
|
fn name(&self) -> &str {
|
|
"pick"
|
|
}
|
|
|
|
fn signature(&self) -> Signature {
|
|
Signature::build("pick").rest()
|
|
}
|
|
|
|
fn run(
|
|
&self,
|
|
args: CommandArgs,
|
|
registry: &CommandRegistry,
|
|
) -> Result<OutputStream, ShellError> {
|
|
args.process(registry, pick)?.run()
|
|
}
|
|
}
|
|
|
|
fn pick(
|
|
PickArgs { rest: fields }: PickArgs,
|
|
RunnableContext { input, name, .. }: RunnableContext,
|
|
) -> Result<OutputStream, ShellError> {
|
|
if fields.len() == 0 {
|
|
return Err(ShellError::labeled_error(
|
|
"Pick requires columns to pick",
|
|
"needs parameter",
|
|
name,
|
|
));
|
|
}
|
|
|
|
let fields: Vec<_> = fields.iter().map(|f| f.item.clone()).collect();
|
|
|
|
let objects = input
|
|
.values
|
|
.map(move |value| select_fields(&value.item, &fields, value.tag()));
|
|
|
|
Ok(objects.from_input_stream())
|
|
}
|