mirror of
https://github.com/neovim/neovim.git
synced 2024-12-20 11:15:14 -07:00
vim-patch:9.0.1030: using freed memory with the cmdline popup menu
Problem: Using freed memory with the cmdline popup menu. Solution: Clear the popup menu when clearing the matches. (closes vim/vim#11677)038e6d20e6
Co-authored-by: Bram Moolenaar <Bram@vim.org> (cherry picked from commit4d22424d9e
)
This commit is contained in:
parent
0bc56cebe7
commit
21ea794690
@ -484,6 +484,11 @@ char *ExpandOne(expand_T *xp, char *str, char *orig, int options, int mode)
|
||||
FreeWild(xp->xp_numfiles, xp->xp_files);
|
||||
xp->xp_numfiles = -1;
|
||||
XFREE_CLEAR(orig_save);
|
||||
|
||||
// The entries from xp_files may be used in the PUM, remove it.
|
||||
if (compl_match_array != NULL) {
|
||||
cmdline_pum_remove();
|
||||
}
|
||||
}
|
||||
findex = 0;
|
||||
|
||||
|
@ -2206,6 +2206,21 @@ func Test_wildmenu_pum()
|
||||
call delete('Xdir', 'rf')
|
||||
endfunc
|
||||
|
||||
func Test_wildmenu_pum_clear_entries()
|
||||
" This was using freed memory. Run in a terminal to get the pum to update.
|
||||
let lines =<< trim END
|
||||
set wildoptions=pum
|
||||
set wildchar=<C-E>
|
||||
END
|
||||
call writefile(lines, 'XwildmenuTest', 'D')
|
||||
let buf = RunVimInTerminal('-S XwildmenuTest', #{rows: 10})
|
||||
|
||||
call term_sendkeys(buf, ":\<C-E>\<C-E>")
|
||||
call VerifyScreenDump(buf, 'Test_wildmenu_pum_clear_entries_1', {})
|
||||
|
||||
set wildoptions& wildchar&
|
||||
endfunc
|
||||
|
||||
" this was going over the end of IObuff
|
||||
func Test_report_error_with_composing()
|
||||
let caught = 'no'
|
||||
|
@ -2417,6 +2417,29 @@ describe('builtin popupmenu', function()
|
||||
]]}
|
||||
end)
|
||||
|
||||
-- oldtest: Test_wildmenu_pum_clear_entries()
|
||||
it('wildoptions=pum when using Ctrl-E as wildchar vim-patch:9.0.1030', function()
|
||||
screen:try_resize(30, 10)
|
||||
exec([[
|
||||
set wildoptions=pum
|
||||
set wildchar=<C-E>
|
||||
]])
|
||||
feed(':sign <C-E><C-E>')
|
||||
screen:expect([[
|
||||
|
|
||||
{1:~ }|
|
||||
{1:~ }|
|
||||
{1:~ }{s: define }{1: }|
|
||||
{1:~ }{n: jump }{1: }|
|
||||
{1:~ }{n: list }{1: }|
|
||||
{1:~ }{n: place }{1: }|
|
||||
{1:~ }{n: undefine }{1: }|
|
||||
{1:~ }{n: unplace }{1: }|
|
||||
:sign define^ |
|
||||
]])
|
||||
assert_alive()
|
||||
end)
|
||||
|
||||
it("'pumblend' RGB-color", function()
|
||||
screen:try_resize(60,14)
|
||||
screen:set_default_attr_ids({
|
||||
|
Loading…
Reference in New Issue
Block a user