use std::{path::Path, sync::Arc}; use dap::client::DebugAdapterClient; use gpui::{App, AppContext, Subscription}; use super::session::{Session, SessionStateEvent}; pub fn intercept_debug_sessions) + 'static>( cx: &mut gpui::TestAppContext, configure: T, ) -> Subscription { cx.update(|cx| { let configure = Arc::new(configure); cx.observe_new::(move |_, _, cx| { let configure = configure.clone(); cx.subscribe_self(move |session, event, cx| { let configure = configure.clone(); if matches!(event, SessionStateEvent::Running) { let client = session.adapter_client().unwrap(); register_default_handlers(session, &client, cx); configure(&client); cx.background_spawn(async move { client .fake_event(dap::messages::Events::Initialized( Some(Default::default()), )) .await }) .detach(); } }) .detach(); }) }) } fn register_default_handlers(session: &Session, client: &Arc, cx: &mut App) { client.on_request::(move |_, _| Ok(Default::default())); let paths = session.breakpoint_store.read(cx).breakpoint_paths(); client.on_request::(move |_, args| { let p = Arc::from(Path::new(&args.source.path.unwrap())); if !paths.contains(&p) { panic!("Sent breakpoints for path without any") } Ok(dap::SetBreakpointsResponse { breakpoints: Vec::default(), }) }); client.on_request::(move |_, _| Ok(())); client.on_request::(move |_, _| { Ok(dap::SetExceptionBreakpointsResponse { breakpoints: None }) }); client.on_request::(move |_, _| Ok(())); client.on_request::(move |_, _| { Ok(dap::ThreadsResponse { threads: vec![] }) }); }