forked from aniani/vim
patch 9.1.0034: Window scrolls unexpectedly when 'scrollbind' is set
Problem: Window may unexpectedly scroll when 'scrollbind' is set and setting a buffer-local option using setbufvar() (Boris Staletic) Solution: Save and restore the windows topline before opening the popup window. fixes: #13863 closes: #13869 Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
@@ -4924,6 +4924,10 @@ f_setbufvar(typval_T *argvars, typval_T *rettv UNUSED)
|
|||||||
if (*varname == '&')
|
if (*varname == '&')
|
||||||
{
|
{
|
||||||
aco_save_T aco;
|
aco_save_T aco;
|
||||||
|
// safe the current window position, it could
|
||||||
|
// change because of 'scrollbind' window-local
|
||||||
|
// options
|
||||||
|
linenr_T old_topline = curwin->w_topline;
|
||||||
|
|
||||||
// Set curbuf to be our buf, temporarily.
|
// Set curbuf to be our buf, temporarily.
|
||||||
aucmd_prepbuf(&aco, buf);
|
aucmd_prepbuf(&aco, buf);
|
||||||
@@ -4935,6 +4939,7 @@ f_setbufvar(typval_T *argvars, typval_T *rettv UNUSED)
|
|||||||
// reset notion of buffer
|
// reset notion of buffer
|
||||||
aucmd_restbuf(&aco);
|
aucmd_restbuf(&aco);
|
||||||
}
|
}
|
||||||
|
curwin->w_topline = old_topline;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@@ -4215,4 +4215,22 @@ func Test_popup_close_callback_recursive()
|
|||||||
set maxfuncdepth&
|
set maxfuncdepth&
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_popupwin_setbufvar_changing_window_view()
|
||||||
|
" Test for Github Issue https://github.com/vim/vim/issues/13863
|
||||||
|
" using setbufvar(buf, '&option') should not scroll
|
||||||
|
" the current window
|
||||||
|
20new
|
||||||
|
call append(0, range(1, 25))
|
||||||
|
setlocal scrollbind
|
||||||
|
norm! G
|
||||||
|
let topline = winsaveview()['topline']
|
||||||
|
call setbufvar(winbufnr(popup_atcursor(['foobar'], {})), '&syntax', 'python')
|
||||||
|
" close popup
|
||||||
|
call popup_clear()
|
||||||
|
call assert_equal(topline, winsaveview()['topline'])
|
||||||
|
|
||||||
|
" clean up
|
||||||
|
bw!
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2
|
" vim: shiftwidth=2 sts=2
|
||||||
|
@@ -704,6 +704,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
34,
|
||||||
/**/
|
/**/
|
||||||
33,
|
33,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user