aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2023-03-12 12:10:27 +0800
committerGitHub <noreply@github.com>2023-03-12 12:10:27 +0800
commit172227a44642b67ec8af5b438e5373a3daf61fdb (patch)
tree3249c062a84ca4c9592d522b499c5834208bab09 /src
parent1c4b3d41b538078234282cfba74e5cf07c42c916 (diff)
downloadrneovim-172227a44642b67ec8af5b438e5373a3daf61fdb.tar.gz
rneovim-172227a44642b67ec8af5b438e5373a3daf61fdb.tar.bz2
rneovim-172227a44642b67ec8af5b438e5373a3daf61fdb.zip
fix(screen): correctly draw background and eob with 'rightleft' (#22640)
Diffstat (limited to 'src')
-rw-r--r--src/nvim/grid.c3
-rw-r--r--src/nvim/screen.c17
2 files changed, 9 insertions, 11 deletions
diff --git a/src/nvim/grid.c b/src/nvim/grid.c
index efbeac4f3f..f20a9a847d 100644
--- a/src/nvim/grid.c
+++ b/src/nvim/grid.c
@@ -550,8 +550,7 @@ void grid_put_linebuf(ScreenGrid *grid, int row, int coloff, int endcol, int cle
if (bg_attr) {
for (int c = col; c < endcol; c++) {
- linebuf_attr[off_from + (size_t)c] =
- hl_combine_attr(bg_attr, linebuf_attr[off_from + (size_t)c]);
+ linebuf_attr[c] = hl_combine_attr(bg_attr, linebuf_attr[c]);
}
}
diff --git a/src/nvim/screen.c b/src/nvim/screen.c
index 43c7866180..8b0f8b58a7 100644
--- a/src/nvim/screen.c
+++ b/src/nvim/screen.c
@@ -111,14 +111,14 @@ static int win_fill_end(win_T *wp, int c1, int c2, int off, int width, int row,
int attr)
{
int nn = off + width;
+ const int endcol = wp->w_grid.cols;
- if (nn > wp->w_grid.cols) {
- nn = wp->w_grid.cols;
+ if (nn > endcol) {
+ nn = endcol;
}
if (wp->w_p_rl) {
- grid_fill(&wp->w_grid, row, endrow, W_ENDCOL(wp) - nn, W_ENDCOL(wp) - off,
- c1, c2, attr);
+ grid_fill(&wp->w_grid, row, endrow, endcol - nn, endcol - off, c1, c2, attr);
} else {
grid_fill(&wp->w_grid, row, endrow, off, nn, c1, c2, attr);
}
@@ -156,13 +156,12 @@ void win_draw_end(win_T *wp, int c1, int c2, bool draw_margin, int row, int endr
int attr = hl_combine_attr(win_bg_attr(wp), win_hl_attr(wp, (int)hl));
+ const int endcol = wp->w_grid.cols;
if (wp->w_p_rl) {
- grid_fill(&wp->w_grid, row, endrow, wp->w_wincol, W_ENDCOL(wp) - 1 - n,
- c2, c2, attr);
- grid_fill(&wp->w_grid, row, endrow, W_ENDCOL(wp) - 1 - n, W_ENDCOL(wp) - n,
- c1, c2, attr);
+ grid_fill(&wp->w_grid, row, endrow, 0, endcol - 1 - n, c2, c2, attr);
+ grid_fill(&wp->w_grid, row, endrow, endcol - 1 - n, endcol - n, c1, c2, attr);
} else {
- grid_fill(&wp->w_grid, row, endrow, n, wp->w_grid.cols, c1, c2, attr);
+ grid_fill(&wp->w_grid, row, endrow, n, endcol, c1, c2, attr);
}
}