use std::sync::{
atomic::{AtomicUsize, Ordering},
Arc,
};
use tracing::Subscriber;
use tracing_subscriber::Layer;
#[derive(Default)]
pub(crate) struct TraceCount {
trace: AtomicUsize,
debug: AtomicUsize,
info: AtomicUsize,
warn: AtomicUsize,
error: AtomicUsize,
}
impl std::fmt::Display for TraceCount {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
std::sync::atomic::fence(Ordering::SeqCst);
let trace = self.trace.load(Ordering::SeqCst);
let debug = self.debug.load(Ordering::SeqCst);
let info = self.info.load(Ordering::SeqCst);
let warn = self.warn.load(Ordering::SeqCst);
let error = self.error.load(Ordering::SeqCst);
write!(
f,
"Trace: {}, Debug: {}, Info: {}, Warn: {}, Error: {}",
trace, debug, info, warn, error
)
}
}
pub(crate) struct TraceCounter(pub(crate) Arc<TraceCount>);
impl<S: Subscriber> Layer<S> for TraceCounter {
fn on_event(
&self,
event: &tracing::Event<'_>,
_ctx: tracing_subscriber::layer::Context<'_, S>,
) {
use tracing::Level;
let var = match *event.metadata().level() {
Level::TRACE => &self.0.trace,
Level::DEBUG => &self.0.debug,
Level::INFO => &self.0.info,
Level::WARN => &self.0.warn,
Level::ERROR => &self.0.error,
};
var.fetch_add(1, Ordering::Relaxed);
}
}