forked from extern/nushell
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:
parent
0fc9b6cfa2
commit
1a46e70dfb
@ -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)]
|
||||||
|
@ -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)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user