aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_lsp_server/src/main_loop
diff options
context:
space:
mode:
Diffstat (limited to 'crates/ra_lsp_server/src/main_loop')
-rw-r--r--crates/ra_lsp_server/src/main_loop/handlers.rs26
1 files changed, 23 insertions, 3 deletions
diff --git a/crates/ra_lsp_server/src/main_loop/handlers.rs b/crates/ra_lsp_server/src/main_loop/handlers.rs
index 3b7a14a5c..012f74270 100644
--- a/crates/ra_lsp_server/src/main_loop/handlers.rs
+++ b/crates/ra_lsp_server/src/main_loop/handlers.rs
@@ -6,9 +6,8 @@ use languageserver_types::{
6 DiagnosticSeverity, DocumentSymbol, Documentation, FoldingRange, FoldingRangeKind, 6 DiagnosticSeverity, DocumentSymbol, Documentation, FoldingRange, FoldingRangeKind,
7 FoldingRangeParams, Location, MarkupContent, MarkupKind, MarkedString, Position, 7 FoldingRangeParams, Location, MarkupContent, MarkupKind, MarkedString, Position,
8 PrepareRenameResponse, RenameParams, SymbolInformation, TextDocumentIdentifier, TextEdit, 8 PrepareRenameResponse, RenameParams, SymbolInformation, TextDocumentIdentifier, TextEdit,
9 Range, 9 Range, WorkspaceEdit, ParameterInformation, ParameterLabel, SignatureInformation, Hover,
10 WorkspaceEdit, ParameterInformation, ParameterLabel, SignatureInformation, Hover, HoverContents, 10 HoverContents, DocumentFormattingParams, DocumentHighlight,
11 DocumentFormattingParams,
12}; 11};
13use ra_analysis::{FileId, FoldKind, Query, RunnableKind, FileRange, FilePosition, Severity}; 12use ra_analysis::{FileId, FoldKind, Query, RunnableKind, FileRange, FilePosition, Severity};
14use ra_syntax::{TextUnit, text_utils::intersect}; 13use ra_syntax::{TextUnit, text_utils::intersect};
@@ -668,6 +667,27 @@ pub fn handle_code_action(
668 Ok(Some(CodeActionResponse::Commands(res))) 667 Ok(Some(CodeActionResponse::Commands(res)))
669} 668}
670 669
670pub fn handle_document_highlight(
671 world: ServerWorld,
672 params: req::TextDocumentPositionParams,
673) -> Result<Option<Vec<DocumentHighlight>>> {
674 let file_id = params.text_document.try_conv_with(&world)?;
675 let line_index = world.analysis().file_line_index(file_id);
676
677 let refs = world
678 .analysis()
679 .find_all_refs(params.try_conv_with(&world)?)?;
680
681 Ok(Some(
682 refs.into_iter()
683 .map(|r| DocumentHighlight {
684 range: r.1.conv_with(&line_index),
685 kind: None,
686 })
687 .collect(),
688 ))
689}
690
671pub fn publish_diagnostics( 691pub fn publish_diagnostics(
672 world: &ServerWorld, 692 world: &ServerWorld,
673 file_id: FileId, 693 file_id: FileId,