mirror of
https://github.com/nushell/nushell
synced 2025-01-15 06:34:15 +00:00
keep metadata while format filesize (#5502)
This commit is contained in:
parent
b00098ccc6
commit
d88d057bf6
1 changed files with 10 additions and 5 deletions
|
@ -2,8 +2,8 @@ use nu_engine::CallExt;
|
||||||
use nu_protocol::ast::Call;
|
use nu_protocol::ast::Call;
|
||||||
use nu_protocol::engine::{Command, EngineState, Stack};
|
use nu_protocol::engine::{Command, EngineState, Stack};
|
||||||
use nu_protocol::{
|
use nu_protocol::{
|
||||||
format_filesize, Category, Example, IntoPipelineData, PipelineData, ShellError, Signature,
|
format_filesize, Category, Example, IntoPipelineData, PipelineData, PipelineMetadata,
|
||||||
Span, SyntaxShape, Value,
|
ShellError, Signature, Span, SyntaxShape, Value,
|
||||||
};
|
};
|
||||||
use std::iter;
|
use std::iter;
|
||||||
|
|
||||||
|
@ -47,13 +47,16 @@ impl Command for FileSize {
|
||||||
.as_string()?
|
.as_string()?
|
||||||
.to_ascii_lowercase();
|
.to_ascii_lowercase();
|
||||||
let span = call.head;
|
let span = call.head;
|
||||||
|
let input_metadata = input.metadata();
|
||||||
let data_as_value = input.into_value(span);
|
let data_as_value = input.into_value(span);
|
||||||
|
|
||||||
// Something need to consider:
|
// Something need to consider:
|
||||||
// 1. what if input data type is not table? For now just output nothing.
|
// 1. what if input data type is not table? For now just output nothing.
|
||||||
// 2. what if value is not a FileSize type? For now just return nothing too for the value.
|
// 2. what if value is not a FileSize type? For now just return nothing too for the value.
|
||||||
match data_as_value {
|
match data_as_value {
|
||||||
Value::List { vals, span } => format_impl(vals, field, format_value, span),
|
Value::List { vals, span } => {
|
||||||
|
format_impl(vals, field, format_value, span, input_metadata)
|
||||||
|
}
|
||||||
_ => Ok(Value::Nothing { span }.into_pipeline_data()),
|
_ => Ok(Value::Nothing { span }.into_pipeline_data()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -79,6 +82,7 @@ fn format_impl(
|
||||||
field: String,
|
field: String,
|
||||||
format_value: String,
|
format_value: String,
|
||||||
input_span: Span,
|
input_span: Span,
|
||||||
|
input_metadata: Option<PipelineMetadata>,
|
||||||
) -> Result<PipelineData, ShellError> {
|
) -> Result<PipelineData, ShellError> {
|
||||||
let records: Vec<Value> = vals
|
let records: Vec<Value> = vals
|
||||||
.into_iter()
|
.into_iter()
|
||||||
|
@ -113,11 +117,12 @@ fn format_impl(
|
||||||
})
|
})
|
||||||
.collect();
|
.collect();
|
||||||
|
|
||||||
Ok(Value::List {
|
let result = Value::List {
|
||||||
vals: records,
|
vals: records,
|
||||||
span: input_span,
|
span: input_span,
|
||||||
}
|
}
|
||||||
.into_pipeline_data())
|
.into_pipeline_data();
|
||||||
|
Ok(result.set_metadata(input_metadata))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn format_value_impl(val: Value, format_value: &str, span: Span) -> Value {
|
fn format_value_impl(val: Value, format_value: &str, span: Span) -> Value {
|
||||||
|
|
Loading…
Reference in a new issue