diff options
Diffstat (limited to 'src/lib.rs')
-rw-r--r-- | src/lib.rs | 88 |
1 files changed, 53 insertions, 35 deletions
@@ -1,11 +1,13 @@ mod log_level; pub use log_level::*; -pub mod ansi { pub use ansi::*; } +use inked::*; use std::sync::Mutex; -pub static LOG_LEVEL: Mutex<LogLevel> = Mutex::new(LogLevel::Warn); + +static LOG_LEVEL: Mutex<LogLevel> = Mutex::new(LogLevel::Warn); + pub fn set_log_level(level: LogLevel) { *LOG_LEVEL.lock().unwrap() = level; @@ -16,48 +18,64 @@ pub fn get_log_level() -> LogLevel { } -#[macro_export] macro_rules! info { - ($($tokens:tt)*) => { - if *$crate::LOG_LEVEL.lock().unwrap() <= { $crate::LogLevel::Info } { - use $crate::ansi::*; - eprint!("{BOLD}{BLUE}[INFO]{NORMAL}: "); - eprint!($($tokens)*); - eprintln!("{NORMAL}"); +pub fn log_info(message: &str, details: Option<impl Into<InkedString>>) { + if *LOG_LEVEL.lock().unwrap() <= LogLevel::Info { + let mut string = InkedString::new(); + string.push(ink!("[INFO]").blue().bold()); + string.push(ink!(": {message}\n")); + if let Some(details) = details { + string.append(details.into()); } - }; + string.eprint(); + } } -#[macro_export] macro_rules! warn { - ($($tokens:tt)*) => {{ - if *$crate::LOG_LEVEL.lock().unwrap() <= { $crate::LogLevel::Warn } { - use $crate::ansi::*; - eprint!("{BOLD}{YELLOW}[WARNING]{NORMAL}{WHITE}: "); - eprint!($($tokens)*); - eprintln!("{NORMAL}"); +pub fn log_warn(message: &str, details: Option<impl Into<InkedString>>) { + if *LOG_LEVEL.lock().unwrap() <= LogLevel::Warn { + let mut string = InkedString::new(); + string.push(ink!("[WARN]").yellow().bold()); + string.push(ink!(": {message}\n").white()); + if let Some(details) = details { + string.append(details.into()); } - }}; + string.eprint(); + } } -#[macro_export] macro_rules! error { - ($($tokens:tt)*) => {{ - if *$crate::LOG_LEVEL.lock().unwrap() <= { $crate::LogLevel::Error } { - use $crate::ansi::*; - eprint!("{BOLD}{RED}[ERROR]{WHITE}: "); - eprint!($($tokens)*); - eprintln!("{NORMAL}"); +pub fn log_error(message: &str, details: Option<impl Into<InkedString>>) { + if *LOG_LEVEL.lock().unwrap() <= LogLevel::Error { + let mut string = InkedString::new(); + string.push(ink!("[ERROR]").red().bold()); + string.push(ink!(": {message}\n").white()); + if let Some(details) = details { + string.append(details.into()); } - }}; + string.eprint(); + } } -#[macro_export] macro_rules! fatal { - ($($tokens:tt)*) => {{ - if *$crate::LOG_LEVEL.lock().unwrap() <= { $crate::LogLevel::Fatal } { - use $crate::ansi::*; - eprint!("{BOLD}{RED}[FATAL]{WHITE}: "); - eprint!($($tokens)*); - eprintln!("{NORMAL}"); +pub fn log_fatal(message: &str, details: Option<impl Into<InkedString>>) -> ! { + if *LOG_LEVEL.lock().unwrap() <= LogLevel::Fatal { + let mut string = InkedString::new(); + string.push(ink!("[FATAL]").red().bold()); + string.push(ink!(": {message}\n").white()); + if let Some(details) = details { + string.append(details.into()); } - std::process::exit(1); - }}; + string.eprint(); + } + std::process::exit(1); } +#[macro_export] macro_rules! info { + ($($tokens:tt)*) => { $crate::log_info(&format!($($tokens)*), Option::<String>::None) }; +} +#[macro_export] macro_rules! warn { + ($($tokens:tt)*) => { $crate::log_warn(&format!($($tokens)*), Option::<String>::None) }; +} +#[macro_export] macro_rules! error { + ($($tokens:tt)*) => { $crate::log_error(&format!($($tokens)*), Option::<String>::None) }; +} +#[macro_export] macro_rules! fatal { + ($($tokens:tt)*) => { $crate::log_fatal(&format!($($tokens)*), Option::<String>::None) }; +} |