# HG changeset patch # User Bram Moolenaar # Date 1599598804 -7200 # Node ID 6666ace75ef5ac22225ebd4d7578e0fb2d743a3b # Parent ac6d1eecb47d5b29a6a839534c7e11f689065d7b patch 8.2.1638: leaking memory when popup filter function can't be called Commit: https://github.com/vim/vim/commit/8e9be208ea58149c4e522166a6194da18a2eced7 Author: Bram Moolenaar Date: Tue Sep 8 22:55:26 2020 +0200 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. diff --git a/src/popupwin.c b/src/popupwin.c --- a/src/popupwin.c +++ b/src/popupwin.c @@ -3155,31 +3155,33 @@ invoke_popup_filter(win_T *wp, int c) if (call_callback(&wp->w_filter_cb, -1, &rettv, 2, argv) == FAIL) { // 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); - return 1; - } - - 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; + res = TRUE; } else { - if (win_valid_popup(wp) && wp->w_filter_errors > 0) - --wp->w_filter_errors; - res = tv_get_bool(&rettv); + 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 + { + 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); diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -755,6 +755,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1638, +/**/ 1637, /**/ 1636,