use std::fmt::Display;
pub trait Logger {
/// Registra uma mensagem no nível de verbosidade fornecido.
fn log(&self, verbosity: u8, message: impl Display);
}
struct StderrLogger;
impl Logger for StderrLogger {
fn log(&self, verbosity: u8, message: impl Display) {
eprintln!("verbosidade={verbosity}: {message}");
}
}
fn do_things(logger: &impl Logger) {
logger.log(5, "PSC (_FYI_)");
logger.log(2, "oh-oh");
}
/// Registra apenas mensagens até o nível de verbosidade fornecido.
struct VerbosityFilter {
max_verbosity: u8,
inner: StderrLogger,
}
impl Logger for VerbosityFilter {
fn log(&self, verbosity: u8, message: impl Display) {
if verbosity <= self.max_verbosity {
self.inner.log(verbosity, message);
}
}
}
fn main() {
let l = VerbosityFilter { max_verbosity: 3, inner: StderrLogger };
do_things(&l);
}