From 4066ae404831c7bbbe70a018c38ea2f50406fc0a Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Tue, 24 May 2016 16:42:32 +0200 Subject: [PATCH 1/2] Add dep: env_logger = 0.3 --- libimagrt/Cargo.toml | 1 + libimagrt/src/lib.rs | 1 + 2 files changed, 2 insertions(+) diff --git a/libimagrt/Cargo.toml b/libimagrt/Cargo.toml index 89610457..4e3dd673 100644 --- a/libimagrt/Cargo.toml +++ b/libimagrt/Cargo.toml @@ -5,6 +5,7 @@ authors = ["Matthias Beyer "] [dependencies] clap = "2.1.1" +env_logger = "0.3" toml = "0.1.27" log = "0.3" xdg-basedir = "0.2.2" diff --git a/libimagrt/src/lib.rs b/libimagrt/src/lib.rs index e4503f2e..d1d7e249 100644 --- a/libimagrt/src/lib.rs +++ b/libimagrt/src/lib.rs @@ -17,6 +17,7 @@ #[macro_use] extern crate log; #[macro_use] extern crate itertools; #[cfg(unix)] extern crate xdg_basedir; +extern crate env_logger; extern crate tempfile; extern crate ansi_term; From 9a92f9091fa41e97dac7acb06181df748e04c807 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Tue, 24 May 2016 16:43:04 +0200 Subject: [PATCH 2/2] Add env_logger as fallback if IMAG_LOG_ENV is present --- libimagrt/src/runtime.rs | 39 +++++++++++++++++++++++---------------- 1 file changed, 23 insertions(+), 16 deletions(-) diff --git a/libimagrt/src/runtime.rs b/libimagrt/src/runtime.rs index 57540b76..ba520445 100644 --- a/libimagrt/src/runtime.rs +++ b/libimagrt/src/runtime.rs @@ -197,23 +197,30 @@ impl<'a> Runtime<'a> { * Initialize the internal logger */ fn init_logger(is_debugging: bool, is_verbose: bool) { - let lvl = if is_debugging { - LogLevelFilter::Debug - } else if is_verbose { - LogLevelFilter::Info - } else { - LogLevelFilter::Error - }; + use std::env::var as env_var; + use env_logger; - log::set_logger(|max_log_lvl| { - max_log_lvl.set(lvl); - debug!("Init logger with {}", lvl); - Box::new(ImagLogger::new(lvl.to_log_level().unwrap())) - }) - .map_err(|_| { - panic!("Could not setup logger"); - }) - .ok(); + if env_var("IMAG_LOG_ENV").is_ok() { + env_logger::init().unwrap(); + } else { + let lvl = if is_debugging { + LogLevelFilter::Debug + } else if is_verbose { + LogLevelFilter::Info + } else { + LogLevelFilter::Error + }; + + log::set_logger(|max_log_lvl| { + max_log_lvl.set(lvl); + debug!("Init logger with {}", lvl); + Box::new(ImagLogger::new(lvl.to_log_level().unwrap())) + }) + .map_err(|_| { + panic!("Could not setup logger"); + }) + .ok(); + } } /**