Skip to main content

synaps_cli/core/
logging.rs

1use tracing_appender::non_blocking::WorkerGuard;
2
3
4pub fn init_logging() -> Option<WorkerGuard> {
5    let log_dir = crate::config::get_active_config_dir();
6    if !log_dir.exists() {
7        let _ = std::fs::create_dir_all(&log_dir);
8    }
9
10    let file_appender = tracing_appender::rolling::daily(log_dir, "synaps.log");
11    let (non_blocking, guard) = tracing_appender::non_blocking(file_appender);
12
13    if let Err(e) = tracing_subscriber::fmt()
14        .with_env_filter(tracing_subscriber::EnvFilter::from_default_env()
15            .add_directive("synaps_cli=debug".parse().expect("valid directive"))
16            .add_directive("tracing=info".parse().expect("valid directive")))
17        .with_writer(non_blocking)
18        .with_target(false)
19        .with_thread_ids(true)
20        .with_ansi(false)
21        .try_init()
22    {
23        eprintln!("Failed to initialize logging: {}", e);
24    }
25
26    Some(guard)
27}