use core::fmt::Arguments;
pub use log::Level;
use log::{Log, Metadata, Record};
struct Logger;
impl Log for Logger {
fn enabled(&self, _metadata: &Metadata) -> bool {
true
}
fn log(&self, record: &Record) {
if self.enabled(record.metadata()) {
let message = alloc::format!("{}", record.args());
let level = match record.level() {
Level::Error => 1,
Level::Warn => 2,
Level::Info => 3,
Level::Debug => 4,
Level::Trace => 5,
};
let _ = crate::ext().log(level, &message);
}
}
fn flush(&self) {}
}
pub fn log(level: Level, args: Arguments<'_>) {
let record = Record::builder().level(level).args(args).build();
Logger.log(&record);
}
#[macro_export]
macro_rules! log {
($level: expr, $($arg:tt)+) => {{ $crate::logger::log($level, ::core::format_args!($($arg)+)) }}
}
#[macro_export(local_inner_macros)]
macro_rules! error {
($($arg:tt)+) => {{ log!($crate::logger::Level::Error, $($arg)+) }}
}
#[macro_export(local_inner_macros)]
macro_rules! warn {
($($arg:tt)+) => {{ log!($crate::logger::Level::Warn, $($arg)+) }}
}
#[macro_export(local_inner_macros)]
macro_rules! info {
($($arg:tt)+) => {{ log!($crate::logger::Level::Info, $($arg)+) }}
}
#[macro_export(local_inner_macros)]
macro_rules! debug {
($($arg:tt)+) => {{ log!($crate::logger::Level::Debug, $($arg)+) }}
}
#[macro_export(local_inner_macros)]
macro_rules! trace {
($($arg:tt)+) => {{ log!($crate::logger::Level::Trace, $($arg)+) }}
}