int
eval1(char_u **arg, typval_T *rettv, evalarg_T *evalarg)
{
+ char_u *p;
+ int getnext;
+
/*
* Get the first variable.
*/
if (eval2(arg, rettv, evalarg) == FAIL)
return FAIL;
- if ((*arg)[0] == '?')
+ p = eval_next_non_blank(*arg, evalarg, &getnext);
+ if (*p == '?')
{
int result;
typval_T var2;
int orig_flags;
int evaluate;
+ if (getnext)
+ *arg = eval_next_line(evalarg);
+
if (evalarg == NULL)
{
CLEAR_FIELD(nested_evalarg);
/*
* Check for the ":".
*/
- if ((*arg)[0] != ':')
+ p = eval_next_non_blank(*arg, evalarg, &getnext);
+ if (*p != ':')
{
emsg(_(e_missing_colon));
if (evaluate && result)
clear_tv(rettv);
return FAIL;
}
+ if (getnext)
+ *arg = eval_next_line(evalarg);
/*
* Get the third variable. Recursive!
assert_equal(function('len'), RetThat)
enddef
+def Test_expr1_vimscript()
+ " only checks line continuation
+ let lines =<< trim END
+ vim9script
+ let var = 1
+ ? 'yes'
+ : 'no'
+ assert_equal('yes', var)
+ END
+ CheckScriptSuccess(lines)
+
+ lines =<< trim END
+ vim9script
+ let var = v:false
+ ? 'yes'
+ : 'no'
+ assert_equal('no', var)
+ END
+ CheckScriptSuccess(lines)
+enddef
+
func Test_expr1_fails()
call CheckDefFailure(["let x = 1 ? 'one'"], "Missing ':' after '?'")
call CheckDefFailure(["let x = 1 ? 'one' : xxx"], "E1001:")