summaryrefslogtreecommitdiff
path: root/alacritty_terminal/src/term
diff options
context:
space:
mode:
authorChristian Duerr <contact@christianduerr.com>2019-11-04 00:14:23 +0100
committerGitHub <noreply@github.com>2019-11-04 00:14:23 +0100
commit93e87eb0f1858138113d4ecdfaa8bfac3c127a39 (patch)
tree8c7a1083907c6efabad3de0e6a875c665c500b0e /alacritty_terminal/src/term
parentb47a88b142a8987f1d0d48db8c0db1e5f3048a76 (diff)
downloadalacritty-93e87eb0f1858138113d4ecdfaa8bfac3c127a39.tar.gz
alacritty-93e87eb0f1858138113d4ecdfaa8bfac3c127a39.zip
Fix incorrect cell foreground when clearing screen
This fixes a bug that would clear the cells with the current template cell with just the `flags` reset, to make sure the colors are correct. However, the cell foreground was not reset, leading to cells counting as occupied when resizing. With this change both cell flags and foreground color are ignored when clearing both the whole screen and inside the line, allowing us to accurately keep track of cell occupation. Fixes #2866.
Diffstat (limited to 'alacritty_terminal/src/term')
-rw-r--r--alacritty_terminal/src/term/mod.rs6
1 files changed, 2 insertions, 4 deletions
diff --git a/alacritty_terminal/src/term/mod.rs b/alacritty_terminal/src/term/mod.rs
index 63a5e040..f7b37b23 100644
--- a/alacritty_terminal/src/term/mod.rs
+++ b/alacritty_terminal/src/term/mod.rs
@@ -1661,8 +1661,7 @@ impl<T: EventListener> ansi::Handler for Term<T> {
#[inline]
fn clear_line(&mut self, mode: ansi::LineClearMode) {
trace!("Clearing line: {:?}", mode);
- let mut template = self.cursor.template;
- template.flags ^= template.flags;
+ let template = Cell { bg: self.cursor.template.bg, ..Cell::default() };
let col = self.cursor.point.col;
@@ -1725,8 +1724,7 @@ impl<T: EventListener> ansi::Handler for Term<T> {
#[inline]
fn clear_screen(&mut self, mode: ansi::ClearMode) {
trace!("Clearing screen: {:?}", mode);
- let mut template = self.cursor.template;
- template.flags ^= template.flags;
+ let template = Cell { bg: self.cursor.template.bg, ..Cell::default() };
// Remove active selections
self.grid.selection = None;