char_u *
eval_next_non_blank(char_u *arg, evalarg_T *evalarg, int *getnext)
{
+ char_u *p = skipwhite(arg);
+
*getnext = FALSE;
if (in_vim9script()
&& evalarg != NULL
&& (evalarg->eval_cookie != NULL || evalarg->eval_cctx != NULL)
- && (*arg == NUL || (VIM_ISWHITE(arg[-1])
- && vim9_comment_start(arg))))
+ && (*p == NUL || (VIM_ISWHITE(p[-1]) && vim9_comment_start(p))))
{
- char_u *p;
+ char_u *next;
if (evalarg->eval_cookie != NULL)
- p = getline_peek(evalarg->eval_getline, evalarg->eval_cookie);
+ next = getline_peek(evalarg->eval_getline, evalarg->eval_cookie);
else
- p = peek_next_line_from_context(evalarg->eval_cctx);
+ next = peek_next_line_from_context(evalarg->eval_cctx);
- if (p != NULL)
+ if (next != NULL)
{
*getnext = TRUE;
- return skipwhite(p);
+ return skipwhite(next);
}
}
- return arg;
+ return p;
}
/*
p = skipwhite(arg);
ret = eval1(&p, rettv, evalarg);
+ p = skipwhite(p);
if (ret == FAIL || !ends_excmd2(arg, p))
{
if (getnext)
*arg = eval_next_line(evalarg_used);
+ else
+ *arg = p;
result = FALSE;
if (evaluate)
}
if (getnext)
*arg = eval_next_line(evalarg_used);
+ else
+ *arg = p;
/*
* Get the third variable. Recursive!
{
if (getnext)
*arg = eval_next_line(evalarg_used);
+ else
+ *arg = p;
/*
* Get the second variable.
{
if (getnext)
*arg = eval_next_line(evalarg_used);
+ else
+ *arg = p;
/*
* Get the second variable.
if (getnext)
*arg = eval_next_line(evalarg);
+ else
+ *arg = p;
evaluate = evalarg == NULL ? 0 : (evalarg->eval_flags & EVAL_EVALUATE);
if ((op != '+' || (rettv->v_type != VAR_LIST
&& rettv->v_type != VAR_BLOB))
int evaluate;
int getnext;
typval_T var2;
+ char_u *p;
int op;
varnumber_T n1, n2;
#ifdef FEAT_FLOAT
#endif
int error;
- op = *eval_next_non_blank(*arg, evalarg, &getnext);
+ p = eval_next_non_blank(*arg, evalarg, &getnext);
+ op = *p;
if (op != '*' && op != '/' && op != '%')
break;
if (getnext)
*arg = eval_next_line(evalarg);
+ else
+ *arg = p;
#ifdef FEAT_FLOAT
f1 = 0;
vim_free(alias);
}
- *arg = skipwhite(*arg);
-
// Handle following '[', '(' and '.' for expr[expr], expr.name,
// expr(expr), expr->name(expr)
if (ret == OK)
p = eval_next_non_blank(*arg, evalarg, &getnext);
if (getnext
&& ((rettv->v_type == VAR_DICT && *p == '.' && eval_isdictc(p[1]))
- || (*p == '-' && p[1] == '>'
+ || (p[0] == '-' && p[1] == '>'
&& (p[2] == '{' || ASCII_ISALPHA(p[2])))))
{
*arg = eval_next_line(evalarg);
dict_unref(selfdict);
selfdict = NULL;
}
- else if (**arg == '-' && (*arg)[1] == '>')
+ else if (p[0] == '-' && p[1] == '>')
{
+ *arg = p;
if (ret == OK)
{
if ((*arg)[2] == '{')
call assert_equal("c", matchstr("abcd", ".", 2, 0))
call assert_equal("a", matchstr("abcd", ".", 0, -1))
call assert_equal(-1, match("abcd", ".", 0, 5))
- call assert_equal(0 , match("abcd", ".", 0, -1))
- call assert_equal(0 , match('abc', '.', 0, 1))
- call assert_equal(1 , match('abc', '.', 0, 2))
- call assert_equal(2 , match('abc', '.', 0, 3))
+ call assert_equal(0, match("abcd", ".", 0, -1))
+ call assert_equal(0, match('abc', '.', 0, 1))
+ call assert_equal(1, match('abc', '.', 0, 2))
+ call assert_equal(2, match('abc', '.', 0, 3))
call assert_equal(-1, match('abc', '.', 0, 4))
- call assert_equal(1 , match('abc', '.', 1, 1))
- call assert_equal(2 , match('abc', '.', 2, 1))
+ call assert_equal(1, match('abc', '.', 1, 1))
+ call assert_equal(2, match('abc', '.', 2, 1))
call assert_equal(-1, match('abc', '.', 3, 1))
- call assert_equal(3 , match('abc', '$', 0, 1))
+ call assert_equal(3, match('abc', '$', 0, 1))
call assert_equal(-1, match('abc', '$', 0, 2))
- call assert_equal(3 , match('abc', '$', 1, 1))
- call assert_equal(3 , match('abc', '$', 2, 1))
- call assert_equal(3 , match('abc', '$', 3, 1))
+ call assert_equal(3, match('abc', '$', 1, 1))
+ call assert_equal(3, match('abc', '$', 2, 1))
+ call assert_equal(3, match('abc', '$', 3, 1))
call assert_equal(-1, match('abc', '$', 4, 1))
- call assert_equal(0 , match('abc', '\zs', 0, 1))
- call assert_equal(1 , match('abc', '\zs', 0, 2))
- call assert_equal(2 , match('abc', '\zs', 0, 3))
- call assert_equal(3 , match('abc', '\zs', 0, 4))
+ call assert_equal(0, match('abc', '\zs', 0, 1))
+ call assert_equal(1, match('abc', '\zs', 0, 2))
+ call assert_equal(2, match('abc', '\zs', 0, 3))
+ call assert_equal(3, match('abc', '\zs', 0, 4))
call assert_equal(-1, match('abc', '\zs', 0, 5))
- call assert_equal(1 , match('abc', '\zs', 1, 1))
- call assert_equal(2 , match('abc', '\zs', 2, 1))
- call assert_equal(3 , match('abc', '\zs', 3, 1))
+ call assert_equal(1, match('abc', '\zs', 1, 1))
+ call assert_equal(2, match('abc', '\zs', 2, 1))
+ call assert_equal(3, match('abc', '\zs', 3, 1))
call assert_equal(-1, match('abc', '\zs', 4, 1))
endfunc