mirror of
https://github.com/nushell/nushell
synced 2025-01-27 04:15:21 +00:00
get
now streams properly
patch
This commit is contained in:
parent
e26364f885
commit
65b8b7e36e
1 changed files with 39 additions and 3 deletions
|
@ -1,4 +1,5 @@
|
|||
use nu_engine::command_prelude::*;
|
||||
use nu_protocol::{ast::PathMember, Signals};
|
||||
|
||||
#[derive(Clone)]
|
||||
pub struct Get;
|
||||
|
@ -72,9 +73,13 @@ If multiple cell paths are given, this will produce a list of values."#
|
|||
}
|
||||
|
||||
if rest.is_empty() {
|
||||
input
|
||||
.follow_cell_path(&cell_path.members, call.head, !sensitive)
|
||||
.map(|x| x.into_pipeline_data())
|
||||
follow_cell_path_into_stream(
|
||||
input,
|
||||
engine_state.signals().clone(),
|
||||
cell_path.members,
|
||||
call.head,
|
||||
!sensitive,
|
||||
)
|
||||
} else {
|
||||
let mut output = vec![];
|
||||
|
||||
|
@ -94,6 +99,7 @@ If multiple cell paths are given, this will produce a list of values."#
|
|||
}
|
||||
.map(|x| x.set_metadata(metadata))
|
||||
}
|
||||
|
||||
fn examples(&self) -> Vec<Example> {
|
||||
vec![
|
||||
Example {
|
||||
|
@ -139,6 +145,36 @@ If multiple cell paths are given, this will produce a list of values."#
|
|||
}
|
||||
}
|
||||
|
||||
pub fn follow_cell_path_into_stream(
|
||||
data: PipelineData,
|
||||
signals: Signals,
|
||||
cell_path: Vec<PathMember>,
|
||||
head: Span,
|
||||
insensitive: bool,
|
||||
) -> Result<PipelineData, ShellError> {
|
||||
match data {
|
||||
PipelineData::ListStream(stream, ..) => {
|
||||
let result = stream
|
||||
.into_iter()
|
||||
.map(move |value| {
|
||||
let span = value.span();
|
||||
|
||||
match value.follow_cell_path(&cell_path, insensitive) {
|
||||
Ok(v) => v,
|
||||
Err(error) => Value::error(error, span),
|
||||
}
|
||||
})
|
||||
.into_pipeline_data(head, signals);
|
||||
|
||||
Ok(result)
|
||||
}
|
||||
|
||||
_ => data
|
||||
.follow_cell_path(&cell_path, head, insensitive)
|
||||
.map(|x| x.into_pipeline_data()),
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::*;
|
||||
|
|
Loading…
Reference in a new issue