From 755a3e9fb6b9b11cc3eaf4fc16d66408b1cbe2a3 Mon Sep 17 00:00:00 2001 From: danda Date: Tue, 6 Dec 2022 19:20:04 -0800 Subject: [PATCH] fix(cli): use default if prop not in config file Fixes a "property X not found in config" error when the missing property has a default value. --- kindelia/src/config.rs | 31 ++++++++++++++++++------------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/kindelia/src/config.rs b/kindelia/src/config.rs index c637eec6..302214e4 100644 --- a/kindelia/src/config.rs +++ b/kindelia/src/config.rs @@ -50,7 +50,10 @@ where } if let (Some(prop_path), Some(config_values)) = (self.prop, config_values) { // If config file and argument prop path are set, read from config file - return Self::resolve_from_config_aux(config_values, &prop_path); + if let Some(v) = Self::resolve_from_config_aux(config_values, &prop_path)? + { + return Ok(v); + } } (self.default_value)() } @@ -66,10 +69,13 @@ where { if let Some(prop_path) = self.prop { if let Some(config_values) = config_values { - Self::resolve_from_config_aux(config_values, &prop_path) - } else { - (self.default_value)() + if let Some(v) = + Self::resolve_from_config_aux(config_values, &prop_path)? + { + return Ok(v); + } } + (self.default_value)() } else { Err(anyhow!( "Cannot resolve from config file config without 'prop' field set" @@ -105,18 +111,17 @@ where fn resolve_from_config_aux( config_values: &toml::Value, prop_path: &str, - ) -> anyhow::Result + ) -> anyhow::Result> where T: ArgumentFrom, { - let value = Self::get_prop(config_values, prop_path).context(anyhow!( - "Could not find prop '{}' in config file.", - prop_path - ))?; - T::arg_from(value).context(anyhow!( - "Could not convert value of '{}' into desired type", - prop_path, - )) + match Self::get_prop(config_values, prop_path) { + Some(value) => Ok(Some(T::arg_from(value).context(anyhow!( + "Could not convert value of '{}' into desired type", + prop_path, + ))?)), + None => Ok(None), + } } fn get_prop(mut value: &toml::Value, prop_path: &str) -> Option {