rust/crates/rust-analyzer/src/lsp_ext.rs

405 lines
11 KiB
Rust
Raw Normal View History

2020-05-10 12:25:37 -05:00
//! rust-analyzer extensions to the LSP.
2020-05-17 17:11:40 -05:00
use std::{collections::HashMap, path::PathBuf};
2020-05-10 12:24:02 -05:00
use lsp_types::request::Request;
use lsp_types::{
notification::Notification, CodeActionKind, Position, Range, TextDocumentIdentifier,
};
use serde::{Deserialize, Serialize};
2018-08-10 13:13:39 -05:00
2019-01-22 15:15:03 -06:00
pub enum AnalyzerStatus {}
impl Request for AnalyzerStatus {
type Params = AnalyzerStatusParams;
2019-01-22 15:15:03 -06:00
type Result = String;
2019-01-28 05:43:07 -06:00
const METHOD: &'static str = "rust-analyzer/analyzerStatus";
2019-01-22 15:15:03 -06:00
}
#[derive(Deserialize, Serialize, Debug)]
#[serde(rename_all = "camelCase")]
pub struct AnalyzerStatusParams {
pub text_document: Option<TextDocumentIdentifier>,
}
pub enum MemoryUsage {}
impl Request for MemoryUsage {
type Params = ();
type Result = String;
const METHOD: &'static str = "rust-analyzer/memoryUsage";
}
2020-07-01 07:57:59 -05:00
pub enum ReloadWorkspace {}
2019-01-25 10:11:58 -06:00
2020-07-01 07:57:59 -05:00
impl Request for ReloadWorkspace {
2019-01-25 10:11:58 -06:00
type Params = ();
type Result = ();
2020-07-01 07:57:59 -05:00
const METHOD: &'static str = "rust-analyzer/reloadWorkspace";
2019-01-25 10:11:58 -06:00
}
2018-08-10 07:07:43 -05:00
pub enum SyntaxTree {}
impl Request for SyntaxTree {
type Params = SyntaxTreeParams;
type Result = String;
2019-01-28 05:43:07 -06:00
const METHOD: &'static str = "rust-analyzer/syntaxTree";
2018-08-10 07:07:43 -05:00
}
2020-03-02 10:52:46 -06:00
#[derive(Deserialize, Serialize, Debug)]
2018-08-10 13:13:39 -05:00
#[serde(rename_all = "camelCase")]
2018-08-10 07:07:43 -05:00
pub struct SyntaxTreeParams {
pub text_document: TextDocumentIdentifier,
pub range: Option<Range>,
2018-08-10 07:07:43 -05:00
}
2018-08-10 13:13:39 -05:00
pub enum ViewHir {}
impl Request for ViewHir {
type Params = lsp_types::TextDocumentPositionParams;
type Result = String;
const METHOD: &'static str = "rust-analyzer/viewHir";
}
2019-11-17 12:47:50 -06:00
pub enum ExpandMacro {}
impl Request for ExpandMacro {
type Params = ExpandMacroParams;
2019-11-19 08:56:48 -06:00
type Result = Option<ExpandedMacro>;
2019-11-17 12:47:50 -06:00
const METHOD: &'static str = "rust-analyzer/expandMacro";
}
2020-03-02 10:52:46 -06:00
#[derive(Deserialize, Serialize, Debug)]
2019-11-17 12:47:50 -06:00
#[serde(rename_all = "camelCase")]
pub struct ExpandMacroParams {
pub text_document: TextDocumentIdentifier,
pub position: Position,
2019-11-17 12:47:50 -06:00
}
#[derive(Deserialize, Serialize, Debug)]
#[serde(rename_all = "camelCase")]
pub struct ExpandedMacro {
pub name: String,
pub expansion: String,
}
2020-05-24 09:18:46 -05:00
pub enum MatchingBrace {}
2018-08-15 16:23:22 -05:00
2020-05-24 09:18:46 -05:00
impl Request for MatchingBrace {
type Params = MatchingBraceParams;
2018-08-15 16:23:22 -05:00
type Result = Vec<Position>;
2020-05-24 09:18:46 -05:00
const METHOD: &'static str = "experimental/matchingBrace";
2018-08-15 16:23:22 -05:00
}
2020-03-02 10:52:46 -06:00
#[derive(Deserialize, Serialize, Debug)]
2018-08-15 16:23:22 -05:00
#[serde(rename_all = "camelCase")]
2020-05-24 09:18:46 -05:00
pub struct MatchingBraceParams {
2018-08-15 16:23:22 -05:00
pub text_document: TextDocumentIdentifier,
2020-05-24 09:18:46 -05:00
pub positions: Vec<Position>,
2018-08-15 16:23:22 -05:00
}
2018-08-22 02:18:58 -05:00
pub enum ParentModule {}
impl Request for ParentModule {
2020-05-10 12:24:02 -05:00
type Params = lsp_types::TextDocumentPositionParams;
type Result = Option<lsp_types::GotoDefinitionResponse>;
const METHOD: &'static str = "experimental/parentModule";
2018-08-22 02:18:58 -05:00
}
2018-08-23 14:14:51 -05:00
pub enum JoinLines {}
impl Request for JoinLines {
type Params = JoinLinesParams;
2020-05-21 12:50:23 -05:00
type Result = Vec<lsp_types::TextEdit>;
const METHOD: &'static str = "experimental/joinLines";
2018-08-23 14:14:51 -05:00
}
2020-03-02 10:52:46 -06:00
#[derive(Deserialize, Serialize, Debug)]
2018-08-23 14:14:51 -05:00
#[serde(rename_all = "camelCase")]
pub struct JoinLinesParams {
pub text_document: TextDocumentIdentifier,
2020-05-21 12:50:23 -05:00
pub ranges: Vec<Range>,
2018-08-23 14:14:51 -05:00
}
2018-08-27 14:03:19 -05:00
pub enum OnEnter {}
impl Request for OnEnter {
2020-05-10 12:24:02 -05:00
type Params = lsp_types::TextDocumentPositionParams;
2020-05-25 07:12:53 -05:00
type Result = Option<Vec<SnippetTextEdit>>;
const METHOD: &'static str = "experimental/onEnter";
}
2018-08-27 14:03:19 -05:00
pub enum Runnables {}
impl Request for Runnables {
type Params = RunnablesParams;
type Result = Vec<Runnable>;
2020-06-02 10:34:18 -05:00
const METHOD: &'static str = "experimental/runnables";
2018-08-27 14:03:19 -05:00
}
2018-09-01 12:21:11 -05:00
#[derive(Serialize, Deserialize, Debug)]
2018-08-27 14:03:19 -05:00
#[serde(rename_all = "camelCase")]
pub struct RunnablesParams {
pub text_document: TextDocumentIdentifier,
pub position: Option<Position>,
}
2020-06-02 10:22:23 -05:00
#[derive(Deserialize, Serialize, Debug)]
#[serde(rename_all = "camelCase")]
pub struct Runnable {
pub label: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub location: Option<lsp_types::LocationLink>,
pub kind: RunnableKind,
pub args: CargoRunnable,
}
#[derive(Serialize, Deserialize, Debug)]
#[serde(rename_all = "lowercase")]
pub enum RunnableKind {
Cargo,
}
2020-03-02 10:52:46 -06:00
#[derive(Deserialize, Serialize, Debug)]
2018-08-27 14:03:19 -05:00
#[serde(rename_all = "camelCase")]
2020-06-02 10:22:23 -05:00
pub struct CargoRunnable {
// command to be executed instead of cargo
pub override_cargo: Option<String>,
2020-06-02 11:02:58 -05:00
#[serde(skip_serializing_if = "Option::is_none")]
2020-06-02 10:22:23 -05:00
pub workspace_root: Option<PathBuf>,
// command, --package and --lib stuff
pub cargo_args: Vec<String>,
// user-specified additional cargo args, like `--release`.
pub cargo_extra_args: Vec<String>,
2020-06-02 10:22:23 -05:00
// stuff after --
pub executable_args: Vec<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub expect_test: Option<bool>,
2018-08-27 14:03:19 -05:00
}
2018-08-29 10:03:14 -05:00
2021-02-27 11:04:43 -06:00
pub enum RelatedTests {}
impl Request for RelatedTests {
2021-03-11 08:39:41 -06:00
type Params = lsp_types::TextDocumentPositionParams;
2021-02-27 11:04:43 -06:00
type Result = Vec<TestInfo>;
const METHOD: &'static str = "rust-analyzer/relatedTests";
}
#[derive(Debug, Deserialize, Serialize)]
pub struct TestInfo {
pub runnable: Runnable,
}
2019-07-22 13:52:47 -05:00
pub enum InlayHints {}
impl Request for InlayHints {
type Params = InlayHintsParams;
type Result = Vec<InlayHint>;
const METHOD: &'static str = "rust-analyzer/inlayHints";
}
#[derive(Serialize, Deserialize, Debug)]
#[serde(rename_all = "camelCase")]
pub struct InlayHintsParams {
pub text_document: TextDocumentIdentifier,
}
#[derive(Debug, PartialEq, Eq, Deserialize, Serialize)]
pub enum InlayKind {
2019-08-04 16:28:36 -05:00
TypeHint,
ParameterHint,
ChainingHint,
2019-07-22 13:52:47 -05:00
}
#[derive(Debug, Deserialize, Serialize)]
pub struct InlayHint {
pub range: Range,
pub kind: InlayKind,
pub label: String,
}
pub enum Ssr {}
impl Request for Ssr {
type Params = SsrParams;
2020-05-21 17:28:49 -05:00
type Result = lsp_types::WorkspaceEdit;
const METHOD: &'static str = "experimental/ssr";
}
#[derive(Debug, Deserialize, Serialize)]
2020-03-15 16:23:18 -05:00
#[serde(rename_all = "camelCase")]
pub struct SsrParams {
2020-03-15 16:23:18 -05:00
pub query: String,
pub parse_only: bool,
/// File position where SSR was invoked. Paths in `query` will be resolved relative to this
/// position.
#[serde(flatten)]
pub position: lsp_types::TextDocumentPositionParams,
/// Current selections. Search/replace will be restricted to these if non-empty.
pub selections: Vec<lsp_types::Range>,
}
2020-05-17 17:11:40 -05:00
2020-07-02 05:37:04 -05:00
pub enum StatusNotification {}
#[derive(Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
2020-07-02 05:37:04 -05:00
pub enum Status {
Loading,
2021-01-28 09:33:02 -06:00
ReadyPartial,
2020-07-02 05:37:04 -05:00
Ready,
NeedsReload,
Invalid,
}
2020-08-17 06:56:27 -05:00
#[derive(Deserialize, Serialize)]
pub struct StatusParams {
pub status: Status,
}
2020-07-02 05:37:04 -05:00
impl Notification for StatusNotification {
2020-08-17 06:56:27 -05:00
type Params = StatusParams;
2020-07-02 05:37:04 -05:00
const METHOD: &'static str = "rust-analyzer/status";
}
2020-05-17 17:11:40 -05:00
pub enum CodeActionRequest {}
impl Request for CodeActionRequest {
type Params = lsp_types::CodeActionParams;
type Result = Option<Vec<CodeAction>>;
const METHOD: &'static str = "textDocument/codeAction";
}
pub enum CodeActionResolveRequest {}
impl Request for CodeActionResolveRequest {
type Params = CodeAction;
type Result = CodeAction;
const METHOD: &'static str = "codeAction/resolve";
}
2020-05-17 17:11:40 -05:00
#[derive(Debug, PartialEq, Clone, Default, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
2020-05-17 17:11:40 -05:00
pub struct CodeAction {
pub title: String,
#[serde(skip_serializing_if = "Option::is_none")]
2020-05-22 10:29:55 -05:00
pub group: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub kind: Option<CodeActionKind>,
// We don't handle commands on the client-side
// #[serde(skip_serializing_if = "Option::is_none")]
// pub command: Option<lsp_types::Command>,
2020-05-17 17:11:40 -05:00
#[serde(skip_serializing_if = "Option::is_none")]
pub edit: Option<SnippetWorkspaceEdit>,
#[serde(skip_serializing_if = "Option::is_none")]
pub is_preferred: Option<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
pub data: Option<CodeActionData>,
}
#[derive(Debug, Eq, PartialEq, Clone, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct CodeActionData {
pub code_action_params: lsp_types::CodeActionParams,
pub id: String,
2020-05-17 17:11:40 -05:00
}
#[derive(Debug, Eq, PartialEq, Clone, Default, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct SnippetWorkspaceEdit {
2020-05-19 13:27:14 -05:00
#[serde(skip_serializing_if = "Option::is_none")]
2020-05-17 17:11:40 -05:00
pub changes: Option<HashMap<lsp_types::Url, Vec<lsp_types::TextEdit>>>,
2020-05-19 13:27:14 -05:00
#[serde(skip_serializing_if = "Option::is_none")]
2020-05-17 17:11:40 -05:00
pub document_changes: Option<Vec<SnippetDocumentChangeOperation>>,
}
#[derive(Debug, Eq, PartialEq, Clone, Deserialize, Serialize)]
#[serde(untagged, rename_all = "lowercase")]
pub enum SnippetDocumentChangeOperation {
Op(lsp_types::ResourceOp),
Edit(SnippetTextDocumentEdit),
}
#[derive(Debug, Eq, PartialEq, Clone, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct SnippetTextDocumentEdit {
pub text_document: lsp_types::OptionalVersionedTextDocumentIdentifier,
2020-05-17 17:11:40 -05:00
pub edits: Vec<SnippetTextEdit>,
}
#[derive(Debug, Eq, PartialEq, Clone, Default, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct SnippetTextEdit {
pub range: Range,
pub new_text: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub insert_text_format: Option<lsp_types::InsertTextFormat>,
}
2020-06-03 06:15:54 -05:00
pub enum HoverRequest {}
impl Request for HoverRequest {
type Params = lsp_types::HoverParams;
type Result = Option<Hover>;
const METHOD: &'static str = "textDocument/hover";
}
#[derive(Debug, PartialEq, Clone, Deserialize, Serialize)]
pub struct Hover {
2020-06-03 08:39:32 -05:00
#[serde(flatten)]
pub hover: lsp_types::Hover,
2020-06-03 09:35:26 -05:00
#[serde(skip_serializing_if = "Vec::is_empty")]
pub actions: Vec<CommandLinkGroup>,
2020-06-03 06:15:54 -05:00
}
2020-06-03 08:39:32 -05:00
#[derive(Debug, PartialEq, Clone, Default, Deserialize, Serialize)]
2020-06-03 06:15:54 -05:00
pub struct CommandLinkGroup {
2020-06-03 08:39:32 -05:00
#[serde(skip_serializing_if = "Option::is_none")]
2020-06-03 06:15:54 -05:00
pub title: Option<String>,
pub commands: Vec<CommandLink>,
}
// LSP v3.15 Command does not have a `tooltip` field, vscode supports one.
2020-06-03 08:39:32 -05:00
#[derive(Debug, PartialEq, Clone, Default, Deserialize, Serialize)]
2020-06-03 06:15:54 -05:00
pub struct CommandLink {
2020-06-03 08:39:32 -05:00
#[serde(flatten)]
pub command: lsp_types::Command,
2020-06-03 06:15:54 -05:00
#[serde(skip_serializing_if = "Option::is_none")]
pub tooltip: Option<String>,
}
2020-08-30 03:02:29 -05:00
2020-08-31 18:38:32 -05:00
pub enum ExternalDocs {}
2020-08-30 03:02:29 -05:00
2020-08-31 18:38:32 -05:00
impl Request for ExternalDocs {
type Params = lsp_types::TextDocumentPositionParams;
type Result = Option<lsp_types::Url>;
const METHOD: &'static str = "experimental/externalDocs";
2020-08-30 03:02:29 -05:00
}
2020-11-12 19:48:07 -06:00
pub enum OpenCargoToml {}
impl Request for OpenCargoToml {
type Params = OpenCargoTomlParams;
type Result = Option<lsp_types::GotoDefinitionResponse>;
const METHOD: &'static str = "experimental/openCargoToml";
}
#[derive(Serialize, Deserialize, Debug)]
#[serde(rename_all = "camelCase")]
pub struct OpenCargoTomlParams {
pub text_document: TextDocumentIdentifier,
}
2021-02-13 05:07:47 -06:00
/// Information about CodeLens, that is to be resolved.
#[derive(Debug, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub(crate) enum CodeLensResolveData {
Impls(lsp_types::request::GotoImplementationParams),
References(lsp_types::TextDocumentPositionParams),
}
2021-02-12 16:26:01 -06:00
pub fn supports_utf8(caps: &lsp_types::ClientCapabilities) -> bool {
caps.offset_encoding.as_deref().unwrap_or_default().iter().any(|it| it == "utf-8")
}