aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2021-12-03 11:40:52 -0500
committerJesse Luehrs <doy@tozt.net>2021-12-03 11:40:52 -0500
commit481f6d62265916992dd5b7d3cb3c98c48004372a (patch)
tree14b6eab60b72f642759c5ad9e8867257a8e8ba52 /src
parentc2a1180df6cb44d73abf0412e2c10efc4f0438f0 (diff)
downloadvt100-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.rs11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/row.rs b/src/row.rs
index e666cb7..48c18eb 100644
--- a/src/row.rs
+++ b/src/row.rs
@@ -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();