From bfd77ff0a4aaab76c492eca05d6530178e507de4 Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Sun, 1 Dec 2024 13:32:27 +0900 Subject: [PATCH] cli: config get: break method chaining for ease of error type migration .get_value() doesn't do type casting, so a Type error wouldn't occur. --- cli/src/commands/config/get.rs | 53 ++++++++++++++++------------------ 1 file changed, 25 insertions(+), 28 deletions(-) diff --git a/cli/src/commands/config/get.rs b/cli/src/commands/config/get.rs index ac37b0cec48..3ebf579e421 100644 --- a/cli/src/commands/config/get.rs +++ b/cli/src/commands/config/get.rs @@ -47,34 +47,31 @@ pub fn cmd_config_get( command: &CommandHelper, args: &ConfigGetArgs, ) -> Result<(), CommandError> { - let value = command - .settings() - .get_value(&args.name) - .and_then(|value| value.into_string()) - .map_err(|err| match err { - ConfigError::Type { - origin, - unexpected, - expected, - key, - } => { - let expected = format!("a value convertible to {expected}"); - // Copied from `impl fmt::Display for ConfigError`. We can't use - // the `Display` impl directly because `expected` is required to - // be a `'static str`. - let mut buf = String::new(); - use std::fmt::Write; - write!(buf, "invalid type: {unexpected}, expected {expected}").unwrap(); - if let Some(key) = key { - write!(buf, " for key `{key}`").unwrap(); - } - if let Some(origin) = origin { - write!(buf, " in {origin}").unwrap(); - } - config_error(buf) + let value = command.settings().get_value(&args.name)?; + let stringified = value.into_string().map_err(|err| match err { + ConfigError::Type { + origin, + unexpected, + expected, + key, + } => { + let expected = format!("a value convertible to {expected}"); + // Copied from `impl fmt::Display for ConfigError`. We can't use + // the `Display` impl directly because `expected` is required to + // be a `'static str`. + let mut buf = String::new(); + use std::fmt::Write; + write!(buf, "invalid type: {unexpected}, expected {expected}").unwrap(); + if let Some(key) = key { + write!(buf, " for key `{key}`").unwrap(); } - err => err.into(), - })?; - writeln!(ui.stdout(), "{value}")?; + if let Some(origin) = origin { + write!(buf, " in {origin}").unwrap(); + } + config_error(buf) + } + err => err.into(), + })?; + writeln!(ui.stdout(), "{stringified}")?; Ok(()) }