nushell/src/commands/which_.rs

78 lines
2.1 KiB
Rust
Raw Normal View History

2019-08-15 07:02:02 +02:00
use crate::commands::WholeStreamCommand;
use crate::prelude::*;
use nu_errors::ShellError;
2019-11-30 01:21:05 +01:00
use nu_protocol::{Primitive, Signature, SyntaxShape, UntaggedValue, Value};
2019-08-10 09:06:08 +02:00
pub struct Which;
2019-08-15 07:02:02 +02:00
impl WholeStreamCommand for Which {
fn name(&self) -> &str {
"which"
}
fn signature(&self) -> Signature {
2019-10-28 06:15:35 +01:00
Signature::build("which").required(
"name",
SyntaxShape::Any,
"the name of the command to find the path to",
)
}
fn usage(&self) -> &str {
"Finds a program file."
}
2019-08-10 09:06:08 +02:00
fn run(
&self,
args: CommandArgs,
registry: &CommandRegistry,
) -> Result<OutputStream, ShellError> {
which(args, registry)
}
}
pub fn which(args: CommandArgs, registry: &CommandRegistry) -> Result<OutputStream, ShellError> {
let args = args.evaluate_once(registry)?;
let mut which_out = VecDeque::new();
let tag = args.call_info.name_tag.clone();
2019-08-10 09:06:08 +02:00
if let Some(v) = &args.call_info.args.positional {
if !v.is_empty() {
2019-08-10 09:06:08 +02:00
match &v[0] {
Value {
value: UntaggedValue::Primitive(Primitive::String(s)),
2019-08-10 09:06:08 +02:00
tag,
} => {
if let Ok(ok) = which::which(&s) {
which_out.push_back(
UntaggedValue::Primitive(Primitive::Path(ok)).into_value(tag.clone()),
);
2019-08-10 09:06:08 +02:00
}
}
Value { tag, .. } => {
2019-08-10 09:06:08 +02:00
return Err(ShellError::labeled_error(
"Expected a filename to find",
"needs a filename",
tag,
2019-08-10 09:06:08 +02:00
));
}
}
} else {
return Err(ShellError::labeled_error(
"Expected a binary to find",
"needs application name",
tag,
2019-08-10 09:06:08 +02:00
));
}
} else {
return Err(ShellError::labeled_error(
"Expected a binary to find",
"needs application name",
tag,
2019-08-10 09:06:08 +02:00
));
}
Ok(which_out.to_output_stream())
}