From 5dd0fa900c1a3495ffd72f0dc017b2dfaaa895b3 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 15 May 2016 17:46:52 +0200 Subject: [PATCH 1/2] Add dependency: ansi_term = 0.7 --- libimagutil/Cargo.toml | 1 + libimagutil/src/lib.rs | 1 + 2 files changed, 2 insertions(+) diff --git a/libimagutil/Cargo.toml b/libimagutil/Cargo.toml index 96638623..efcbff44 100644 --- a/libimagutil/Cargo.toml +++ b/libimagutil/Cargo.toml @@ -7,4 +7,5 @@ authors = ["Matthias Beyer "] lazy_static = "0.1.15" log = "0.3" regex = "0.1" +ansi_term = "0.7" diff --git a/libimagutil/src/lib.rs b/libimagutil/src/lib.rs index e9894c0a..e0d7a3ce 100644 --- a/libimagutil/src/lib.rs +++ b/libimagutil/src/lib.rs @@ -16,6 +16,7 @@ #[macro_use] extern crate lazy_static; #[macro_use] extern crate log; extern crate regex; +extern crate ansi_term; pub mod ismatch; pub mod key_value_split; From f22624302c5ab9abb6d88d75825d04ea0ca7a6b4 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 15 May 2016 17:47:01 +0200 Subject: [PATCH 2/2] Make trace() output red --- libimagutil/src/trace.rs | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/libimagutil/src/trace.rs b/libimagutil/src/trace.rs index 3a66bcb8..e04b292f 100644 --- a/libimagutil/src/trace.rs +++ b/libimagutil/src/trace.rs @@ -2,6 +2,8 @@ use std::error::Error; use std::io::Write; use std::io::stderr; +use ansi_term::Colour::Red; + /// Print an Error type and its cause recursively /// /// The error is printed with "Error NNNN :" as prefix, where "NNNN" is a number which increases @@ -29,8 +31,9 @@ pub fn trace_error(e: &Error) { /// Output is the same as for `trace_error()`, though there are only `max` levels printed. pub fn trace_error_maxdepth(e: &Error, max: u64) { let n = count_error_causes(e); - write!(stderr(), - "{}/{} Levels of errors will be printed\n", (if max > n { n } else { max }), n).ok(); + let msg = Red.blink().paint(format!("{}/{} Levels of errors will be printed\n", + (if max > n { n } else { max }), n)); + write!(stderr(), "{}", msg).ok(); print_trace_maxdepth(n, e, max); write!(stderr(), "").ok(); } @@ -55,7 +58,7 @@ fn print_trace_maxdepth(idx: u64, e: &Error, max: u64) -> Option<&Error> { } else { write!(stderr(), "\n").ok(); } - write!(stderr(), "ERROR[{:>4}]: {}", idx, e.description()).ok(); + write!(stderr(), "{}: {}", Red.paint(format!("ERROR[{:>4}]", idx)), e.description()).ok(); e.cause() } @@ -65,7 +68,7 @@ fn count_error_causes(e: &Error) -> u64 { } fn print_trace_dbg(idx: u64, e: &Error) { - debug!("ERROR[{:>4}]: {}", idx, e.description()); + debug!("{}: {}", Red.blink().paint(format!("ERROR[{:>4}]", idx)), e.description()); if e.cause().is_some() { print_trace_dbg(idx + 1, e.cause().unwrap()); }