
https://github.com/zed-industries/zed/issues/30972 brought up another case where our context is not enough to track the actual source of the issue: we get a general top-level error without inner error. The reason for this was `.ok_or_else(|| anyhow!("failed to read HEAD SHA"))?; ` on the top level. The PR finally reworks the way we use anyhow to reduce such issues (or at least make it simpler to bubble them up later in a fix). On top of that, uses a few more anyhow methods for better readability. * `.ok_or_else(|| anyhow!("..."))`, `map_err` and other similar error conversion/option reporting cases are replaced with `context` and `with_context` calls * in addition to that, various `anyhow!("failed to do ...")` are stripped with `.context("Doing ...")` messages instead to remove the parasitic `failed to` text * `anyhow::ensure!` is used instead of `if ... { return Err(...); }` calls * `anyhow::bail!` is used instead of `return Err(anyhow!(...));` Release Notes: - N/A
59 lines
1.8 KiB
Rust
59 lines
1.8 KiB
Rust
mod codelldb;
|
|
mod gdb;
|
|
mod go;
|
|
mod javascript;
|
|
mod php;
|
|
mod python;
|
|
mod ruby;
|
|
|
|
use std::sync::Arc;
|
|
|
|
use anyhow::Result;
|
|
use async_trait::async_trait;
|
|
use codelldb::CodeLldbDebugAdapter;
|
|
use dap::{
|
|
DapRegistry, DebugRequest,
|
|
adapters::{
|
|
self, AdapterVersion, DapDelegate, DebugAdapter, DebugAdapterBinary, DebugAdapterName,
|
|
GithubRepo,
|
|
},
|
|
configure_tcp_connection,
|
|
inline_value::{PythonInlineValueProvider, RustInlineValueProvider},
|
|
};
|
|
use gdb::GdbDebugAdapter;
|
|
use go::GoDebugAdapter;
|
|
use gpui::{App, BorrowAppContext};
|
|
use javascript::JsDebugAdapter;
|
|
use php::PhpDebugAdapter;
|
|
use python::PythonDebugAdapter;
|
|
use ruby::RubyDebugAdapter;
|
|
use serde_json::{Value, json};
|
|
|
|
pub fn init(cx: &mut App) {
|
|
cx.update_default_global(|registry: &mut DapRegistry, _cx| {
|
|
registry.add_adapter(Arc::from(CodeLldbDebugAdapter::default()));
|
|
registry.add_adapter(Arc::from(PythonDebugAdapter::default()));
|
|
registry.add_adapter(Arc::from(PhpDebugAdapter::default()));
|
|
registry.add_adapter(Arc::from(JsDebugAdapter::default()));
|
|
registry.add_adapter(Arc::from(RubyDebugAdapter));
|
|
registry.add_adapter(Arc::from(GoDebugAdapter));
|
|
registry.add_adapter(Arc::from(GdbDebugAdapter));
|
|
|
|
registry.add_inline_value_provider("Rust".to_string(), Arc::from(RustInlineValueProvider));
|
|
registry
|
|
.add_inline_value_provider("Python".to_string(), Arc::from(PythonInlineValueProvider));
|
|
})
|
|
}
|
|
|
|
trait ToDap {
|
|
fn to_dap(&self) -> dap::StartDebuggingRequestArgumentsRequest;
|
|
}
|
|
|
|
impl ToDap for DebugRequest {
|
|
fn to_dap(&self) -> dap::StartDebuggingRequestArgumentsRequest {
|
|
match self {
|
|
Self::Launch(_) => dap::StartDebuggingRequestArgumentsRequest::Launch,
|
|
Self::Attach(_) => dap::StartDebuggingRequestArgumentsRequest::Attach,
|
|
}
|
|
}
|
|
}
|