Use new functions in which (#3310)

* Use new functions in which

* Impl rest_with_minimum and use it

* Use has_flag instead of get_switch
This commit is contained in:
Leonhard Kipp 2021-04-20 08:38:36 +02:00 committed by GitHub
parent 0fc9b6cfa2
commit 1a46e70dfb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 27 additions and 18 deletions

View File

@ -3,7 +3,7 @@ use indexmap::map::IndexMap;
use log::trace; use log::trace;
use nu_engine::WholeStreamCommand; use nu_engine::WholeStreamCommand;
use nu_errors::ShellError; use nu_errors::ShellError;
use nu_protocol::{Primitive, ReturnSuccess, Signature, SyntaxShape, UntaggedValue, Value}; use nu_protocol::{Primitive, Signature, SyntaxShape, UntaggedValue, Value};
use nu_source::Tagged; use nu_source::Tagged;
pub struct Which; pub struct Which;
@ -24,7 +24,7 @@ impl WholeStreamCommand for Which {
"Finds a program file, alias or custom command." "Finds a program file, alias or custom command."
} }
fn run_with_actions(&self, args: CommandArgs) -> Result<ActionStream, ShellError> { fn run(&self, args: CommandArgs) -> Result<OutputStream, ShellError> {
which(args) which(args)
} }
} }
@ -165,10 +165,9 @@ fn get_all_entries_in_path(_: &str, _: Tag) -> Vec<Value> {
vec![] vec![]
} }
#[derive(Deserialize, Debug)] #[derive(Debug)]
struct WhichArgs { struct WhichArgs {
application: Tagged<String>, applications: Vec<Tagged<String>>,
rest: Vec<Tagged<String>>,
all: bool, all: bool,
} }
@ -214,26 +213,22 @@ fn which_single(application: Tagged<String>, all: bool, scope: &Scope) -> Vec<Va
} }
} }
fn which(args: CommandArgs) -> Result<ActionStream, ShellError> { fn which(args: CommandArgs) -> Result<OutputStream, ShellError> {
let scope = args.scope.clone(); let args = args.evaluate_once()?;
let ( let which_args = WhichArgs {
WhichArgs { applications: args.rest_with_minimum(0, 1)?,
application, all: args.has_flag("all"),
rest, };
all,
},
_,
) = args.process()?;
let mut output = vec![]; let mut output = vec![];
for app in vec![application].into_iter().chain(rest.into_iter()) { for app in which_args.applications {
let values = which_single(app, all, &scope); let values = which_single(app, which_args.all, &args.scope);
output.extend(values); output.extend(values);
} }
Ok((output.into_iter().map(ReturnSuccess::value)).to_action_stream()) Ok(output.into_iter().to_output_stream())
} }
#[cfg(test)] #[cfg(test)]

View File

@ -281,4 +281,18 @@ impl EvaluatedCommandArgs {
Ok(output) Ok(output)
} }
pub fn rest_with_minimum<T: FromValue>(
&self,
pos: usize,
count: usize,
) -> Result<Vec<T>, ShellError> {
let mut output = vec![];
for i in pos..pos + count {
output.push(self.req(i)?);
}
output.extend(self.rest(pos + count)?);
Ok(output)
}
} }