summaryrefslogtreecommitdiff
path: root/alacritty_terminal/src/term/cell.rs
diff options
context:
space:
mode:
authorChristian Duerr <contact@christianduerr.com>2020-01-09 23:06:41 +0000
committerGitHub <noreply@github.com>2020-01-09 23:06:41 +0000
commit3fb631b91caec163707858bd1d435015e6e6cb18 (patch)
treecfc575f224622b7c83a21281c2e23a7f8af83364 /alacritty_terminal/src/term/cell.rs
parent5651c3f7114dff611e616865ad02e682779979d9 (diff)
downloadalacritty-3fb631b91caec163707858bd1d435015e6e6cb18.tar.gz
alacritty-3fb631b91caec163707858bd1d435015e6e6cb18.zip
Fix cut off full width glyphs in last column
This resolves the issue with full width glyphs getting rendered in the last column. Since they need at least two glyphs, it is not possible to properly render them in the last column. Instead of rendering half of the glyph in the last column, with the other half cut off, an additional spacer is now inserted before the wide glyph. This means that the specific glyph in question is then three cells wide. Fixes #2385.
Diffstat (limited to 'alacritty_terminal/src/term/cell.rs')
-rw-r--r--alacritty_terminal/src/term/cell.rs22
1 files changed, 11 insertions, 11 deletions
diff --git a/alacritty_terminal/src/term/cell.rs b/alacritty_terminal/src/term/cell.rs
index 92725336..d57f57cc 100644
--- a/alacritty_terminal/src/term/cell.rs
+++ b/alacritty_terminal/src/term/cell.rs
@@ -67,23 +67,23 @@ impl GridCell for Cell {
&& self.extra[0] == ' '
&& self.bg == Color::Named(NamedColor::Background)
&& self.fg == Color::Named(NamedColor::Foreground)
- && !self
- .flags
- .intersects(Flags::INVERSE | Flags::UNDERLINE | Flags::STRIKEOUT | Flags::WRAPLINE)
+ && !self.flags.intersects(
+ Flags::INVERSE
+ | Flags::UNDERLINE
+ | Flags::STRIKEOUT
+ | Flags::WRAPLINE
+ | Flags::WIDE_CHAR_SPACER,
+ )
}
#[inline]
- fn is_wrap(&self) -> bool {
- self.flags.contains(Flags::WRAPLINE)
+ fn flags(&self) -> &Flags {
+ &self.flags
}
#[inline]
- fn set_wrap(&mut self, wrap: bool) {
- if wrap {
- self.flags.insert(Flags::WRAPLINE);
- } else {
- self.flags.remove(Flags::WRAPLINE);
- }
+ fn flags_mut(&mut self) -> &mut Flags {
+ &mut self.flags
}
#[inline]