diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim index a2c4e7daed..8ac05d421a 100644 --- a/src/testdir/test_vim9_func.vim +++ b/src/testdir/test_vim9_func.vim @@ -960,6 +960,12 @@ def Test_call_lambda_args() echo ((a) => a)('aa', 'bb') END CheckDefAndScriptFailure(lines, 'E118:', 1) + + lines =<< trim END + echo 'aa'->((a) => a)('bb') + END + CheckDefFailure(lines, 'E118: Too many arguments for function: ->((a) => a)(''bb'')', 1) + CheckScriptFailure(['vim9script'] + lines, 'E118: Too many arguments for function: ', 2) enddef def FilterWithCond(x: string, Cond: func(string): bool): bool diff --git a/src/version.c b/src/version.c index 61cd6f7b2f..bc26f903df 100644 --- 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 */ +/**/ + 3195, /**/ 3194, /**/ diff --git a/src/vim9compile.c b/src/vim9compile.c index 7014875482..5a39906efb 100644 --- a/src/vim9compile.c +++ b/src/vim9compile.c @@ -4354,8 +4354,7 @@ compile_subscript( } type = ((type_T **)stack->ga_data)[stack->ga_len - 1]; - if (generate_PCALL(cctx, argcount, - (char_u *)"[expression]", type, FALSE) == FAIL) + if (generate_PCALL(cctx, argcount, p - 2, type, FALSE) == FAIL) return FAIL; } else