From 7d2d4ed4a86f28bfce8d2fda8a774701d80f5175 Mon Sep 17 00:00:00 2001 From: Dmitry Sharshakov Date: Thu, 12 Aug 2021 19:35:55 +0300 Subject: dap: implement threads request --- helix-dap/examples/dap-basic.rs | 1 + helix-dap/src/client.rs | 21 +++++++++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/helix-dap/examples/dap-basic.rs b/helix-dap/examples/dap-basic.rs index 434f2eeb..cc05cd8e 100644 --- a/helix-dap/examples/dap-basic.rs +++ b/helix-dap/examples/dap-basic.rs @@ -42,6 +42,7 @@ pub async fn main() -> Result<()> { println!("configurationDone: {:?}", client.configuration_done().await); println!("stopped: {:?}", client.wait_for_stopped().await); + println!("threads: {:#?}", client.threads().await); println!("stack trace: {:#?}", client.stack_trace(1).await); let mut _in = String::new(); diff --git a/helix-dap/src/client.rs b/helix-dap/src/client.rs index 37f264ec..d76f9af3 100644 --- a/helix-dap/src/client.rs +++ b/helix-dap/src/client.rs @@ -148,6 +148,19 @@ struct StackTraceResponseBody { stack_frames: Vec, } +#[derive(Debug, PartialEq, Clone, Deserialize, Serialize)] +#[serde(rename_all = "camelCase")] +pub struct Thread { + id: usize, + name: String, +} + +#[derive(Debug, PartialEq, Clone, Deserialize, Serialize)] +#[serde(rename_all = "camelCase")] +struct ThreadsResponseBody { + threads: Vec, +} + #[derive(Debug)] pub struct Client { id: usize, @@ -349,4 +362,12 @@ impl Client { Ok((body.stack_frames, body.total_frames)) } + + pub async fn threads(&mut self) -> Result> { + let response = self.request("threads".to_owned(), None).await?; + + let body: ThreadsResponseBody = from_value(response.body.unwrap()).unwrap(); + + Ok(body.threads) + } } -- cgit v1.2.3-70-g09d2