summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-02-07 16:33:35 +0100
committerBram Moolenaar <Bram@vim.org>2021-02-07 16:33:35 +0100
commit6628b7ebff1cfcb476ce96852a7d2b095872826c (patch)
treeb15e0dd02ba3aba21b8986f319800adaf3cf14f1
parenta5a1ec1826c0e43d0282ba4d35c155a97bab3e27 (diff)
downloadvim-git-6628b7ebff1cfcb476ce96852a7d2b095872826c.tar.gz
patch 8.2.2483: Vim9: type error for misformed expressionv8.2.2483
Problem: Vim9: type error for misformed expression. Solution: Check for end of command before checking type. (closes #7795)
-rw-r--r--src/testdir/test_vim9_script.vim22
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c15
3 files changed, 39 insertions, 0 deletions
diff --git a/src/testdir/test_vim9_script.vim b/src/testdir/test_vim9_script.vim
index d25bb47aa..72e12740a 100644
--- a/src/testdir/test_vim9_script.vim
+++ b/src/testdir/test_vim9_script.vim
@@ -1743,6 +1743,21 @@ def Test_if_elseif_else_fails()
CheckDefFailure(['endif'], 'E580:')
CheckDefFailure(['if g:abool', 'elseif xxx'], 'E1001:')
CheckDefFailure(['if true', 'echo 1'], 'E171:')
+
+ var lines =<< trim END
+ var s = ''
+ if s = ''
+ endif
+ END
+ CheckDefFailure(lines, 'E488:')
+
+ lines =<< trim END
+ var s = ''
+ if s == ''
+ elseif s = ''
+ endif
+ END
+ CheckDefFailure(lines, 'E488:')
enddef
let g:bool_true = v:true
@@ -2200,6 +2215,13 @@ def Test_while_loop_fails()
CheckDefFailure(['break'], 'E587:')
CheckDefFailure(['if true', 'break'], 'E587:')
CheckDefFailure(['while 1', 'echo 3'], 'E170:')
+
+ var lines =<< trim END
+ var s = ''
+ while s = ''
+ endwhile
+ END
+ CheckDefFailure(lines, 'E488:')
enddef
def Test_interrupt_loop()
diff --git a/src/version.c b/src/version.c
index 17ab64a91..4c5310700 100644
--- a/src/version.c
+++ b/src/version.c
@@ -751,6 +751,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 2483,
+/**/
2482,
/**/
2481,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index 3c24fdb06..7a220a851 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -6701,6 +6701,11 @@ compile_if(char_u *arg, cctx_T *cctx)
clear_ppconst(&ppconst);
return NULL;
}
+ if (!ends_excmd2(arg, skipwhite(p)))
+ {
+ semsg(_(e_trailing_arg), p);
+ return NULL;
+ }
if (cctx->ctx_skip == SKIP_YES)
clear_ppconst(&ppconst);
else if (instr->ga_len == instr_count && ppconst.pp_used == 1)
@@ -6825,6 +6830,11 @@ compile_elseif(char_u *arg, cctx_T *cctx)
return NULL;
}
cctx->ctx_skip = save_skip;
+ if (!ends_excmd2(arg, skipwhite(p)))
+ {
+ semsg(_(e_trailing_arg), p);
+ return NULL;
+ }
if (scope->se_skip_save == SKIP_YES)
clear_ppconst(&ppconst);
else if (instr->ga_len == instr_count && ppconst.pp_used == 1)
@@ -7237,6 +7247,11 @@ compile_while(char_u *arg, cctx_T *cctx)
// compile "expr"
if (compile_expr0(&p, cctx) == FAIL)
return NULL;
+ if (!ends_excmd2(arg, skipwhite(p)))
+ {
+ semsg(_(e_trailing_arg), p);
+ return NULL;
+ }
if (bool_on_stack(cctx) == FAIL)
return FAIL;