summaryrefslogtreecommitdiff
path: root/src/term
diff options
context:
space:
mode:
authorChristian Duerr <chrisduerr@users.noreply.github.com>2018-10-20 22:30:59 +0000
committerGitHub <noreply@github.com>2018-10-20 22:30:59 +0000
commit4380d0864b1098909bdcfec132b866c34924517e (patch)
treef3c97e5897d1d8007f7fb651bfa2bff814bbc910 /src/term
parent34ada9295d0d3801f305a9818de38ebaeb784f63 (diff)
downloadalacritty-4380d0864b1098909bdcfec132b866c34924517e.tar.gz
alacritty-4380d0864b1098909bdcfec132b866c34924517e.zip
Fix rotation of selection below 0
Whenever the viewport is scrolled, the selection is rotated to make sure that it moves with the viewport. However this did not correctly handle the underflow that happens when the selection goes below 0. This resolves that problem for the selection by moving the internal line representation to an isize, thus correctly keeping track of the selection start/end points even when they have a negative index. Once the selection is converted to a span, the lines are clamped to the visible region. This fixes #1640 and fixes #1643.
Diffstat (limited to 'src/term')
-rw-r--r--src/term/mod.rs6
1 files changed, 4 insertions, 2 deletions
diff --git a/src/term/mod.rs b/src/term/mod.rs
index 495a7567..f4563922 100644
--- a/src/term/mod.rs
+++ b/src/term/mod.rs
@@ -973,8 +973,9 @@ impl Term {
}
}
+ let alt_screen = self.mode.contains(TermMode::ALT_SCREEN);
let selection = self.grid.selection.clone()?;
- let span = selection.to_span(self)?;
+ let span = selection.to_span(self, alt_screen)?;
let mut res = String::new();
@@ -1058,8 +1059,9 @@ impl Term {
config: &'b Config,
window_focused: bool,
) -> RenderableCellsIter {
+ let alt_screen = self.mode.contains(TermMode::ALT_SCREEN);
let selection = self.grid.selection.as_ref()
- .and_then(|s| s.to_span(self))
+ .and_then(|s| s.to_span(self, alt_screen))
.map(|span| {
span.to_locations()
});