summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-01-09 16:21:37 +0100
committerBram Moolenaar <Bram@vim.org>2021-01-09 16:21:37 +0100
commitcff40ff98664f4f5a9631aff1a155caf762ea74b (patch)
tree43819da60d947bf116b65278fae16b888741208e
parent657137ca487c60d63989236115115161def270a5 (diff)
patch 8.2.2320: Vim9: no error for comparing bool with stringv8.2.2320
Problem: Vim9: no error for comparing bool with string. Solution: Check for wrong types when comparing. (closes #7639)
-rw-r--r--src/errors.h2
-rw-r--r--src/testdir/test_vim9_expr.vim12
-rw-r--r--src/typval.c24
-rw-r--r--src/version.c2
4 files changed, 40 insertions, 0 deletions
diff --git a/src/errors.h b/src/errors.h
index e71b706004..47e9876f68 100644
--- a/src/errors.h
+++ b/src/errors.h
@@ -341,3 +341,5 @@ EXTERN char e_mismatched_endfunction[]
INIT(= N_("E1151: Mismatched endfunction"));
EXTERN char e_mismatched_enddef[]
INIT(= N_("E1152: Mismatched enddef"));
+EXTERN char e_invalid_operation_for_bool[]
+ INIT(= N_("E1153: Invalid operation for bool"));
diff --git a/src/testdir/test_vim9_expr.vim b/src/testdir/test_vim9_expr.vim
index 6d82e5e27d..fc42088d81 100644
--- a/src/testdir/test_vim9_expr.vim
+++ b/src/testdir/test_vim9_expr.vim
@@ -597,6 +597,18 @@ def Test_expr4_equal()
CheckDefFailure(["var x = 'a' == "], 'E1097:', 3)
CheckDefExecFailure(['var items: any', 'eval 1', 'eval 2', 'if items == []', 'endif'], 'E691:', 4)
+
+ CheckDefExecFailure(['var x: any = "a"', 'echo x == true'], 'E1072: Cannot compare string with bool', 2)
+ CheckDefExecFailure(["var x: any = true", 'echo x == ""'], 'E1072: Cannot compare bool with string', 2)
+ CheckDefExecFailure(["var x: any = 99", 'echo x == true'], 'E1138', 2)
+ CheckDefExecFailure(["var x: any = 'a'", 'echo x == 99'], 'E1030:', 2)
+
+ for op in ['>', '>=', '<', '<=', '=~', '!~']
+ CheckDefExecFailure([
+ "var a: any = 'a'",
+ 'var b: any = true',
+ 'echo a ' .. op .. ' b'], 'E1072:', 3)
+ endfor
enddef
" test != comperator
diff --git a/src/typval.c b/src/typval.c
index e620bedd74..06276b473d 100644
--- a/src/typval.c
+++ b/src/typval.c
@@ -834,6 +834,30 @@ typval_compare(
default: break; // avoid gcc warning
}
}
+ else if (in_vim9script() && (typ1->v_type == VAR_BOOL
+ || typ2->v_type == VAR_BOOL))
+ {
+ if (typ1->v_type != typ2->v_type)
+ {
+ semsg(_(e_cannot_compare_str_with_str),
+ vartype_name(typ1->v_type), vartype_name(typ2->v_type));
+ clear_tv(typ1);
+ return FAIL;
+ }
+ n1 = typ1->vval.v_number;
+ n2 = typ2->vval.v_number;
+ switch (type)
+ {
+ case EXPR_IS:
+ case EXPR_EQUAL: n1 = (n1 == n2); break;
+ case EXPR_ISNOT:
+ case EXPR_NEQUAL: n1 = (n1 != n2); break;
+ default:
+ emsg(_(e_invalid_operation_for_bool));
+ clear_tv(typ1);
+ return FAIL;
+ }
+ }
else
{
s1 = tv_get_string_buf(typ1, buf1);
diff --git a/src/version.c b/src/version.c
index 0b174f5319..2ef443b239 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 */
/**/
+ 2320,
+/**/
2319,
/**/
2318,