update x_offset calculation in Buffer::set_string_truncated (#3839)

when `truncate_start` is `true`, the `x_offset` is now properly updated
according to the width of the content or the truncated length.
This commit is contained in:
kristopherbullinger 2022-11-16 20:06:50 -05:00 committed by GitHub
parent 94346356e7
commit 7483c76222
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -360,14 +360,14 @@ pub fn set_string_truncated(
let mut start_index = self.index_of(x, y); let mut start_index = self.index_of(x, y);
let mut index = self.index_of(max_offset as u16, y); let mut index = self.index_of(max_offset as u16, y);
let total_width = string.width(); let content_width = string.width();
let truncated = total_width > width; let truncated = content_width > width;
if ellipsis && truncated { if ellipsis && truncated {
self.content[start_index].set_symbol(""); self.content[start_index].set_symbol("");
start_index += 1; start_index += 1;
} }
if !truncated { if !truncated {
index -= width - total_width; index -= width - content_width;
} }
for (byte_offset, s) in graphemes.rev() { for (byte_offset, s) in graphemes.rev() {
let width = s.width(); let width = s.width();
@ -384,6 +384,7 @@ pub fn set_string_truncated(
self.content[i].reset(); self.content[i].reset();
} }
index -= width; index -= width;
x_offset += width;
} }
} }
(x_offset as u16, y) (x_offset as u16, y)