summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-04-11 18:24:46 +0200
committerBram Moolenaar <Bram@vim.org>2021-04-11 18:24:46 +0200
commitaf8ea0d066d31cf3cd0a39c5c49ce0342728588d (patch)
tree197127aeed14e316adffce7c854b94bc8351764a
parent09f067fca38c9f89ad088e8c096c4df3998575e2 (diff)
patch 8.2.2755: Vim9: no error for using a number in a conditionv8.2.2755
Problem: Vim9: no error for using a number in a condition. Solution: Also use ISN_COND2BOOL if the type is t_number_bool. (closes #7644)
-rw-r--r--src/testdir/test_vim9_disassemble.vim8
-rw-r--r--src/testdir/test_vim9_expr.vim17
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c2
4 files changed, 24 insertions, 5 deletions
diff --git a/src/testdir/test_vim9_disassemble.vim b/src/testdir/test_vim9_disassemble.vim
index e24e72f06b..363aaea356 100644
--- a/src/testdir/test_vim9_disassemble.vim
+++ b/src/testdir/test_vim9_disassemble.vim
@@ -770,7 +770,7 @@ def Test_disassemble_const_expr()
'if has("gui_running")\_s*' ..
'\d PUSHS "gui_running"\_s*' ..
'\d BCALL has(argc 1)\_s*' ..
- '\d 2BOOL (!!val)\_s*' ..
+ '\d COND2BOOL\_s*' ..
'\d JUMP_IF_FALSE -> \d\_s*' ..
' echo "yes"\_s*' ..
'\d PUSHS "yes"\_s*' ..
@@ -1537,13 +1537,13 @@ def Test_disassemble_return_bool()
assert_match('ReturnBool\_s*' ..
'var name: bool = 1 && 0 || 1\_s*' ..
'0 PUSHNR 1\_s*' ..
- '1 2BOOL (!!val)\_s*' ..
+ '1 COND2BOOL\_s*' ..
'2 JUMP_IF_COND_FALSE -> 5\_s*' ..
'3 PUSHNR 0\_s*' ..
- '4 2BOOL (!!val)\_s*' ..
+ '4 COND2BOOL\_s*' ..
'5 JUMP_IF_COND_TRUE -> 8\_s*' ..
'6 PUSHNR 1\_s*' ..
- '7 2BOOL (!!val)\_s*' ..
+ '7 COND2BOOL\_s*' ..
'\d STORE $0\_s*' ..
'return name\_s*' ..
'\d\+ LOAD $0\_s*' ..
diff --git a/src/testdir/test_vim9_expr.vim b/src/testdir/test_vim9_expr.vim
index 44ff105c62..0e0e34e01e 100644
--- a/src/testdir/test_vim9_expr.vim
+++ b/src/testdir/test_vim9_expr.vim
@@ -282,6 +282,20 @@ def Test_expr2()
g:vals = []
assert_equal(false, Record(0) || Record(false) || Record(0))
assert_equal([0, false, 0], g:vals)
+
+ g:vals = []
+ var x = 1
+ if x || true
+ g:vals = [1]
+ endif
+ assert_equal([1], g:vals)
+
+ g:vals = []
+ x = 3
+ if true || x
+ g:vals = [1]
+ endif
+ assert_equal([1], g:vals)
END
CheckDefAndScriptSuccess(lines)
enddef
@@ -357,6 +371,9 @@ def Test_expr2_fails()
# TODO: should fail at compile time
call CheckDefExecAndScriptFailure(["var x = 3 || 7"], 'E1023:', 1)
+ call CheckDefAndScriptFailure(["if 3"], 'E1023:', 1)
+ call CheckDefExecAndScriptFailure(['var x = 3', 'if x', 'endif'], 'E1023:', 2)
+
call CheckDefAndScriptFailure2(["var x = [] || false"], 'E1012: Type mismatch; expected bool but got list<unknown>', 'E745:', 1)
enddef
diff --git a/src/version.c b/src/version.c
index d18c0f8216..d8b39eb226 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 */
/**/
+ 2755,
+/**/
2754,
/**/
2753,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index 15d2c30e94..59d1339073 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -990,7 +990,7 @@ bool_on_stack(cctx_T *cctx)
if (type == &t_bool)
return OK;
- if (type == &t_any || type == &t_number)
+ if (type == &t_any || type == &t_number || type == &t_number_bool)
// Number 0 and 1 are OK to use as a bool. "any" could also be a bool.
// This requires a runtime type check.
return generate_COND2BOOL(cctx);