patch 8.2.1638: leaking memory when popup filter function can't be called

Problem:    Leaking memory when popup filter function can't be called.
Solution:   Don't return too soon.
This commit is contained in:
Bram Moolenaar
2020-09-08 22:55:26 +02:00
parent c3516f7e45
commit 8e9be208ea
2 changed files with 25 additions and 21 deletions

View File

@ -3155,31 +3155,33 @@ invoke_popup_filter(win_T *wp, int c)
if (call_callback(&wp->w_filter_cb, -1, &rettv, 2, argv) == FAIL) if (call_callback(&wp->w_filter_cb, -1, &rettv, 2, argv) == FAIL)
{ {
// Cannot call the function, close the popup to avoid that the filter // Cannot call the function, close the popup to avoid that the filter
// eats keys and the user can't get out. // eats keys and the user is stuck. Might as well eat the key.
popup_close_with_retval(wp, -1); popup_close_with_retval(wp, -1);
return 1; res = TRUE;
}
if (win_valid_popup(wp) && old_lnum != wp->w_cursor.lnum)
popup_highlight_curline(wp);
// If an error was given always return FALSE, so that keys are not
// consumed and the user can type something.
// If we get three errors in a row then close the popup. Decrement the
// error count by 1/10 if there are no errors, thus allowing up to 1 in
// 10 calls to cause an error.
if (win_valid_popup(wp) && called_emsg > prev_called_emsg)
{
wp->w_filter_errors += 10;
if (wp->w_filter_errors >= 30)
popup_close_with_retval(wp, -1);
res = FALSE;
} }
else else
{ {
if (win_valid_popup(wp) && wp->w_filter_errors > 0) if (win_valid_popup(wp) && old_lnum != wp->w_cursor.lnum)
--wp->w_filter_errors; popup_highlight_curline(wp);
res = tv_get_bool(&rettv);
// If an error was given always return FALSE, so that keys are not
// consumed and the user can type something.
// If we get three errors in a row then close the popup. Decrement the
// error count by 1/10 if there are no errors, thus allowing up to 1 in
// 10 calls to cause an error.
if (win_valid_popup(wp) && called_emsg > prev_called_emsg)
{
wp->w_filter_errors += 10;
if (wp->w_filter_errors >= 30)
popup_close_with_retval(wp, -1);
res = FALSE;
}
else
{
if (win_valid_popup(wp) && wp->w_filter_errors > 0)
--wp->w_filter_errors;
res = tv_get_bool(&rettv);
}
} }
vim_free(argv[1].vval.v_string); vim_free(argv[1].vval.v_string);

View File

@ -754,6 +754,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 */
/**/
1638,
/**/ /**/
1637, 1637,
/**/ /**/