use crate::OwnedJsValue;
#[allow(missing_docs)]
#[derive(PartialEq, Eq, Clone, Copy, Debug)]
pub enum Level {
Trace,
Debug,
Log,
Info,
Warn,
Error,
}
impl std::fmt::Display for Level {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
use Level::*;
let v = match self {
Trace => "trace",
Debug => "debug",
Log => "log",
Info => "info",
Warn => "warn",
Error => "error",
};
write!(f, "{}", v)
}
}
pub trait ConsoleBackend: std::panic::RefUnwindSafe + 'static {
fn log(&self, level: Level, values: Vec<OwnedJsValue>);
}
impl<F> ConsoleBackend for F
where
F: Fn(Level, Vec<OwnedJsValue>) + std::panic::RefUnwindSafe + 'static,
{
fn log(&self, level: Level, values: Vec<OwnedJsValue>) {
(self)(level, values);
}
}
#[cfg(feature = "log")]
mod log {
use crate::OwnedJsValue;
use super::Level;
pub struct LogConsole;
fn print_value(value: OwnedJsValue) -> String {
value.to_json_string(0).unwrap()
}
impl super::ConsoleBackend for LogConsole {
fn log(&self, level: Level, values: Vec<OwnedJsValue>) {
if values.is_empty() {
return;
}
let log_level = match level {
Level::Trace => log::Level::Trace,
Level::Debug => log::Level::Debug,
Level::Log => log::Level::Info,
Level::Info => log::Level::Info,
Level::Warn => log::Level::Warn,
Level::Error => log::Level::Error,
};
let msg = values
.into_iter()
.map(print_value)
.collect::<Vec<_>>()
.join(" ");
log::log!(log_level, "{}", msg);
}
}
}
#[cfg(feature = "log")]
pub use self::log::LogConsole;