mirror of
https://github.com/vim/vim.git
synced 2025-09-07 22:03:36 -04:00
patch 9.0.1104: invalid memory access when checking function argument types
Problem: Invalid memory access when checking function argument types. Solution: Do not check beyond the number of arguments. (closes #11755)
This commit is contained in:
parent
b9a1edfc54
commit
56310d38d8
@ -426,6 +426,16 @@ def Test_check_argument_type()
|
||||
Func()
|
||||
END
|
||||
v9.CheckScriptFailure(lines, 'E1013: Argument 2: type mismatch, expected number but got bool', 2)
|
||||
|
||||
lines =<< trim END
|
||||
vim9script
|
||||
|
||||
def Foobar(Fn: func(any, ?string): any)
|
||||
enddef
|
||||
|
||||
Foobar((t) => 0)
|
||||
END
|
||||
v9.CheckScriptSuccess(lines)
|
||||
enddef
|
||||
|
||||
def Test_missing_return()
|
||||
|
@ -695,6 +695,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1104,
|
||||
/**/
|
||||
1103,
|
||||
/**/
|
||||
|
@ -848,7 +848,7 @@ check_type_maybe(
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < expected->tt_argcount; ++i)
|
||||
for (i = 0; i < expected->tt_argcount && i < actual->tt_argcount; ++i)
|
||||
// Allow for using "any" argument type, lambda's have them.
|
||||
if (actual->tt_args[i] != &t_any && check_type(
|
||||
expected->tt_args[i], actual->tt_args[i], FALSE,
|
||||
|
Loading…
x
Reference in New Issue
Block a user