mirror of
https://github.com/nushell/nushell
synced 2025-01-15 22:54:16 +00:00
5bfb96447a
Remove a number of unwraps. In some cases, a `?` just worked as is. I also made it possible to use `?` to go from Result<OutputStream, ShellError> to OutputStream. Finally, started updating PerItemCommand to be able to use the signature deserialization logic, which substantially reduces unwraps. This is still in-progress work, but tests pass and it should be clear to merge and keep iterating on master.
96 lines
2.8 KiB
Rust
96 lines
2.8 KiB
Rust
#[macro_export]
|
|
macro_rules! stream {
|
|
($($expr:expr),*) => {{
|
|
let mut v = VecDeque::new();
|
|
|
|
$(
|
|
v.push_back($expr);
|
|
)*
|
|
|
|
v
|
|
}}
|
|
}
|
|
|
|
#[macro_export]
|
|
macro_rules! trace_stream {
|
|
(target: $target:tt, $desc:tt = $expr:expr) => {{
|
|
if log::log_enabled!(target: $target, log::Level::Trace) {
|
|
use futures::stream::StreamExt;
|
|
// Blocking is generally quite bad, but this is for debugging
|
|
// let mut local = futures::executor::LocalPool::new();
|
|
// let objects = local.run_until($expr.into_vec());
|
|
// let objects: Vec<_> = futures::executor::block_on($expr.into_vec());
|
|
|
|
let objects = $expr.values.inspect(|o| {
|
|
trace!(target: $target, "{} = {:#?}", $desc, o.debug());
|
|
});
|
|
|
|
$crate::stream::InputStream::from_stream(objects.boxed())
|
|
} else {
|
|
$expr
|
|
}
|
|
}};
|
|
}
|
|
|
|
crate use crate::cli::MaybeOwned;
|
|
crate use crate::commands::command::{
|
|
CallInfo, CommandAction, CommandArgs, ReturnSuccess, ReturnValue, RunnableContext,
|
|
};
|
|
crate use crate::commands::PerItemCommand;
|
|
crate use crate::context::CommandRegistry;
|
|
crate use crate::context::{Context, SpanSource};
|
|
crate use crate::env::host::handle_unexpected;
|
|
crate use crate::env::Host;
|
|
crate use crate::errors::{ShellError, ShellErrorUtils};
|
|
crate use crate::object::base as value;
|
|
crate use crate::object::meta::{Tag, Tagged, TaggedItem};
|
|
crate use crate::object::types::ExtractType;
|
|
crate use crate::object::{Primitive, Value};
|
|
crate use crate::parser::hir::SyntaxType;
|
|
crate use crate::parser::registry::Signature;
|
|
crate use crate::shell::filesystem_shell::FilesystemShell;
|
|
crate use crate::shell::shell_manager::ShellManager;
|
|
crate use crate::shell::value_shell::ValueShell;
|
|
crate use crate::stream::{InputStream, OutputStream};
|
|
crate use crate::traits::{HasSpan, ToDebug};
|
|
crate use crate::Span;
|
|
crate use crate::Text;
|
|
crate use futures::stream::BoxStream;
|
|
crate use futures::{FutureExt, Stream, StreamExt};
|
|
crate use futures_async_stream::async_stream_block;
|
|
#[allow(unused)]
|
|
crate use serde::{Deserialize, Serialize};
|
|
crate use std::collections::VecDeque;
|
|
crate use std::future::Future;
|
|
crate use std::sync::{Arc, Mutex};
|
|
|
|
pub trait FromInputStream {
|
|
fn from_input_stream(self) -> OutputStream;
|
|
}
|
|
|
|
impl<T> FromInputStream for T
|
|
where
|
|
T: Stream<Item = Tagged<Value>> + Send + 'static,
|
|
{
|
|
fn from_input_stream(self) -> OutputStream {
|
|
OutputStream {
|
|
values: self.map(ReturnSuccess::value).boxed(),
|
|
}
|
|
}
|
|
}
|
|
|
|
pub trait ToOutputStream {
|
|
fn to_output_stream(self) -> OutputStream;
|
|
}
|
|
|
|
impl<T, U> ToOutputStream for T
|
|
where
|
|
T: Stream<Item = U> + Send + 'static,
|
|
U: Into<ReturnValue>,
|
|
{
|
|
fn to_output_stream(self) -> OutputStream {
|
|
OutputStream {
|
|
values: self.map(|item| item.into()).boxed(),
|
|
}
|
|
}
|
|
}
|