diff options
author | Christian Duerr <contact@christianduerr.com> | 2020-08-22 00:38:09 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-22 00:38:09 +0000 |
commit | 92a3d482d076eebbd12681444ae8f4dfdf08da69 (patch) | |
tree | 54569c6072acb15d4d0f1e40814fd9abb127fdba | |
parent | 3c3e6870dedad56b270f5b65ea57d5a6e46b1de6 (diff) | |
download | alacritty-92a3d482d076eebbd12681444ae8f4dfdf08da69.tar.gz alacritty-92a3d482d076eebbd12681444ae8f4dfdf08da69.zip |
Fix config import error handling
-rw-r--r-- | alacritty/src/config/mod.rs | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/alacritty/src/config/mod.rs b/alacritty/src/config/mod.rs index e5cc8583..243f1bae 100644 --- a/alacritty/src/config/mod.rs +++ b/alacritty/src/config/mod.rs @@ -191,24 +191,31 @@ fn parse_config( /// Load all referenced configuration files. fn load_imports(config: &Value, config_paths: &mut Vec<PathBuf>, recursion_limit: usize) -> Value { - let mut merged = Value::Null; - let imports = match config.get("import") { Some(Value::Sequence(imports)) => imports, - _ => return merged, + Some(_) => { + error!(target: LOG_TARGET_CONFIG, "Invalid import type: expected a sequence"); + return Value::Null; + }, + None => return Value::Null, }; // Limit recursion to prevent infinite loops. if !imports.is_empty() && recursion_limit == 0 { error!(target: LOG_TARGET_CONFIG, "Exceeded maximum configuration import depth"); - return merged; + return Value::Null; } + let mut merged = Value::Null; + for import in imports { let path = match import { Value::String(path) => PathBuf::from(path), _ => { - error!(target: LOG_TARGET_CONFIG, "Encountered invalid configuration file import"); + error!( + target: LOG_TARGET_CONFIG, + "Invalid import element type: expected path string" + ); continue; }, }; |