From c5d5c17208ddbe0401fd5d7005a10241ba37332b Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Fri, 25 Mar 2016 15:10:54 +0100 Subject: [PATCH] Enhance error printing on config file parsing errors --- libimagrt/src/configuration.rs | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/libimagrt/src/configuration.rs b/libimagrt/src/configuration.rs index c4b3b31c..6b4319f1 100644 --- a/libimagrt/src/configuration.rs +++ b/libimagrt/src/configuration.rs @@ -204,6 +204,8 @@ fn fetch_config(rtp: &PathBuf) -> Result { use std::env; use std::fs::File; use std::io::Read; + use std::io::Write; + use std::io::stderr; use xdg_basedir; use itertools::Itertools; @@ -238,7 +240,18 @@ fn fetch_config(rtp: &PathBuf) -> Result { f.read_to_string(&mut s).ok(); s }; - Parser::new(&content[..]).parse() + let mut parser = Parser::new(&content[..]); + let res = parser.parse(); + if res.is_none() { + write!(stderr(), "Config file parser error:"); + for error in parser.errors { + write!(stderr(), "At [{}][{}] <> {}", error.lo, error.hi, error); + write!(stderr(), "in: '{}'", &content[error.lo..error.hi]); + } + None + } else { + res + } }) .filter(|loaded| loaded.is_some()) .nth(0)