diff options
author | Jesse Luehrs <doy@tozt.net> | 2021-12-03 11:40:52 -0500 |
---|---|---|
committer | Jesse Luehrs <doy@tozt.net> | 2021-12-03 11:40:52 -0500 |
commit | 481f6d62265916992dd5b7d3cb3c98c48004372a (patch) | |
tree | 14b6eab60b72f642759c5ad9e8867257a8e8ba52 /src | |
parent | c2a1180df6cb44d73abf0412e2c10efc4f0438f0 (diff) | |
download | vt100-rust-481f6d62265916992dd5b7d3cb3c98c48004372a.tar.gz vt100-rust-481f6d62265916992dd5b7d3cb3c98c48004372a.zip |
fix cell attrs when wrapped but no first cell contents on next line
Diffstat (limited to 'src')
-rw-r--r-- | src/row.rs | 11 |
1 files changed, 11 insertions, 0 deletions
@@ -156,6 +156,11 @@ impl Row { let first_cell = self.get(start).unwrap(); if wrapping && first_cell == &default_cell { + let default_attrs = default_cell.attrs(); + if &prev_attrs != default_attrs { + default_attrs.write_escape_code_diff(contents, &prev_attrs); + prev_attrs = *default_attrs; + } contents.push(b' '); crate::term::Backspace::default().write_buf(contents); crate::term::EraseChar::new(1).write_buf(contents); @@ -294,6 +299,12 @@ impl Row { && prev_pos.col >= self.cols() - if prev_first_cell.is_wide() { 1 } else { 0 } { + let first_cell_attrs = first_cell.attrs(); + if &prev_attrs != first_cell_attrs { + first_cell_attrs + .write_escape_code_diff(contents, &prev_attrs); + prev_attrs = *first_cell_attrs; + } let mut cell_contents = prev_first_cell.contents(); let need_erase = if cell_contents.is_empty() { cell_contents = " ".to_string(); |