refactor(logging): extract tracing infrastructure to its own module

This commit is contained in:
Harsh Shandilya 2022-07-13 13:14:28 +05:30
parent f9ce850414
commit 26b0b06759
No known key found for this signature in database
GPG key ID: 366D7BBAD1031E80
2 changed files with 38 additions and 27 deletions

33
src/logging.rs Normal file
View file

@ -0,0 +1,33 @@
use tracing::dispatcher::SetGlobalDefaultError;
use tracing::subscriber::set_global_default;
use tracing::Level;
use tracing_subscriber::filter::Targets;
#[cfg(not(feature = "journald"))]
fn configure_tracing(filter: Targets) -> Result<(), SetGlobalDefaultError> {
use tracing_subscriber::layer::SubscriberExt;
use tracing_subscriber::{fmt, Layer};
let stdout_log = fmt::layer().pretty();
let subscriber =
tracing_subscriber::registry().with(stdout_log.with_filter(filter));
set_global_default(subscriber)
}
#[cfg(feature = "journald")]
fn configure_tracing(filter: Targets) -> Result<(), SetGlobalDefaultError> {
use tracing_journald::Layer;
use tracing_subscriber::layer::SubscriberExt;
use tracing_subscriber::registry;
let subscriber = registry()
.with(filter)
.with(Layer::new().unwrap().with_field_prefix(None));
set_global_default(subscriber)
}
pub fn init() -> Result<(), SetGlobalDefaultError> {
let tracing_filter =
Targets::new().with_target("clipboard_subsitutor", Level::DEBUG);
configure_tracing(tracing_filter)
}