v9.CheckScriptSuccess(lines)
enddef
+def Test_using_vnone_default()
+ var lines =<< trim END
+ vim9script
+
+ def F(a: string = v:none)
+ if a isnot v:none
+ var b = a
+ endif
+ enddef
+ F()
+ END
+ v9.CheckScriptSuccess(lines)
+
+ # TODO: this should give an error for using a missing argument
+ # lines =<< trim END
+ # vim9script
+
+ # def F(a: string = v:none)
+ # var b = a
+ # enddef
+ # F()
+ # END
+ # v9.CheckScriptFailure(lines, 'E99:')
+enddef
+
def Test_convert_number_to_float()
var lines =<< trim END
vim9script
case ISN_LOAD:
if (GA_GROW_FAILS(&ectx->ec_stack, 1))
goto theend;
- copy_tv(STACK_TV_VAR(iptr->isn_arg.number), STACK_TV_BOT(0));
+ tv = STACK_TV_VAR(iptr->isn_arg.number);
+ if (tv->v_type == VAR_UNKNOWN)
+ {
+ // missing argument or default value v:none
+ STACK_TV_BOT(0)->v_type = VAR_SPECIAL;
+ STACK_TV_BOT(0)->vval.v_number = VVAL_NONE;
+ }
+ else
+ copy_tv(tv, STACK_TV_BOT(0));
++ectx->ec_stack.ga_len;
break;
*/
static isntype_T
get_compare_isn(
- exprtype_T exprtype,
+ exprtype_T exprtype,
typval_T *tv1,
typval_T *tv2,
type_T *type1,
return ISN_DROP;
}
if (isntype == ISN_DROP
- || ((exprtype != EXPR_EQUAL && exprtype != EXPR_NEQUAL
- && (vartype1 == VAR_BOOL || vartype1 == VAR_SPECIAL
- || vartype2 == VAR_BOOL || vartype2 == VAR_SPECIAL)))
- || ((exprtype != EXPR_EQUAL && exprtype != EXPR_NEQUAL
- && exprtype != EXPR_IS && exprtype != EXPR_ISNOT
- && (vartype1 == VAR_BLOB || vartype2 == VAR_BLOB
- || vartype1 == VAR_LIST || vartype2 == VAR_LIST))))
+ || (isntype != ISN_COMPARENULL
+ && (((exprtype != EXPR_EQUAL
+ && exprtype != EXPR_NEQUAL
+ && (vartype1 == VAR_BOOL || vartype1 == VAR_SPECIAL
+ || vartype2 == VAR_BOOL || vartype2 == VAR_SPECIAL)))
+ || ((exprtype != EXPR_EQUAL
+ && exprtype != EXPR_NEQUAL
+ && exprtype != EXPR_IS
+ && exprtype != EXPR_ISNOT
+ && (vartype1 == VAR_BLOB || vartype2 == VAR_BLOB
+ || vartype1 == VAR_LIST || vartype2 == VAR_LIST))))))
{
semsg(_(e_cannot_compare_str_with_str),
vartype_name(vartype1), vartype_name(vartype2));