diff options
author | Christian Duerr <contact@christianduerr.com> | 2020-03-07 22:17:38 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-07 22:17:38 +0000 |
commit | 64a3115648d354731ef08c2de8b2168b9326b7b5 (patch) | |
tree | c9121ed2e475ed2b531d8f8a1c01d9f000d74769 /alacritty_terminal/src/grid/mod.rs | |
parent | de5d770416eb6ea5567b2b46874b8e35b084b9e1 (diff) | |
download | alacritty-64a3115648d354731ef08c2de8b2168b9326b7b5.tar.gz alacritty-64a3115648d354731ef08c2de8b2168b9326b7b5.zip |
Fix selection with invisible start and end
This resolves an issue with the selection clamping, where no selection
would be rendered at all when the start was above the viewport while the
end was below it.
Diffstat (limited to 'alacritty_terminal/src/grid/mod.rs')
-rw-r--r-- | alacritty_terminal/src/grid/mod.rs | 36 |
1 files changed, 11 insertions, 25 deletions
diff --git a/alacritty_terminal/src/grid/mod.rs b/alacritty_terminal/src/grid/mod.rs index febdff69..34d989db 100644 --- a/alacritty_terminal/src/grid/mod.rs +++ b/alacritty_terminal/src/grid/mod.rs @@ -145,24 +145,21 @@ impl<T: GridCell + PartialEq + Copy> Grid<T> { Grid { raw, cols, lines, display_offset: 0, selection: None, max_scroll_limit: scrollback } } - pub fn buffer_to_visible(&self, point: impl Into<Point<usize>>) -> Option<Point<usize>> { - let mut point = point.into(); - - if point.line < self.display_offset || point.line >= self.display_offset + self.lines.0 { - return None; + /// Clamp a buffer point to the visible region. + pub fn clamp_buffer_to_visible(&self, point: Point<usize>) -> Point { + if point.line < self.display_offset { + Point::new(self.lines - 1, self.cols - 1) + } else if point.line >= self.display_offset + self.lines.0 { + Point::new(Line(0), Column(0)) + } else { + // Since edgecases are handled, conversion is identical as visible to buffer + self.visible_to_buffer(point.into()).into() } - - point.line = self.lines.0 + self.display_offset - point.line - 1; - - Some(point) } + /// Convert viewport relative point to global buffer indexing. pub fn visible_to_buffer(&self, point: Point) -> Point<usize> { - Point { line: self.visible_line_to_buffer(point.line), col: point.col } - } - - fn visible_line_to_buffer(&self, line: Line) -> usize { - self.line_to_offset(line) + self.display_offset + Point { line: self.lines.0 + self.display_offset - point.line.0 - 1, col: point.col } } /// Update the size of the scrollback history @@ -453,17 +450,6 @@ impl<T: GridCell + PartialEq + Copy> Grid<T> { self.lines = target; } - /// Convert a Line index (active region) to a buffer offset - /// - /// # Panics - /// - /// This method will panic if `Line` is larger than the grid dimensions - pub fn line_to_offset(&self, line: Line) -> usize { - assert!(line < self.num_lines()); - - *(self.num_lines() - line - 1) - } - #[inline] pub fn scroll_down(&mut self, region: &Range<Line>, positions: Line, template: &T) { let num_lines = self.num_lines().0; |