From 279db98d3cb6c7ee41af81c3e8eb6ef69a1662d0 Mon Sep 17 00:00:00 2001 From: Dmitry Sharshakov Date: Sun, 15 Aug 2021 10:08:51 +0300 Subject: [PATCH] refactor: use tagged enum for handling DAP payloads --- helix-dap/src/client.rs | 1 - helix-dap/src/transport.rs | 10 ++-------- 2 files changed, 2 insertions(+), 9 deletions(-) diff --git a/helix-dap/src/client.rs b/helix-dap/src/client.rs index c2a8dcc07..8339b953f 100644 --- a/helix-dap/src/client.rs +++ b/helix-dap/src/client.rs @@ -461,7 +461,6 @@ impl Client { let req = Request { back_ch: Some(callback_rx), seq: self.next_request_id(), - msg_type: "request".to_owned(), command, arguments, }; diff --git a/helix-dap/src/transport.rs b/helix-dap/src/transport.rs index cb16e45e0..e17dc53d5 100644 --- a/helix-dap/src/transport.rs +++ b/helix-dap/src/transport.rs @@ -18,8 +18,6 @@ pub struct Request { #[serde(skip)] pub back_ch: Option>>, pub seq: u64, - #[serde(rename = "type")] - pub msg_type: String, pub command: String, pub arguments: Option, } @@ -27,8 +25,6 @@ pub struct Request { #[derive(Debug, PartialEq, Clone, Deserialize, Serialize)] pub struct Response { // seq is omitted as unused and is not sent by some implementations - #[serde(rename = "type")] - pub msg_type: String, pub request_seq: u64, pub success: bool, pub command: String, @@ -39,14 +35,12 @@ pub struct Response { #[derive(Debug, PartialEq, Clone, Deserialize, Serialize)] pub struct Event { // seq is omitted as unused and is not sent by some implementations - #[serde(rename = "type")] - pub msg_type: String, pub event: String, pub body: Option, } #[derive(Debug, Clone, Deserialize, Serialize)] -#[serde(untagged)] +#[serde(tag = "type", rename_all = "camelCase")] pub enum Payload { // type = "event" Event(Event), @@ -135,7 +129,7 @@ impl Transport { server_stdin: &mut Box, req: Request, ) -> Result<()> { - let json = serde_json::to_string(&req)?; + let json = serde_json::to_string(&Payload::Request(req.clone()))?; if let Some(back) = req.back_ch { self.pending_requests.lock().await.insert(req.seq, back); }