synaps_cli/core/
logging.rs1use 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}