From 2449834868ba4699a4b381fbc684ed4e4a9a05d0 Mon Sep 17 00:00:00 2001 From: Antonio Scandurra Date: Tue, 30 Nov 2021 11:40:53 +0100 Subject: [PATCH] Use display coordinates for the highlighted row in "go to line" --- crates/go_to_line/src/lib.rs | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/crates/go_to_line/src/lib.rs b/crates/go_to_line/src/lib.rs index 6670c4cf0d57a..4e493b57a07b1 100644 --- a/crates/go_to_line/src/lib.rs +++ b/crates/go_to_line/src/lib.rs @@ -1,5 +1,5 @@ use buffer::{Bias, Point, Selection}; -use editor::{Autoscroll, Editor, EditorSettings}; +use editor::{display_map::ToDisplayPoint, Autoscroll, Editor, EditorSettings}; use gpui::{ action, elements::*, geometry::vector::Vector2F, keymap::Binding, Axis, Entity, MutableAppContext, RenderContext, View, ViewContext, ViewHandle, @@ -138,10 +138,11 @@ impl GoToLine { ) }) { self.line_selection = self.active_editor.update(cx, |active_editor, cx| { - let buffer = active_editor.buffer().read(cx); - let point = buffer.clip_point(point, Bias::Left); + let snapshot = active_editor.snapshot(cx).display_snapshot; + let point = snapshot.buffer_snapshot.clip_point(point, Bias::Left); + let display_point = point.to_display_point(&snapshot); active_editor.select_ranges([point..point], Some(Autoscroll::Center), cx); - active_editor.set_highlighted_row(Some(point.row)); + active_editor.set_highlighted_row(Some(display_point.row())); Some(active_editor.newest_selection(cx)) }); cx.notify();