aboutsummaryrefslogtreecommitdiff
path: root/helix-term/src/commands
diff options
context:
space:
mode:
authorlazytanuki2022-06-27 11:19:56 +0000
committerGitHub2022-06-27 11:19:56 +0000
commit096abdd19bb422cba607d43d05b195b37a7f95e9 (patch)
tree6c958977196fdad8d090d1962f862464d7e107eb /helix-term/src/commands
parentfde9e034d4a7bd16d3c9780600874323e4e91628 (diff)
feat: highlight / select symbol under cursor using LSP textDocument/documentHighlight (#2738)
* feat: highlight symbol under cursor using LSP textDocument/documentHighlight * fix: please clippy * fix: shorter description and code style
Diffstat (limited to 'helix-term/src/commands')
-rw-r--r--helix-term/src/commands/lsp.rs43
1 files changed, 43 insertions, 0 deletions
diff --git a/helix-term/src/commands/lsp.rs b/helix-term/src/commands/lsp.rs
index 6f75fb49..c1cdb164 100644
--- a/helix-term/src/commands/lsp.rs
+++ b/helix-term/src/commands/lsp.rs
@@ -655,6 +655,7 @@ pub fn signature_help(cx: &mut Context) {
},
);
}
+
pub fn hover(cx: &mut Context) {
let (view, doc) = current!(cx.editor);
let language_server = language_server!(cx.editor, doc);
@@ -704,6 +705,7 @@ pub fn hover(cx: &mut Context) {
},
);
}
+
pub fn rename_symbol(cx: &mut Context) {
ui::prompt(
cx,
@@ -729,3 +731,44 @@ pub fn rename_symbol(cx: &mut Context) {
},
);
}
+
+pub fn select_references_to_symbol_under_cursor(cx: &mut Context) {
+ let (view, doc) = current!(cx.editor);
+ let language_server = language_server!(cx.editor, doc);
+ let offset_encoding = language_server.offset_encoding();
+
+ let pos = doc.position(view.id, offset_encoding);
+
+ let future = language_server.text_document_document_highlight(doc.identifier(), pos, None);
+
+ cx.callback(
+ future,
+ move |editor, _compositor, response: Option<Vec<lsp::DocumentHighlight>>| {
+ let document_highlights = match response {
+ Some(highlights) if !highlights.is_empty() => highlights,
+ _ => return,
+ };
+ let (view, doc) = current!(editor);
+ let language_server = language_server!(editor, doc);
+ let offset_encoding = language_server.offset_encoding();
+ let text = doc.text();
+ let pos = doc.selection(view.id).primary().head;
+
+ // We must find the range that contains our primary cursor to prevent our primary cursor to move
+ let mut primary_index = 0;
+ let ranges = document_highlights
+ .iter()
+ .filter_map(|highlight| lsp_range_to_range(text, highlight.range, offset_encoding))
+ .enumerate()
+ .map(|(i, range)| {
+ if range.contains(pos) {
+ primary_index = i;
+ }
+ range
+ })
+ .collect();
+ let selection = Selection::new(ranges, primary_index);
+ doc.set_selection(view.id, selection);
+ },
+ );
+}