mirror of
https://github.com/vim/vim.git
synced 2025-09-26 04:04:07 -04:00
patch 8.2.0207: crash when missing member type on list argument
Problem: Crash when missing member type on list argument. Solution: Check for invalid type. (closes #5572)
This commit is contained in:
@@ -160,13 +160,16 @@ def Test_call_default_args()
|
|||||||
enddef
|
enddef
|
||||||
|
|
||||||
def Test_return_type_wrong()
|
def Test_return_type_wrong()
|
||||||
" TODO: why is ! needed for Mac and FreeBSD?
|
|
||||||
CheckScriptFailure(['def Func(): number', 'return "a"', 'enddef'], 'expected number but got string')
|
CheckScriptFailure(['def Func(): number', 'return "a"', 'enddef'], 'expected number but got string')
|
||||||
CheckScriptFailure(['def Func(): string', 'return 1', 'enddef'], 'expected string but got number')
|
CheckScriptFailure(['def Func(): string', 'return 1', 'enddef'], 'expected string but got number')
|
||||||
CheckScriptFailure(['def Func(): void', 'return "a"', 'enddef'], 'expected void but got string')
|
CheckScriptFailure(['def Func(): void', 'return "a"', 'enddef'], 'expected void but got string')
|
||||||
CheckScriptFailure(['def Func()', 'return "a"', 'enddef'], 'expected void but got string')
|
CheckScriptFailure(['def Func()', 'return "a"', 'enddef'], 'expected void but got string')
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
|
def Test_arg_type_wrong()
|
||||||
|
CheckScriptFailure(['def Func3(items: list)', 'echo "a"', 'enddef'], 'E1008: Missing <type>')
|
||||||
|
enddef
|
||||||
|
|
||||||
def Test_try_catch()
|
def Test_try_catch()
|
||||||
let l = []
|
let l = []
|
||||||
try
|
try
|
||||||
|
@@ -2968,6 +2968,11 @@ ex_function(exarg_T *eap)
|
|||||||
|
|
||||||
if (eap->cmdidx == CMD_def)
|
if (eap->cmdidx == CMD_def)
|
||||||
{
|
{
|
||||||
|
int lnum_save = SOURCING_LNUM;
|
||||||
|
|
||||||
|
// error messages are for the first function line
|
||||||
|
SOURCING_LNUM = sourcing_lnum_top;
|
||||||
|
|
||||||
// parse the argument types
|
// parse the argument types
|
||||||
ga_init2(&fp->uf_type_list, sizeof(type_T), 5);
|
ga_init2(&fp->uf_type_list, sizeof(type_T), 5);
|
||||||
|
|
||||||
@@ -2980,16 +2985,23 @@ ex_function(exarg_T *eap)
|
|||||||
fp->uf_arg_types = ALLOC_CLEAR_MULT(type_T *, len);
|
fp->uf_arg_types = ALLOC_CLEAR_MULT(type_T *, len);
|
||||||
if (fp->uf_arg_types != NULL)
|
if (fp->uf_arg_types != NULL)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
type_T *type;
|
||||||
|
|
||||||
for (i = 0; i < len; ++ i)
|
for (i = 0; i < len; ++ i)
|
||||||
{
|
{
|
||||||
p = ((char_u **)argtypes.ga_data)[i];
|
p = ((char_u **)argtypes.ga_data)[i];
|
||||||
if (p == NULL)
|
if (p == NULL)
|
||||||
// todo: get type from default value
|
// todo: get type from default value
|
||||||
fp->uf_arg_types[i] = &t_any;
|
type = &t_any;
|
||||||
else
|
else
|
||||||
fp->uf_arg_types[i] = parse_type(&p, &fp->uf_type_list);
|
type = parse_type(&p, &fp->uf_type_list);
|
||||||
|
if (type == NULL)
|
||||||
|
{
|
||||||
|
SOURCING_LNUM = lnum_save;
|
||||||
|
goto errret_2;
|
||||||
|
}
|
||||||
|
fp->uf_arg_types[i] = type;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (varargs)
|
if (varargs)
|
||||||
@@ -3005,6 +3017,11 @@ ex_function(exarg_T *eap)
|
|||||||
fp->uf_va_type = &t_any;
|
fp->uf_va_type = &t_any;
|
||||||
else
|
else
|
||||||
fp->uf_va_type = parse_type(&p, &fp->uf_type_list);
|
fp->uf_va_type = parse_type(&p, &fp->uf_type_list);
|
||||||
|
if (fp->uf_va_type == NULL)
|
||||||
|
{
|
||||||
|
SOURCING_LNUM = lnum_save;
|
||||||
|
goto errret_2;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
varargs = FALSE;
|
varargs = FALSE;
|
||||||
}
|
}
|
||||||
|
@@ -742,6 +742,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 */
|
||||||
|
/**/
|
||||||
|
207,
|
||||||
/**/
|
/**/
|
||||||
206,
|
206,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user