aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/plines.c
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2023-06-05 09:19:09 +0800
committerGitHub <noreply@github.com>2023-06-05 09:19:09 +0800
commitcc41697775b0ea4a41a4f82a9e466123d4a2d77f (patch)
treebabfc7fab6873ff516a0c3fe1dbc4708a20f883f /src/nvim/plines.c
parent5282d3299c9b1b07f3e02a9014bc2632cf3b4fed (diff)
parent7955c90621bb679f9c16b6788fbcb6145739886f (diff)
downloadrneovim-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/plines.c')
-rw-r--r--src/nvim/plines.c15
1 files changed, 5 insertions, 10 deletions
diff --git a/src/nvim/plines.c b/src/nvim/plines.c
index 25c745ae97..5f28715f53 100644
--- a/src/nvim/plines.c
+++ b/src/nvim/plines.c
@@ -38,8 +38,7 @@
/// @param winheight when true limit to window height
int plines_win(win_T *wp, linenr_T lnum, bool winheight)
{
- // Check for filler lines above this buffer line. When folded the result
- // is one line anyway.
+ // Check for filler lines above this buffer line.
return plines_win_nofill(wp, lnum, winheight) + win_get_fill(wp, lnum);
}
@@ -199,16 +198,12 @@ int plines_win_col(win_T *wp, linenr_T lnum, long column)
int plines_win_full(win_T *wp, linenr_T lnum, linenr_T *const nextp, bool *const foldedp,
const bool cache, const bool winheight)
{
- bool folded = hasFoldingWin(wp, lnum, NULL, nextp, cache, NULL);
- if (foldedp) {
+ bool folded = hasFoldingWin(wp, lnum, &lnum, nextp, cache, NULL);
+ if (foldedp != NULL) {
*foldedp = folded;
}
- if (folded) {
- return 1;
- } else if (lnum == wp->w_topline) {
- return plines_win_nofill(wp, lnum, winheight) + wp->w_topfill;
- }
- return plines_win(wp, lnum, winheight);
+ return ((folded ? 1 : plines_win_nofill(wp, lnum, winheight)) +
+ (lnum == wp->w_topline ? wp->w_topfill : win_get_fill(wp, lnum)));
}
int plines_m_win(win_T *wp, linenr_T first, linenr_T last)