From 54357d65535153996fd157362dd53ad819e2450f Mon Sep 17 00:00:00 2001 From: Antonio Scandurra Date: Fri, 24 Nov 2023 13:10:56 +0100 Subject: [PATCH] Syntax highlight completions --- crates/editor2/src/editor.rs | 25 ++++++++++++++----------- crates/editor2/src/editor_tests.rs | 2 +- 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/crates/editor2/src/editor.rs b/crates/editor2/src/editor.rs index 05660df430..8387e41e7f 100644 --- a/crates/editor2/src/editor.rs +++ b/crates/editor2/src/editor.rs @@ -43,8 +43,8 @@ use gpui::{ AppContext, AsyncWindowContext, BackgroundExecutor, Bounds, ClipboardItem, Context, EventEmitter, FocusHandle, FocusableView, FontFeatures, FontStyle, FontWeight, HighlightStyle, Hsla, InputHandler, KeyContext, Model, MouseButton, ParentElement, Pixels, Render, RenderOnce, - SharedString, Styled, Subscription, Task, TextRun, TextStyle, UniformListScrollHandle, View, - ViewContext, VisualContext, WeakView, WhiteSpace, WindowContext, + SharedString, Styled, StyledText, Subscription, Task, TextRun, TextStyle, + UniformListScrollHandle, View, ViewContext, VisualContext, WeakView, WhiteSpace, WindowContext, }; use highlight_matching_bracket::refresh_matching_bracket_highlights; use hover_popover::{hide_hover, HoverState}; @@ -1251,6 +1251,7 @@ impl CompletionsMenu { let completions = self.completions.clone(); let matches = self.matches.clone(); let selected_item = self.selected_item; + let style = style.clone(); let list = uniform_list( cx.view().clone(), @@ -1274,13 +1275,12 @@ impl CompletionsMenu { &None }; - // todo!("highlights") - // let highlights = combine_syntax_and_fuzzy_match_highlights( - // &completion.label.text, - // style.text.color.into(), - // styled_runs_for_code_label(&completion.label, &style.syntax), - // &mat.positions, - // ) + let completion_runs = combine_syntax_and_fuzzy_match_highlights( + &completion.label.text, + &style.text, + styled_runs_for_code_label(&completion.label, &style.syntax), + &mat.positions, + ); // todo!("documentation") // MouseEventHandler::new::(mat.candidate_id, cx, |state, _| { @@ -1364,7 +1364,10 @@ impl CompletionsMenu { .bg(gpui::green()) .hover(|style| style.bg(gpui::blue())) .when(item_ix == selected_item, |div| div.bg(gpui::red())) - .child(SharedString::from(completion.label.text.clone())) + .child( + StyledText::new(completion.label.text.clone()) + .with_runs(completion_runs), + ) .min_w(px(300.)) .max_w(px(700.)) }) @@ -10080,7 +10083,7 @@ pub fn diagnostic_style( pub fn combine_syntax_and_fuzzy_match_highlights( text: &str, - default_style: TextStyle, + default_style: &TextStyle, syntax_ranges: impl Iterator, HighlightStyle)>, match_indices: &[usize], ) -> Vec { diff --git a/crates/editor2/src/editor_tests.rs b/crates/editor2/src/editor_tests.rs index 42a1bf3c62..feee78fa3a 100644 --- a/crates/editor2/src/editor_tests.rs +++ b/crates/editor2/src/editor_tests.rs @@ -6770,7 +6770,7 @@ fn test_combine_syntax_and_fuzzy_match_highlights() { assert_eq!( combine_syntax_and_fuzzy_match_highlights( string, - Default::default(), + &TextStyle::default(), syntax_ranges.into_iter(), &match_indices, ),