Problem: Vim9: comperators use 'ignorecase' in Vim9 script.
Solution: Ignore 'ignorecase'. Use true and false instead of 1 and 0.
(closes #6497)
static int
eval4(char_u **arg, typval_T *rettv, evalarg_T *evalarg)
{
- typval_T var2;
char_u *p;
int getnext;
int i;
exptype_T type = EXPR_UNKNOWN;
int len = 2;
- int ic;
/*
* Get the first variable.
*/
if (type != EXPR_UNKNOWN)
{
+ typval_T var2;
+ int ic;
+ int vim9script = in_vim9script();
+
if (getnext)
*arg = eval_next_line(evalarg);
ic = FALSE;
++len;
}
- // nothing appended: use 'ignorecase'
+ // nothing appended: use 'ignorecase' if not in Vim script
else
- ic = p_ic;
+ ic = vim9script ? FALSE : p_ic;
/*
* Get the second variable.
{
int ret;
- if (in_vim9script() && check_compare_types(
- type, rettv, &var2) == FAIL)
+ if (vim9script && check_compare_types(type, rettv, &var2) == FAIL)
{
ret = FAIL;
clear_tv(rettv);
vim9script
let var = 0
< 1
- assert_equal(1, var)
+ assert_equal(true, var)
END
CheckScriptSuccess(lines)
vim9script
let var = 123
!= 123
- assert_equal(0, var)
+ assert_equal(false, var)
END
CheckScriptSuccess(lines)
vim9script
let var = 123 ==
123
- assert_equal(1, var)
+ assert_equal(true, var)
END
CheckScriptSuccess(lines)
let list = [1, 2, 3]
let var = list
is list
- assert_equal(1, var)
+ assert_equal(true, var)
END
CheckScriptSuccess(lines)
let myblob = 0z1234
let var = myblob
isnot 0z11
- assert_equal(1, var)
+ assert_equal(true, var)
END
CheckScriptSuccess(lines)
echo 123 is 123
END
CheckScriptFailure(lines, 'Cannot use "is" with number')
+
+ # check 'ignorecase' not being used
+ lines =<< trim END
+ vim9script
+ set ignorecase
+ assert_equal(false, 'abc' == 'ABC')
+ assert_equal(false, 'abc' ==# 'ABC')
+ assert_equal(true, 'abc' ==? 'ABC')
+
+ assert_equal(true, 'abc' != 'ABC')
+ assert_equal(true, 'abc' !=# 'ABC')
+ assert_equal(false, 'abc' !=? 'ABC')
+
+ assert_equal(false, 'abc' =~ 'ABC')
+ assert_equal(false, 'abc' =~# 'ABC')
+ assert_equal(true, 'abc' =~? 'ABC')
+ set noignorecase
+ END
+ CheckScriptSuccess(lines)
enddef
func Test_expr4_fails()
}
}
clear_tv(typ1);
- typ1->v_type = VAR_NUMBER;
- typ1->vval.v_number = n1;
+ if (in_vim9script())
+ {
+ typ1->v_type = VAR_BOOL;
+ typ1->vval.v_number = n1 ? VVAL_TRUE : VVAL_FALSE;
+ }
+ else
+ {
+ typ1->v_type = VAR_NUMBER;
+ typ1->vval.v_number = n1;
+ }
return OK;
}
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 1263,
/**/
1262,
/**/
typval_compare(tv1, tv2, exptype, ic);
clear_tv(tv2);
- tv1->v_type = VAR_BOOL;
- tv1->vval.v_number = tv1->vval.v_number
- ? VVAL_TRUE : VVAL_FALSE;
--ectx.ec_stack.ga_len;
}
break;