mirror of
https://github.com/nushell/nushell.git
synced 2025-01-13 09:48:30 +01:00
Remove try_trait feature use
This commit is contained in:
parent
3e72c3eca9
commit
012d8f3d6f
31
src/cli.rs
31
src/cli.rs
@ -330,31 +330,6 @@ enum LineResult {
|
|||||||
FatalError(String, ShellError),
|
FatalError(String, ShellError),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl std::ops::Try for LineResult {
|
|
||||||
type Ok = Option<String>;
|
|
||||||
type Error = (String, ShellError);
|
|
||||||
|
|
||||||
fn into_result(self) -> Result<Option<String>, (String, ShellError)> {
|
|
||||||
match self {
|
|
||||||
LineResult::Success(s) => Ok(Some(s)),
|
|
||||||
LineResult::Error(string, err) => Err((string, err)),
|
|
||||||
LineResult::Break => Ok(None),
|
|
||||||
LineResult::CtrlC => Ok(None),
|
|
||||||
LineResult::FatalError(string, err) => Err((string, err)),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fn from_error(v: (String, ShellError)) -> Self {
|
|
||||||
LineResult::Error(v.0, v.1)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn from_ok(v: Option<String>) -> Self {
|
|
||||||
match v {
|
|
||||||
None => LineResult::Break,
|
|
||||||
Some(v) => LineResult::Success(v),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn process_line(readline: Result<String, ReadlineError>, ctx: &mut Context) -> LineResult {
|
async fn process_line(readline: Result<String, ReadlineError>, ctx: &mut Context) -> LineResult {
|
||||||
match &readline {
|
match &readline {
|
||||||
Ok(line) if line.trim() == "" => LineResult::Success(line.clone()),
|
Ok(line) if line.trim() == "" => LineResult::Success(line.clone()),
|
||||||
@ -371,8 +346,10 @@ async fn process_line(readline: Result<String, ReadlineError>, ctx: &mut Context
|
|||||||
debug!("=== Parsed ===");
|
debug!("=== Parsed ===");
|
||||||
debug!("{:#?}", result);
|
debug!("{:#?}", result);
|
||||||
|
|
||||||
let mut pipeline = classify_pipeline(&result, ctx, &Text::from(line))
|
let mut pipeline = match classify_pipeline(&result, ctx, &Text::from(line)) {
|
||||||
.map_err(|err| (line.clone(), err))?;
|
Ok(pipeline) => pipeline,
|
||||||
|
Err(err) => return LineResult::Error(line.clone(), err),
|
||||||
|
};
|
||||||
|
|
||||||
match pipeline.commands.last() {
|
match pipeline.commands.last() {
|
||||||
Some(ClassifiedCommand::External(_)) => {}
|
Some(ClassifiedCommand::External(_)) => {}
|
||||||
|
@ -596,14 +596,10 @@ impl Command {
|
|||||||
.unwrap();
|
.unwrap();
|
||||||
// We don't have an $it or block, so just execute what we have
|
// We don't have an $it or block, so just execute what we have
|
||||||
|
|
||||||
command
|
match command.run(&call_info, ®istry, &raw_args.shell_manager, nothing) {
|
||||||
.run(&call_info, ®istry, &raw_args.shell_manager, nothing)?
|
Ok(o) => o,
|
||||||
.into()
|
Err(e) => OutputStream::one(Err(e)),
|
||||||
// let out = match command.run(&call_info, ®istry, &raw_args.shell_manager, nothing) {
|
}
|
||||||
// Ok(o) => o,
|
|
||||||
// Err(e) => VecDeque::from(vec![ReturnValue::Err(e)]),
|
|
||||||
// };
|
|
||||||
// Ok(out.to_output_stream())
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
#![feature(crate_visibility_modifier)]
|
#![feature(crate_visibility_modifier)]
|
||||||
#![feature(in_band_lifetimes)]
|
#![feature(in_band_lifetimes)]
|
||||||
#![feature(generators)]
|
#![feature(generators)]
|
||||||
#![feature(try_trait)]
|
|
||||||
#![feature(bind_by_move_pattern_guards)]
|
#![feature(bind_by_move_pattern_guards)]
|
||||||
#![feature(specialization)]
|
#![feature(specialization)]
|
||||||
#![feature(proc_macro_hygiene)]
|
#![feature(proc_macro_hygiene)]
|
||||||
|
@ -84,22 +84,6 @@ impl OutputStream {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl std::ops::Try for OutputStream {
|
|
||||||
type Ok = OutputStream;
|
|
||||||
type Error = ShellError;
|
|
||||||
fn into_result(self) -> Result<Self::Ok, Self::Error> {
|
|
||||||
Ok(self)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn from_error(v: Self::Error) -> Self {
|
|
||||||
OutputStream::one(Err(v))
|
|
||||||
}
|
|
||||||
|
|
||||||
fn from_ok(v: Self::Ok) -> Self {
|
|
||||||
v
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Stream for OutputStream {
|
impl Stream for OutputStream {
|
||||||
type Item = ReturnValue;
|
type Item = ReturnValue;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user