use colored::Colorize;
#[derive(PartialEq, PartialOrd, Debug)]
pub enum LogLevel {
Debug,
Info,
Log,
Warn,
Error,
}
pub fn log(level: LogLevel, message: &str) {
let level_str = match level {
LogLevel::Debug => "[DEBUG]".purple(),
LogLevel::Info => "[INFO]".blue(),
LogLevel::Log => "[LOG]".green(),
LogLevel::Warn => "[WARN]".yellow(),
LogLevel::Error => "[ERROR]".red(),
};
let log_level = match std::env::var("BUILDER_CPP_LOG_LEVEL") {
Ok(val) => {
if val == "Debug" {
LogLevel::Debug
} else if val == "Info" {
LogLevel::Info
} else if val == "Log" {
LogLevel::Log
} else if val == "Warn" {
LogLevel::Warn
} else if val == "Error" {
LogLevel::Error
} else {
LogLevel::Log
}
}
Err(_) => LogLevel::Log,
};
if log_level == LogLevel::Debug {
if level == LogLevel::Debug || level == LogLevel::Warn || level == LogLevel::Error {
println!("{} {}", level_str, message);
}
} else if level >= log_level {
println!("{} {}", level_str, message);
}
}