Consider offsets in inlay chunks

Kirill Bulatov created

Change summary

crates/editor/src/display_map/inlay_map.rs | 48 +++---------------------
1 file changed, 6 insertions(+), 42 deletions(-)

Detailed changes

crates/editor/src/display_map/inlay_map.rs 🔗

@@ -315,15 +315,15 @@ impl<'a> Iterator for InlayChunks<'a> {
                     InlayId::Hint(_) => self.inlay_highlight_style,
                 };
                 let next_inlay_highlight_endpoint;
+                let offset_in_inlay = self.output_offset - self.transforms.start().0;
                 if let Some((style, inlay_range)) = inlay_highlight_style_and_range {
-                    let offset_in_inlay = (self.output_offset - self.transforms.start().0).0;
                     let range = inlay_range.highlight_start..inlay_range.highlight_end;
-                    if offset_in_inlay < range.start {
+                    if offset_in_inlay.0 < range.start {
                         next_inlay_highlight_endpoint = range.start;
-                    } else if offset_in_inlay >= range.end {
+                    } else if offset_in_inlay.0 >= range.end {
                         next_inlay_highlight_endpoint = usize::MAX;
                     } else {
-                        next_inlay_highlight_endpoint = range.end;
+                        next_inlay_highlight_endpoint = range.end - offset_in_inlay.0;
                         highlight_style
                             .get_or_insert_with(|| Default::default())
                             .highlight(style.clone());
@@ -332,9 +332,8 @@ impl<'a> Iterator for InlayChunks<'a> {
                     next_inlay_highlight_endpoint = usize::MAX;
                 }
 
-                //
                 let inlay_chunks = self.inlay_chunks.get_or_insert_with(|| {
-                    let start = self.output_offset - self.transforms.start().0;
+                    let start = offset_in_inlay;
                     let end = cmp::min(self.max_output_offset, self.transforms.end(&()).0)
                         - self.transforms.start().0;
                     inlay.text.chunks_in_range(start.0..end.0)
@@ -1035,7 +1034,6 @@ impl InlaySnapshot {
         cursor.seek(&range.start, Bias::Right, &());
 
         let mut highlight_endpoints = Vec::new();
-        // TODO kb repeat this for all other highlights?
         if let Some(text_highlights) = highlights.text_highlights {
             if !text_highlights.is_empty() {
                 self.apply_text_highlights(
@@ -1048,38 +1046,6 @@ impl InlaySnapshot {
             }
         }
         highlight_endpoints.sort();
-
-        // if let Some(inlay_highlights) = highlights.inlay_highlights {
-        //     let adjusted_highlights = TreeMap::from_ordered_entries(inlay_highlights.iter().map(
-        //         |(type_id, styled_ranges)| {
-        //             (
-        //                 *type_id,
-        //                 Arc::new((styled_ranges.0, styled_ranges.1.as_slice())),
-        //             )
-        //         },
-        //     ));
-        //     if !inlay_highlights.is_empty() {
-        //         self.apply_inlay_highlights(
-        //             &mut cursor,
-        //             &range,
-        //             &adjusted_highlights,
-        //             &mut highlight_endpoints,
-        //         );
-        //         cursor.seek(&range.start, Bias::Right, &());
-        //     }
-        // }
-        // if let Some(inlay_background_highlights) = highlights.inlay_background_highlights.as_ref() {
-        //     if !inlay_background_highlights.is_empty() {
-        //         self.apply_inlay_highlights(
-        //             &mut cursor,
-        //             &range,
-        //             inlay_background_highlights,
-        //             &mut highlight_endpoints,
-        //         );
-        //         cursor.seek(&range.start, Bias::Right, &());
-        //     }
-        // }
-
         let buffer_range = self.to_buffer_offset(range.start)..self.to_buffer_offset(range.end);
         let buffer_chunks = self.buffer.chunks(buffer_range, language_aware);
 
@@ -1763,9 +1729,7 @@ mod tests {
                                     inlay: inlay.id,
                                     inlay_position: inlay.position,
                                     highlight_start: 0,
-                                    // TODO kb
-                                    // highlight_end
-                                    highlight_end: inlay_text.len(),
+                                    highlight_end,
                                 })
                             }
                         }