mirror of
https://github.com/vim/vim.git
synced 2025-07-25 10:54:51 -04:00
patch 9.0.0020: with some completion reading past end of string
Problem: With some completion reading past end of string. Solution: Check the length of the string.
This commit is contained in:
parent
eb273cd7b0
commit
f12129f171
@ -2209,11 +2209,21 @@ ins_compl_stop(int c, int prev_mode, int retval)
|
|||||||
// but only do this, if the Popup is still visible
|
// but only do this, if the Popup is still visible
|
||||||
if (c == Ctrl_E)
|
if (c == Ctrl_E)
|
||||||
{
|
{
|
||||||
|
char_u *p = NULL;
|
||||||
|
|
||||||
ins_compl_delete();
|
ins_compl_delete();
|
||||||
if (compl_leader != NULL)
|
if (compl_leader != NULL)
|
||||||
ins_bytes(compl_leader + get_compl_len());
|
p = compl_leader;
|
||||||
else if (compl_first_match != NULL)
|
else if (compl_first_match != NULL)
|
||||||
ins_bytes(compl_orig_text + get_compl_len());
|
p = compl_orig_text;
|
||||||
|
if (p != NULL)
|
||||||
|
{
|
||||||
|
int compl_len = get_compl_len();
|
||||||
|
int len = (int)STRLEN(p);
|
||||||
|
|
||||||
|
if (len > compl_len)
|
||||||
|
ins_bytes_len(p + compl_len, len - compl_len);
|
||||||
|
}
|
||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2184,4 +2184,12 @@ func Test_complete_smartindent()
|
|||||||
delfunction! FooBarComplete
|
delfunction! FooBarComplete
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_complete_overrun()
|
||||||
|
" this was going past the end of the copied text
|
||||||
|
new
|
||||||
|
sil norm si0s0
|
||||||
|
bwipe!
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -735,6 +735,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 */
|
||||||
|
/**/
|
||||||
|
20,
|
||||||
/**/
|
/**/
|
||||||
19,
|
19,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user