From fe8e06e781b312b3a7771b2564f9c8723a9de3c1 Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Fri, 1 Apr 2022 12:07:41 -0700 Subject: [PATCH] Fix clipping when using label-only completions --- crates/project/src/project.rs | 26 +++++++++++++++----------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/crates/project/src/project.rs b/crates/project/src/project.rs index a8311ccf3b..d82629ab67 100644 --- a/crates/project/src/project.rs +++ b/crates/project/src/project.rs @@ -2373,13 +2373,6 @@ impl Project { }; cx.spawn(|_, cx| async move { - let clipped_position = source_buffer_handle - .read_with(&cx, |this, _| this.clip_point_utf16(position, Bias::Left)); - if clipped_position != position { - log::info!("Completion position out of date"); - return Ok(Default::default()); - } - let completions = lang_server .request::(lsp::CompletionParams { text_document_position: lsp::TextDocumentPositionParams::new( @@ -2412,10 +2405,21 @@ impl Project { Some(lsp::CompletionTextEdit::Edit(edit)) => { (range_from_lsp(edit.range), edit.new_text.clone()) } - None => ( - this.common_prefix_at(position, &lsp_completion.label), - lsp_completion.label.clone(), - ), + None => { + let clipped_position = + this.clip_point_utf16(position, Bias::Left); + if position != clipped_position { + log::info!("completion out of expected range"); + return None; + } + ( + this.common_prefix_at( + clipped_position, + &lsp_completion.label, + ), + lsp_completion.label.clone(), + ) + } Some(lsp::CompletionTextEdit::InsertAndReplace(_)) => { log::info!("unsupported insert/replace completion"); return None;