diff options
author | Sean Dewar <6256228+seandewar@users.noreply.github.com> | 2024-03-13 22:06:39 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-13 22:06:39 +0000 |
commit | bbb68e2a034ad3aaea99178c09301ca458ee8dff (patch) | |
tree | b58d044908487e8cb174a0669f2e36890685f534 /src/nvim/eval.lua | |
parent | 2a8cef6bd450febd88d754e0c1909137b7451757 (diff) | |
download | rneovim-bbb68e2a034ad3aaea99178c09301ca458ee8dff.tar.gz rneovim-bbb68e2a034ad3aaea99178c09301ca458ee8dff.tar.bz2 rneovim-bbb68e2a034ad3aaea99178c09301ca458ee8dff.zip |
vim-patch:9.1.0175: wrong window positions with 'winfix{width,height}' (#27845)
Problem: winframe functions incorrectly recompute window positions if
the altframe wasn't adjacent to the closed frame, which is
possible if adjacent windows had 'winfix{width,height}' set.
Solution: recompute for windows within the parent of the altframe and
closed frame. Skip this (as before) if the altframe was
top/left, but only if adjacent to the closed frame, as
positions won't change in that case. Also correct the return
value documentation for win_screenpos. (Sean Dewar)
The issue revealed itself after removing the win_comp_pos call below
winframe_restore in win_splitmove. Similarly, wrong positions could result from
windows closed in other tabpages, as win_free_mem uses winframe_remove (at least
until it is entered later, where enter_tabpage calls win_comp_pos).
NOTE: As win_comp_pos handles only curtab, it's possible via other means for
positions in non-current tabpages to be wrong (e.g: after changing 'laststatus',
'showtabline', etc.). Given enter_tabpage recomputes it, maybe it's intentional
as an optimization? Should probably be documented in win_screenpos then, but I
won't address that here.
closes: vim/vim#14191
Nvim: don't reuse "wp" for "topleft" in winframe_remove, so the change
integrates better with the call to winframe_find_altwin before it.
https://github.com/vim/vim/commit/5866bc3a0f54115d5982fdc09bdbe4c45069265a
Diffstat (limited to 'src/nvim/eval.lua')
-rw-r--r-- | src/nvim/eval.lua | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/src/nvim/eval.lua b/src/nvim/eval.lua index 96dc32259f..810cd2286b 100644 --- a/src/nvim/eval.lua +++ b/src/nvim/eval.lua @@ -12688,9 +12688,7 @@ M.funcs = { [1, 1], unless there is a tabline, then it is [2, 1]. {nr} can be the window number or the |window-ID|. Use zero for the current window. - Returns [0, 0] if the window cannot be found in the current - tabpage. - + Returns [0, 0] if the window cannot be found. ]=], name = 'win_screenpos', params = { { 'nr', 'integer' } }, |