summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Duerr <contact@christianduerr.com>2020-08-22 00:38:09 +0000
committerGitHub <noreply@github.com>2020-08-22 00:38:09 +0000
commit92a3d482d076eebbd12681444ae8f4dfdf08da69 (patch)
tree54569c6072acb15d4d0f1e40814fd9abb127fdba
parent3c3e6870dedad56b270f5b65ea57d5a6e46b1de6 (diff)
downloadalacritty-92a3d482d076eebbd12681444ae8f4dfdf08da69.tar.gz
alacritty-92a3d482d076eebbd12681444ae8f4dfdf08da69.zip
Fix config import error handling
-rw-r--r--alacritty/src/config/mod.rs17
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;
},
};