0
0
mirror of https://github.com/vim/vim.git synced 2025-07-24 10:45:12 -04:00

patch 8.1.2266: position unknown for a mouse click in a popup window

Problem:    Position unknown for a mouse click in a popup window.
Solution:   Set v:mouse_col and v:mouse_lnum. (closes #5171)
This commit is contained in:
Bram Moolenaar 2019-11-06 21:09:17 +01:00
parent 638a4a7508
commit f8b036bcae
3 changed files with 61 additions and 3 deletions

View File

@ -2862,12 +2862,31 @@ invoke_popup_filter(win_T *wp, int c)
argv[2].v_type = VAR_UNKNOWN;
if (is_mouse_key(c))
{
int row = mouse_row - wp->w_winrow;
int col = mouse_col - wp->w_wincol;
linenr_T lnum;
if (row >= 0 && col >= 0)
{
(void)mouse_comp_pos(wp, &row, &col, &lnum, NULL);
set_vim_var_nr(VV_MOUSE_LNUM, lnum);
set_vim_var_nr(VV_MOUSE_COL, col + 1);
}
}
// NOTE: The callback might close the popup and make "wp" invalid.
call_callback(&wp->w_filter_cb, -1, &rettv, 2, argv);
if (win_valid_popup(wp) && old_lnum != wp->w_cursor.lnum)
popup_highlight_curline(wp);
res = tv_get_number(&rettv);
if (is_mouse_key(c))
{
set_vim_var_nr(VV_MOUSE_LNUM, 0);
set_vim_var_nr(VV_MOUSE_COL, 0);
}
vim_free(argv[1].vval.v_string);
clear_tv(&rettv);
return res;
@ -2891,8 +2910,6 @@ popup_do_filter(int c)
return FALSE;
recursive = TRUE;
popup_reset_handled();
if (c == K_LEFTMOUSE)
{
int row = mouse_row;
@ -2903,6 +2920,7 @@ popup_do_filter(int c)
res = TRUE;
}
popup_reset_handled();
state = get_real_state();
while (!res && (wp = find_next_popup(FALSE)) != NULL)
if (wp->w_filter_cb.cb_name != NULL

View File

@ -2166,6 +2166,44 @@ func Test_popupwin_filter_mode()
delfunc MyPopupFilter
endfunc
func Test_popupwin_filter_mouse()
func MyPopupFilter(winid, c)
let g:got_mouse_col = v:mouse_col
let g:got_mouse_lnum = v:mouse_lnum
return 0
endfunc
let winid = popup_create(['short', 'long line that will wrap', 'short'], #{
\ line: 4,
\ col: 8,
\ maxwidth: 12,
\ filter: 'MyPopupFilter',
\ })
redraw
call test_setmouse(4, 8)
call feedkeys("\<LeftMouse>", 'xt')
call assert_equal(1, g:got_mouse_col)
call assert_equal(1, g:got_mouse_lnum)
call test_setmouse(5, 8)
call feedkeys("\<LeftMouse>", 'xt')
call assert_equal(1, g:got_mouse_col)
call assert_equal(2, g:got_mouse_lnum)
call test_setmouse(6, 8)
call feedkeys("\<LeftMouse>", 'xt')
call assert_equal(13, g:got_mouse_col)
call assert_equal(2, g:got_mouse_lnum)
call test_setmouse(7, 20)
call feedkeys("\<LeftMouse>", 'xt')
call assert_equal(13, g:got_mouse_col)
call assert_equal(3, g:got_mouse_lnum)
call popup_close(winid)
delfunc MyPopupFilter
endfunc
func Test_popupwin_with_buffer()
call writefile(['some text', 'in a buffer'], 'XsomeFile')
let buf = bufadd('XsomeFile')

View File

@ -741,6 +741,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
2266,
/**/
2265,
/**/