use anyhow::Result; use tracing_subscriber::filter::LevelFilter; use tracing_subscriber::fmt::time::ChronoLocal; use tracing_subscriber::FmtSubscriber; pub fn init(level: LevelFilter, json_format: bool) -> Result<()> { if level == LevelFilter::OFF { return Ok(()); } let is_terminal = atty::is(atty::Stream::Stderr); let builder = FmtSubscriber::builder() .with_env_filter(format!("asb={},swap={}", level, level)) .with_writer(std::io::stderr) .with_ansi(is_terminal) .with_timer(ChronoLocal::with_format("%F %T".to_owned())) .with_target(false); if json_format { builder.json().init(); } else if is_terminal { builder.init(); } else { builder.without_time().init(); } tracing::info!(%level, "Initialized tracing"); Ok(()) }