From dbccd7e30f40d9a7485c7537b415473ffc09b3d3 Mon Sep 17 00:00:00 2001 From: Kirill Chibisov Date: Sun, 6 Mar 2022 19:34:12 +0300 Subject: [PATCH] Use round instead of ceil for line position Ceiling line position results in strikeout line being lower than it should. --- alacritty/res/rect.f.glsl | 2 +- alacritty/src/renderer/rects.rs | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/alacritty/res/rect.f.glsl b/alacritty/res/rect.f.glsl index 0e0a2616aa9..4fbbd87468b 100644 --- a/alacritty/res/rect.f.glsl +++ b/alacritty/res/rect.f.glsl @@ -87,7 +87,7 @@ color_t draw_dotted(float_t x, float_t y) { // Since we use the entire descent area for dotted underlines, we limit its // height to a single pixel so we don't draw bars instead of dots. - float_t alpha = 1. - abs(floor(underlinePosition - 0.5) - y); + float_t alpha = 1. - abs(floor(underlinePosition) - y); if (int(mod(x, 2.)) != int(cellEven)) { alpha = 0.; } diff --git a/alacritty/src/renderer/rects.rs b/alacritty/src/renderer/rects.rs index 8c600b6bf8a..a4a6bf5d96f 100644 --- a/alacritty/src/renderer/rects.rs +++ b/alacritty/src/renderer/rects.rs @@ -137,7 +137,7 @@ impl RenderLine { let line_bottom = (start.line as f32 + 1.) * size.cell_height(); let baseline = line_bottom + descent; - let mut y = (baseline - position - thickness / 2.).ceil(); + let mut y = (baseline - position - thickness / 2.).round(); let max_y = line_bottom - thickness; if y > max_y { y = max_y;