109 lines
2.4 KiB
Rust
109 lines
2.4 KiB
Rust
#![allow(dead_code)]
|
|
#![allow(unused)]
|
|
use std::{fmt, sync::mpsc::Sender};
|
|
|
|
pub struct Logger {}
|
|
|
|
impl Logger {
|
|
pub const fn new() -> Self {
|
|
Self {}
|
|
}
|
|
|
|
pub fn log(&self, message: &str) {
|
|
_ = self;
|
|
println!("\x1b[32mINFO:\x1b[0m {message}");
|
|
}
|
|
}
|
|
|
|
// #[derive(Debug)]=
|
|
// pub struct Logger {
|
|
// pub sender: Sender<Entry>,
|
|
// }
|
|
|
|
// impl Logger {
|
|
// pub fn new(sender: Sender<Entry>) -> Self {
|
|
// Self { sender }
|
|
// }
|
|
|
|
// pub fn debug<T: fmt::Display>(&self, message: T) {
|
|
// self.sender
|
|
// .send(Entry {
|
|
// etype: EntryType::Debug,
|
|
// message: message.to_string(),
|
|
// })
|
|
// .unwrap();
|
|
// }
|
|
|
|
// pub fn info<T: fmt::Display>(&self, message: T) {
|
|
// self.sender
|
|
// .send(Entry {
|
|
// etype: EntryType::Info,
|
|
// message: message.to_string(),
|
|
// })
|
|
// .unwrap();
|
|
// }
|
|
|
|
// pub fn warn<T: fmt::Display>(&self, message: T) {
|
|
// self.sender
|
|
// .send(Entry {
|
|
// etype: EntryType::Warn,
|
|
// message: message.to_string(),
|
|
// })
|
|
// .unwrap();
|
|
// }
|
|
|
|
// pub fn error<T: fmt::Display>(&self, message: T) {
|
|
// self.sender
|
|
// .send(Entry {
|
|
// etype: EntryType::Error,
|
|
// message: message.to_string(),
|
|
// })
|
|
// .unwrap();
|
|
// }
|
|
|
|
// pub fn fatal<T: fmt::Display>(&self, message: T) {
|
|
// self.sender
|
|
// .send(Entry {
|
|
// etype: EntryType::Fatal,
|
|
// message: message.to_string(),
|
|
// })
|
|
// .unwrap();
|
|
// }
|
|
// }
|
|
|
|
pub struct Entry {
|
|
etype: EntryType,
|
|
pub message: String,
|
|
}
|
|
|
|
#[derive(Copy, Clone, Eq, PartialEq)]
|
|
enum EntryType {
|
|
Debug,
|
|
Info,
|
|
Warn,
|
|
Error,
|
|
Fatal,
|
|
}
|
|
|
|
impl fmt::Display for EntryType {
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
write!(
|
|
f,
|
|
"{:<5}",
|
|
match self {
|
|
Self::Debug => "DEBUG",
|
|
Self::Info => "INFO",
|
|
Self::Warn => "WARN",
|
|
Self::Error => "ERROR",
|
|
Self::Fatal => "FATAL",
|
|
}
|
|
)
|
|
}
|
|
}
|
|
|
|
impl fmt::Display for Entry {
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
write!(f, "{}: {}", self.etype, self.message)
|
|
}
|
|
}
|