diff options
author | zeertzjq <zeertzjq@outlook.com> | 2023-07-04 14:14:09 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-07-04 14:14:09 +0800 |
commit | e8b3ed74bca4bd6ececcc240f816451bef7fd58c (patch) | |
tree | c01f2117e3c9d8286b1111ffed38cb9d4a05c9e6 /src/nvim/plines.c | |
parent | 92760a7f42a95bb252966c2a38423e5bc9d57cc7 (diff) | |
download | rneovim-e8b3ed74bca4bd6ececcc240f816451bef7fd58c.tar.gz rneovim-e8b3ed74bca4bd6ececcc240f816451bef7fd58c.tar.bz2 rneovim-e8b3ed74bca4bd6ececcc240f816451bef7fd58c.zip |
fix(ui-ext): "scroll_delta" handle topfill and skipcol (#24249)
Diffstat (limited to 'src/nvim/plines.c')
-rw-r--r-- | src/nvim/plines.c | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/src/nvim/plines.c b/src/nvim/plines.c index eb1ae540a4..46bbbeeb07 100644 --- a/src/nvim/plines.c +++ b/src/nvim/plines.c @@ -595,3 +595,52 @@ static int win_nolbr_chartabsize(chartabsize_T *cts, int *headp) } return n; } + +int64_t win_get_text_height(win_T *const wp, const linenr_T first, const linenr_T last, + const int64_t start_vcol, const int64_t end_vcol) +{ + int width1 = 0; + int width2 = 0; + if (start_vcol >= 0 || end_vcol >= 0) { + width1 = wp->w_width_inner - win_col_off(wp); + width2 = width1 + win_col_off2(wp); + width1 = MAX(width1, 0); + width2 = MAX(width2, 0); + } + + int64_t size = 0; + int64_t height_nofill = 0; + linenr_T lnum = first; + + if (start_vcol >= 0) { + linenr_T lnum_next = lnum; + const bool folded = hasFoldingWin(wp, lnum, &lnum, &lnum_next, true, NULL); + height_nofill = folded ? 1 : plines_win_nofill(wp, lnum, false); + size += height_nofill; + const int64_t row_off = (start_vcol < width1 || width2 <= 0) + ? 0 + : 1 + (start_vcol - width1) / width2; + size -= MIN(row_off, height_nofill); + lnum = lnum_next + 1; + } + + while (lnum <= last) { + linenr_T lnum_next = lnum; + const bool folded = hasFoldingWin(wp, lnum, &lnum, &lnum_next, true, NULL); + height_nofill = folded ? 1 : plines_win_nofill(wp, lnum, false); + size += win_get_fill(wp, lnum) + height_nofill; + lnum = lnum_next + 1; + } + + if (end_vcol >= 0) { + size -= height_nofill; + const int64_t row_off = end_vcol == 0 + ? 0 + : (end_vcol <= width1 || width2 <= 0) + ? 1 + : 1 + (end_vcol - width1 + width2 - 1) / width2; + size += MIN(row_off, height_nofill); + } + + return size; +} |