From 679879f79b7932db93bff3bdb10febee7c8578d7 Mon Sep 17 00:00:00 2001 From: Marshall Bruner <43101405+brunerm99@users.noreply.github.com> Date: Mon, 2 Oct 2023 13:47:02 +0200 Subject: [PATCH] Add warning to `url join` when input key is not supported (#10506) (#10565) # Description Adds warning to `url join` when input key is not supported as suggested by @amtoine in #10506. It just adds a `println!` statement but it seems like that is all that is done for other warnings, e.g., https://github.com/nushell/nushell/blob/20aaaaf90c24ea5495cba3396d3977ab10923488/crates/nu-glob/src/lib.rs#L434 # Tests + Formatting All pass. --- crates/nu-command/src/network/url/join.rs | 32 ++++++++++++++++++----- 1 file changed, 25 insertions(+), 7 deletions(-) diff --git a/crates/nu-command/src/network/url/join.rs b/crates/nu-command/src/network/url/join.rs index aa6c814c5f..44c2f955a9 100644 --- a/crates/nu-command/src/network/url/join.rs +++ b/crates/nu-command/src/network/url/join.rs @@ -82,7 +82,7 @@ impl Command for SubCommand { fn run( &self, - _engine_state: &EngineState, + engine_state: &EngineState, _stack: &mut Stack, call: &Call, input: PipelineData, @@ -98,7 +98,7 @@ impl Command for SubCommand { let url_components = val .into_iter() .try_fold(UrlComponents::new(), |url, (k, v)| { - url.add_component(k, v, span) + url.add_component(k, v, span, engine_state) }); url_components?.to_url(span) @@ -137,8 +137,14 @@ impl UrlComponents { Default::default() } - pub fn add_component(self, key: String, value: Value, _span: Span) -> Result { - let span = value.span(); + pub fn add_component( + self, + key: String, + value: Value, + span: Span, + engine_state: &EngineState, + ) -> Result { + let value_span = value.span(); if key == "port" { return match value { Value::String { val, .. } => { @@ -154,7 +160,7 @@ impl UrlComponents { msg: String::from( "Port parameter should represent an unsigned integer", ), - span, + span: value_span, }), } } @@ -205,7 +211,7 @@ impl UrlComponents { Ok(Self { query: Some(qs), - params_span: Some(span), + params_span: Some(value_span), ..self }) } @@ -275,7 +281,19 @@ impl UrlComponents { }), ..self }), - _ => Ok(self), + _ => { + nu_protocol::report_error_new( + engine_state, + &ShellError::GenericError( + format!("'{key}' is not a valid URL field"), + format!("Remove '{key}' col from input record"), + Some(span), + None, + vec![], + ), + ); + Ok(self) + } } } }