mod log_level; pub use log_level::*; use inked::*; use std::sync::Mutex; static LOG_LEVEL: Mutex<LogLevel> = Mutex::new(LogLevel::Warn); pub fn set_log_level(level: LogLevel) { *LOG_LEVEL.lock().unwrap() = level; } pub fn get_log_level() -> LogLevel { *LOG_LEVEL.lock().unwrap() } 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(); } } 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(); } } 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(); } } 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()); } 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) }; }