aboutsummaryrefslogtreecommitdiff
path: root/apps/koffice/libko/src/log_util.rs
blob: b87dbe83df4187778de3566cf11207ef24b5d5ec (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#[macro_export]
macro_rules! fatal {
    () => {
        error!("Unknown failure!");
        std::process::exit(2)
    };
    ($($arg:tt)*) => ({
        error!($($arg)*);
        std::process::exit(2)
    })
}

use colored::*;
use env_logger::Builder;
use log::Level;
use std::io::Write;

pub fn initialise() {
    let mut b = Builder::from_default_env();
    b.format(|buf, record| {
        let lvl = record.level().to_string();
        write!(
            buf,
            "[{}]: {}\n",
            match record.level() {
                Level::Error => lvl.red(),
                Level::Warn => lvl.yellow(),
                Level::Info => lvl.green(),
                Level::Debug => lvl.purple(),
                Level::Trace => lvl.cyan(),
            },
            record.args()
        )
    })
    .init();
}