use abbreviated string instead of debug string for DatetimeParseErrors (#12517)

Resolves #12444. Prevents debug string from being printed out.

---------

Co-authored-by: sholderbach <sholderbach@users.noreply.github.com>
This commit is contained in:
pwygab 2024-04-17 05:19:03 +08:00 committed by GitHub
parent cc781a1ecd
commit 43814dcb0f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 32 additions and 20 deletions

View File

@ -332,7 +332,7 @@ fn action(input: &Value, args: &Arguments, head: Span) -> Value {
} }
None => Value::error( None => Value::error(
ShellError::DatetimeParseError { ShellError::DatetimeParseError {
msg: input.to_debug_string(), msg: input.to_abbreviated_string(&nu_protocol::Config::default()),
span: *span, span: *span,
}, },
*span, *span,
@ -345,7 +345,7 @@ fn action(input: &Value, args: &Arguments, head: Span) -> Value {
} }
None => Value::error( None => Value::error(
ShellError::DatetimeParseError { ShellError::DatetimeParseError {
msg: input.to_debug_string(), msg: input.to_abbreviated_string(&nu_protocol::Config::default()),
span: *span, span: *span,
}, },
*span, *span,

View File

@ -78,9 +78,11 @@ fn helper(value: Value, head: Span) -> Value {
} }
Value::Date { val, .. } => Value::string(humanize_date(val), head), Value::Date { val, .. } => Value::string(humanize_date(val), head),
_ => Value::error( _ => Value::error(
ShellError::DatetimeParseError { ShellError::OnlySupportsThisInputType {
msg: value.to_debug_string(), exp_input_type: "date, string (that represents datetime), or nothing".into(),
span: head, wrong_type: value.get_type().to_string(),
dst_span: head,
src_span: span,
}, },
head, head,
), ),

View File

@ -112,9 +112,11 @@ fn helper(val: Value, head: Span) -> Value {
} }
Value::Date { val, .. } => parse_date_into_table(val, head), Value::Date { val, .. } => parse_date_into_table(val, head),
_ => Value::error( _ => Value::error(
ShellError::DatetimeParseError { ShellError::OnlySupportsThisInputType {
msg: val.to_debug_string(), exp_input_type: "date, string (that represents datetime), or nothing".into(),
span: head, wrong_type: val.get_type().to_string(),
dst_span: head,
src_span: span,
}, },
head, head,
), ),

View File

@ -111,9 +111,11 @@ fn helper(val: Value, head: Span) -> Value {
} }
Value::Date { val, .. } => parse_date_into_table(val, head), Value::Date { val, .. } => parse_date_into_table(val, head),
_ => Value::error( _ => Value::error(
ShellError::DatetimeParseError { ShellError::OnlySupportsThisInputType {
msg: val.to_debug_string(), exp_input_type: "date, string (that represents datetime), or nothing".into(),
span: head, wrong_type: val.get_type().to_string(),
dst_span: head,
src_span: val_span,
}, },
head, head,
), ),

View File

@ -115,9 +115,11 @@ fn helper(value: Value, head: Span, timezone: &Spanned<String>) -> Value {
_to_timezone(dt.with_timezone(dt.offset()), timezone, head) _to_timezone(dt.with_timezone(dt.offset()), timezone, head)
} }
_ => Value::error( _ => Value::error(
ShellError::DatetimeParseError { ShellError::OnlySupportsThisInputType {
msg: value.to_debug_string(), exp_input_type: "date, string (that represents datetime), or nothing".into(),
span: head, wrong_type: value.get_type().to_string(),
dst_span: head,
src_span: val_span,
}, },
head, head,
), ),

View File

@ -153,9 +153,11 @@ fn format_helper(value: Value, formatter: &str, formatter_span: Span, head_span:
} }
} }
_ => Value::error( _ => Value::error(
ShellError::DatetimeParseError { ShellError::OnlySupportsThisInputType {
msg: value.to_debug_string(), exp_input_type: "date, string (that represents datetime)".into(),
span: head_span, wrong_type: value.get_type().to_string(),
dst_span: head_span,
src_span: value.span(),
}, },
head_span, head_span,
), ),
@ -174,9 +176,11 @@ fn format_helper_rfc2822(value: Value, span: Span) -> Value {
} }
} }
_ => Value::error( _ => Value::error(
ShellError::DatetimeParseError { ShellError::OnlySupportsThisInputType {
msg: value.to_debug_string(), exp_input_type: "date, string (that represents datetime)".into(),
span, wrong_type: value.get_type().to_string(),
dst_span: span,
src_span: val_span,
}, },
span, span,
), ),