summaryrefslogtreecommitdiff
path: root/alacritty_terminal/src
diff options
context:
space:
mode:
authorKirill Chibisov <wchibisovkirill@gmail.com>2019-11-17 03:04:16 +0300
committerChristian Duerr <contact@christianduerr.com>2019-11-17 01:04:16 +0100
commit495a6f3526f5127c342d67980d0335f1ed4e235b (patch)
tree548846bfec427e786a8d90abdacec4ffbd11eafe /alacritty_terminal/src
parent48861e463311145a653350688dc4bad83a528d91 (diff)
downloadalacritty-495a6f3526f5127c342d67980d0335f1ed4e235b.tar.gz
alacritty-495a6f3526f5127c342d67980d0335f1ed4e235b.zip
Fix cell reset not clearing flags and foreground
Fixes #2330.
Diffstat (limited to 'alacritty_terminal/src')
-rw-r--r--alacritty_terminal/src/ansi.rs6
-rw-r--r--alacritty_terminal/src/term/cell.rs2
-rw-r--r--alacritty_terminal/src/term/mod.rs44
3 files changed, 24 insertions, 28 deletions
diff --git a/alacritty_terminal/src/ansi.rs b/alacritty_terminal/src/ansi.rs
index 3cd03cbb..a889862f 100644
--- a/alacritty_terminal/src/ansi.rs
+++ b/alacritty_terminal/src/ansi.rs
@@ -328,8 +328,8 @@ pub trait Handler {
/// Write clipboard data to child.
fn write_clipboard<W: io::Write>(&mut self, _: u8, _: &mut W) {}
- /// Run the dectest routine
- fn dectest(&mut self) {}
+ /// Run the decaln routine.
+ fn decaln(&mut self) {}
/// Push a title onto the stack
fn push_title(&mut self) {}
@@ -1134,7 +1134,7 @@ where
b'7' => self.handler.save_cursor_position(),
b'8' => {
if !intermediates.is_empty() && intermediates[0] == b'#' {
- self.handler.dectest();
+ self.handler.decaln();
} else {
self.handler.restore_cursor_position();
}
diff --git a/alacritty_terminal/src/term/cell.rs b/alacritty_terminal/src/term/cell.rs
index 234805f9..bb7869b2 100644
--- a/alacritty_terminal/src/term/cell.rs
+++ b/alacritty_terminal/src/term/cell.rs
@@ -135,7 +135,7 @@ impl Cell {
#[inline]
pub fn reset(&mut self, template: &Cell) {
// memcpy template to self
- *self = *template;
+ *self = Cell { c: template.c, bg: template.bg, ..Cell::default() };
}
#[inline]
diff --git a/alacritty_terminal/src/term/mod.rs b/alacritty_terminal/src/term/mod.rs
index f0f38941..ce63c407 100644
--- a/alacritty_terminal/src/term/mod.rs
+++ b/alacritty_terminal/src/term/mod.rs
@@ -1049,13 +1049,15 @@ impl<T> Term<T> {
// Scroll up to keep cursor in terminal
if self.cursor.point.line >= num_lines {
let lines = self.cursor.point.line - num_lines + 1;
- self.grid.scroll_up(&(Line(0)..old_lines), lines, &self.cursor.template);
+ let template = Cell { bg: self.cursor.template.bg, ..Cell::default() };
+ self.grid.scroll_up(&(Line(0)..old_lines), lines, &template);
}
// Scroll up alt grid as well
if self.cursor_save_alt.point.line >= num_lines {
let lines = self.cursor_save_alt.point.line - num_lines + 1;
- self.alt_grid.scroll_up(&(Line(0)..old_lines), lines, &self.cursor_save_alt.template);
+ let template = Cell { bg: self.cursor_save_alt.template.bg, ..Cell::default() };
+ self.alt_grid.scroll_up(&(Line(0)..old_lines), lines, &template);
}
// Move prompt down when growing if scrollback lines are available
@@ -1105,12 +1107,12 @@ impl<T> Term<T> {
pub fn swap_alt(&mut self) {
if self.alt {
- let template = &self.cursor.template;
- self.grid.region_mut(..).each(|c| c.reset(template));
+ let template = self.cursor.template;
+ self.grid.region_mut(..).each(|c| c.reset(&template));
}
self.alt = !self.alt;
- ::std::mem::swap(&mut self.grid, &mut self.alt_grid);
+ std::mem::swap(&mut self.grid, &mut self.alt_grid);
}
/// Scroll screen down
@@ -1124,8 +1126,7 @@ impl<T> Term<T> {
lines = min(lines, self.scroll_region.end - origin);
// Scroll between origin and bottom
- let mut template = self.cursor.template;
- template.flags = Flags::empty();
+ let template = Cell { bg: self.cursor.template.bg, ..Cell::default() };
self.grid.scroll_down(&(origin..self.scroll_region.end), lines, &template);
}
@@ -1139,8 +1140,7 @@ impl<T> Term<T> {
let lines = min(lines, self.scroll_region.end - self.scroll_region.start);
// Scroll from origin to bottom less number of lines
- let mut template = self.cursor.template;
- template.flags = Flags::empty();
+ let template = Cell { bg: self.cursor.template.bg, ..Cell::default() };
self.grid.scroll_up(&(origin..self.scroll_region.end), lines, &template);
}
@@ -1308,11 +1308,10 @@ impl<T: EventListener> ansi::Handler for Term<T> {
}
#[inline]
- fn dectest(&mut self) {
- trace!("Dectesting");
- let mut template = self.cursor.template;
- template.c = 'E';
+ fn decaln(&mut self) {
+ trace!("Decalnning");
+ let template = Cell { c: 'E', ..Cell::default() };
self.grid.region_mut(..).each(|c| c.reset(&template));
}
@@ -1363,9 +1362,8 @@ impl<T: EventListener> ansi::Handler for Term<T> {
// Cells were just moved out towards the end of the line; fill in
// between source and dest with blanks.
- let template = self.cursor.template;
for c in &mut line[source..destination] {
- c.reset(&template);
+ c.reset(&self.cursor.template);
}
}
@@ -1581,9 +1579,9 @@ impl<T: EventListener> ansi::Handler for Term<T> {
let end = min(start + count, self.grid.num_cols());
let row = &mut self.grid[self.cursor.point.line];
- let template = self.cursor.template; // Cleared cells have current background color set
+ // Cleared cells have current background color set
for c in &mut row[start..end] {
- c.reset(&template);
+ c.reset(&self.cursor.template);
}
}
@@ -1609,10 +1607,9 @@ impl<T: EventListener> ansi::Handler for Term<T> {
// Clear last `count` cells in line. If deleting 1 char, need to delete
// 1 cell.
- let template = self.cursor.template;
let end = cols - count;
for c in &mut line[end..] {
- c.reset(&template);
+ c.reset(&self.cursor.template);
}
}
@@ -1658,7 +1655,6 @@ impl<T: EventListener> ansi::Handler for Term<T> {
#[inline]
fn clear_line(&mut self, mode: ansi::LineClearMode) {
trace!("Clearing line: {:?}", mode);
- let template = Cell { bg: self.cursor.template.bg, ..Cell::default() };
let col = self.cursor.point.col;
@@ -1666,19 +1662,19 @@ impl<T: EventListener> ansi::Handler for Term<T> {
ansi::LineClearMode::Right => {
let row = &mut self.grid[self.cursor.point.line];
for cell in &mut row[col..] {
- cell.reset(&template);
+ cell.reset(&self.cursor.template);
}
},
ansi::LineClearMode::Left => {
let row = &mut self.grid[self.cursor.point.line];
for cell in &mut row[..=col] {
- cell.reset(&template);
+ cell.reset(&self.cursor.template);
}
},
ansi::LineClearMode::All => {
let row = &mut self.grid[self.cursor.point.line];
for cell in &mut row[..] {
- cell.reset(&template);
+ cell.reset(&self.cursor.template);
}
},
}
@@ -1746,7 +1742,7 @@ impl<T: EventListener> ansi::Handler for Term<T> {
#[inline]
fn clear_screen(&mut self, mode: ansi::ClearMode) {
trace!("Clearing screen: {:?}", mode);
- let template = Cell { bg: self.cursor.template.bg, ..Cell::default() };
+ let template = self.cursor.template;
// Remove active selections
self.grid.selection = None;