diff options
author | zeertzjq <zeertzjq@outlook.com> | 2023-06-05 09:19:09 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-06-05 09:19:09 +0800 |
commit | cc41697775b0ea4a41a4f82a9e466123d4a2d77f (patch) | |
tree | babfc7fab6873ff516a0c3fe1dbc4708a20f883f /src/nvim/move.c | |
parent | 5282d3299c9b1b07f3e02a9014bc2632cf3b4fed (diff) | |
parent | 7955c90621bb679f9c16b6788fbcb6145739886f (diff) | |
download | rneovim-cc41697775b0ea4a41a4f82a9e466123d4a2d77f.tar.gz rneovim-cc41697775b0ea4a41a4f82a9e466123d4a2d77f.tar.bz2 rneovim-cc41697775b0ea4a41a4f82a9e466123d4a2d77f.zip |
Merge pull request #23908 from zeertzjq/vim-9.0.1600
vim-patch:9.0.{1600,1607}: screenpos() fixes
Diffstat (limited to 'src/nvim/move.c')
-rw-r--r-- | src/nvim/move.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/src/nvim/move.c b/src/nvim/move.c index 48691db26d..6fb6656472 100644 --- a/src/nvim/move.c +++ b/src/nvim/move.c @@ -1069,21 +1069,20 @@ void textpos2screenpos(win_T *wp, pos_T *pos, int *rowp, int *scolp, int *ccolp, bool visible_row = false; bool is_folded = false; - if (pos->lnum >= wp->w_topline && pos->lnum <= wp->w_botline) { - linenr_T lnum = pos->lnum; + linenr_T lnum = pos->lnum; + if (lnum >= wp->w_topline && lnum <= wp->w_botline) { is_folded = hasFoldingWin(wp, lnum, &lnum, NULL, true, NULL); row = plines_m_win(wp, wp->w_topline, lnum - 1) + 1; // Add filler lines above this buffer line. - row += win_get_fill(wp, lnum); + row += lnum == wp->w_topline ? wp->w_topfill : win_get_fill(wp, lnum); visible_row = true; - } else if (!local || pos->lnum < wp->w_topline) { + } else if (!local || lnum < wp->w_topline) { row = 0; } else { row = wp->w_height_inner; } - bool existing_row = (pos->lnum > 0 - && pos->lnum <= wp->w_buffer->b_ml.ml_line_count); + bool existing_row = (lnum > 0 && lnum <= wp->w_buffer->b_ml.ml_line_count); if ((local || visible_row) && existing_row) { const colnr_T off = win_col_off(wp); @@ -1091,6 +1090,7 @@ void textpos2screenpos(win_T *wp, pos_T *pos, int *rowp, int *scolp, int *ccolp, row += local ? 0 : wp->w_winrow + wp->w_winrow_off; coloff = (local ? 0 : wp->w_wincol + wp->w_wincol_off) + 1 + off; } else { + assert(lnum == pos->lnum); getvcol(wp, pos, &scol, &ccol, &ecol); // similar to what is done in validate_cursor_col() @@ -1098,6 +1098,10 @@ void textpos2screenpos(win_T *wp, pos_T *pos, int *rowp, int *scolp, int *ccolp, col += off; int width = wp->w_width_inner - off + win_col_off2(wp); + if (lnum == wp->w_topline) { + col -= wp->w_skipcol; + } + // long line wrapping, adjust row if (wp->w_p_wrap && col >= (colnr_T)wp->w_width_inner && width > 0) { // use same formula as what is used in curs_columns() |