Skip to main content

agent_core/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("agent_core=debug".parse().expect("valid directive"))
17            .add_directive("agent_engine=debug".parse().expect("valid directive"))
18            .add_directive("agent_tui=debug".parse().expect("valid directive"))
19            .add_directive("tracing=info".parse().expect("valid directive")))
20        .with_writer(non_blocking)
21        .with_target(false)
22        .with_thread_ids(true)
23        .with_ansi(false)
24        .try_init()
25    {
26        eprintln!("Failed to initialize logging: {}", e);
27    }
28
29    Some(guard)
30}