X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=crates%2Frust-analyzer%2Fsrc%2Fcaps.rs;h=648f6aeebe7ac3da35750ddc5b5edc59b4fca3cd;hb=0db0dec9993b510efeb61cb1d8ff113270d4ca51;hp=f148521a2cf887cfc1a130f92dd7bebdfacfb758;hpb=fcc109e8904a1b965cbb860daf4e626a78ec125f;p=rust.git diff --git a/crates/rust-analyzer/src/caps.rs b/crates/rust-analyzer/src/caps.rs index f148521a2cf..648f6aeebe7 100644 --- a/crates/rust-analyzer/src/caps.rs +++ b/crates/rust-analyzer/src/caps.rs @@ -1,9 +1,7 @@ -//! Advertizes the capabilities of the LSP Server. -use std::env; - +//! Advertises the capabilities of the LSP Server. use lsp_types::{ CallHierarchyServerCapability, ClientCapabilities, CodeActionKind, CodeActionOptions, - CodeActionProviderCapability, CodeLensOptions, CompletionOptions, + CodeActionProviderCapability, CodeLensOptions, CompletionOptions, DeclarationCapability, DocumentOnTypeFormattingOptions, FileOperationFilter, FileOperationPattern, FileOperationPatternKind, FileOperationRegistrationOptions, FoldingRangeProviderCapability, HoverProviderCapability, ImplementationProviderCapability, OneOf, RenameOptions, SaveOptions, @@ -15,25 +13,24 @@ }; use serde_json::json; +use crate::config::{Config, RustfmtConfig}; use crate::semantic_tokens; -pub fn server_capabilities(client_caps: &ClientCapabilities) -> ServerCapabilities { +pub fn server_capabilities(config: &Config) -> ServerCapabilities { ServerCapabilities { text_document_sync: Some(TextDocumentSyncCapability::Options(TextDocumentSyncOptions { open_close: Some(true), - change: Some(if env::var("RA_NO_INCREMENTAL_SYNC").is_ok() { - TextDocumentSyncKind::Full - } else { - TextDocumentSyncKind::Incremental - }), + change: Some(TextDocumentSyncKind::INCREMENTAL), will_save: None, will_save_wait_until: None, save: Some(SaveOptions::default().into()), })), hover_provider: Some(HoverProviderCapability::Simple(true)), completion_provider: Some(CompletionOptions { - resolve_provider: completions_resolve_provider(client_caps), - trigger_characters: Some(vec![":".to_string(), ".".to_string()]), + resolve_provider: completions_resolve_provider(&config.caps), + trigger_characters: Some(vec![":".to_string(), ".".to_string(), "'".to_string()]), + all_commit_characters: None, + completion_item: None, work_done_progress_options: WorkDoneProgressOptions { work_done_progress: None }, }), signature_help_provider: Some(SignatureHelpOptions { @@ -41,7 +38,7 @@ pub fn server_capabilities(client_caps: &ClientCapabilities) -> ServerCapabiliti retrigger_characters: None, work_done_progress_options: WorkDoneProgressOptions { work_done_progress: None }, }), - declaration_provider: None, + declaration_provider: Some(DeclarationCapability::Simple(true)), definition_provider: Some(OneOf::Left(true)), type_definition_provider: Some(TypeDefinitionProviderCapability::Simple(true)), implementation_provider: Some(ImplementationProviderCapability::Simple(true)), @@ -49,16 +46,18 @@ pub fn server_capabilities(client_caps: &ClientCapabilities) -> ServerCapabiliti document_highlight_provider: Some(OneOf::Left(true)), document_symbol_provider: Some(OneOf::Left(true)), workspace_symbol_provider: Some(OneOf::Left(true)), - code_action_provider: Some(code_action_capabilities(client_caps)), + code_action_provider: Some(code_action_capabilities(&config.caps)), code_lens_provider: Some(CodeLensOptions { resolve_provider: Some(true) }), document_formatting_provider: Some(OneOf::Left(true)), - document_range_formatting_provider: None, + document_range_formatting_provider: match config.rustfmt() { + RustfmtConfig::Rustfmt { enable_range_formatting: true, .. } => Some(OneOf::Left(true)), + _ => Some(OneOf::Left(false)), + }, document_on_type_formatting_provider: Some(DocumentOnTypeFormattingOptions { first_trigger_character: "=".to_string(), - more_trigger_character: Some(vec![".".to_string(), ">".to_string()]), + more_trigger_character: Some(vec![".".to_string(), ">".to_string(), "{".to_string()]), }), selection_range_provider: Some(SelectionRangeProviderCapability::Simple(true)), - semantic_highlighting: None, folding_range_provider: Some(FoldingRangeProviderCapability::Simple(true)), rename_provider: Some(OneOf::Right(RenameOptions { prepare_provider: Some(true), @@ -115,12 +114,15 @@ pub fn server_capabilities(client_caps: &ClientCapabilities) -> ServerCapabiliti moniker_provider: None, experimental: Some(json!({ "joinLines": true, + "openCargoToml": true, "ssr": true, "onEnter": true, "parentModule": true, + "hoverRange": true, "runnables": { "kinds": [ "cargo" ], }, + "workspaceSymbolScopeKindFiltering": true, })), } } @@ -129,7 +131,7 @@ fn completions_resolve_provider(client_caps: &ClientCapabilities) -> Option