# HG changeset patch # User Bram Moolenaar # Date 1595524503 -7200 # Node ID b5d4ab124782252c0efb12c03b1b5809555a1da9 # Parent a6873b0067e55cf2e1b41cedf6554856412f6265 patch 8.2.1283: Vim9: error for misplaced -> lacks argument Commit: https://github.com/vim/vim/commit/637cd7d1c9fa0ee47951ccdc310a388cb7ecfada Author: Bram Moolenaar Date: Thu Jul 23 19:06:23 2020 +0200 patch 8.2.1283: Vim9: error for misplaced -> lacks argument Problem: Vim9: error for misplaced -> lacks argument. Solution: Use the pointer before it was advanced. diff --git a/src/testdir/test_vim9_expr.vim b/src/testdir/test_vim9_expr.vim --- a/src/testdir/test_vim9_expr.vim +++ b/src/testdir/test_vim9_expr.vim @@ -1532,7 +1532,7 @@ func Test_expr7_fails() call CheckDefFailure(["let x = ''", "let y = x.memb"], 'E715:') - call CheckDefFailure(["'yes'->", "Echo()"], 'E488:') + call CheckDefFailure(["'yes'->", "Echo()"], 'E488: Trailing characters: ->') call CheckDefExecFailure(["[1, 2->len()"], 'E697:') call CheckDefExecFailure(["#{a: 1->len()"], 'E488:') diff --git a/src/version.c b/src/version.c --- 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 */ /**/ + 1283, +/**/ 1282, /**/ 1281, diff --git a/src/vim9compile.c b/src/vim9compile.c --- a/src/vim9compile.c +++ b/src/vim9compile.c @@ -3761,6 +3761,8 @@ compile_subscript( } else if (*p == '-' && p[1] == '>') { + char_u *pstart = p; + if (generate_ppconst(cctx, ppconst) == FAIL) return FAIL; @@ -3786,7 +3788,7 @@ compile_subscript( p = *arg; if (!eval_isnamec1(*p)) { - semsg(_(e_trailing_arg), p); + semsg(_(e_trailing_arg), pstart); return FAIL; } if (ASCII_ISALPHA(*p) && p[1] == ':')