mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 8.2.1326: Vim9: skipping over white space after list
Problem: Vim9: skipping over white space after list. Solution: Do not skip white space, a following [] would be misinterpreted. (closes #6552) Fix a few side effects.
This commit is contained in:
@@ -838,6 +838,10 @@ eval_dict(char_u **arg, typval_T *rettv, evalarg_T *evalarg, int literal)
|
|||||||
: eval1(arg, &tvkey, evalarg)) == FAIL) // recursive!
|
: eval1(arg, &tvkey, evalarg)) == FAIL) // recursive!
|
||||||
goto failret;
|
goto failret;
|
||||||
|
|
||||||
|
// The colon should come right after the key, but this wasn't checked
|
||||||
|
// previously, so only require it in Vim9 script.
|
||||||
|
if (!vim9script)
|
||||||
|
*arg = skipwhite(*arg);
|
||||||
if (**arg != ':')
|
if (**arg != ':')
|
||||||
{
|
{
|
||||||
if (evaluate)
|
if (evaluate)
|
||||||
|
41
src/eval.c
41
src/eval.c
@@ -1913,27 +1913,28 @@ eval_func(
|
|||||||
char_u *
|
char_u *
|
||||||
eval_next_non_blank(char_u *arg, evalarg_T *evalarg, int *getnext)
|
eval_next_non_blank(char_u *arg, evalarg_T *evalarg, int *getnext)
|
||||||
{
|
{
|
||||||
|
char_u *p = skipwhite(arg);
|
||||||
|
|
||||||
*getnext = FALSE;
|
*getnext = FALSE;
|
||||||
if (in_vim9script()
|
if (in_vim9script()
|
||||||
&& evalarg != NULL
|
&& evalarg != NULL
|
||||||
&& (evalarg->eval_cookie != NULL || evalarg->eval_cctx != NULL)
|
&& (evalarg->eval_cookie != NULL || evalarg->eval_cctx != NULL)
|
||||||
&& (*arg == NUL || (VIM_ISWHITE(arg[-1])
|
&& (*p == NUL || (VIM_ISWHITE(p[-1]) && vim9_comment_start(p))))
|
||||||
&& vim9_comment_start(arg))))
|
|
||||||
{
|
{
|
||||||
char_u *p;
|
char_u *next;
|
||||||
|
|
||||||
if (evalarg->eval_cookie != NULL)
|
if (evalarg->eval_cookie != NULL)
|
||||||
p = getline_peek(evalarg->eval_getline, evalarg->eval_cookie);
|
next = getline_peek(evalarg->eval_getline, evalarg->eval_cookie);
|
||||||
else
|
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;
|
*getnext = TRUE;
|
||||||
return skipwhite(p);
|
return skipwhite(next);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return arg;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -2039,6 +2040,7 @@ eval0(
|
|||||||
|
|
||||||
p = skipwhite(arg);
|
p = skipwhite(arg);
|
||||||
ret = eval1(&p, rettv, evalarg);
|
ret = eval1(&p, rettv, evalarg);
|
||||||
|
p = skipwhite(p);
|
||||||
|
|
||||||
if (ret == FAIL || !ends_excmd2(arg, p))
|
if (ret == FAIL || !ends_excmd2(arg, p))
|
||||||
{
|
{
|
||||||
@@ -2107,6 +2109,8 @@ eval1(char_u **arg, typval_T *rettv, evalarg_T *evalarg)
|
|||||||
|
|
||||||
if (getnext)
|
if (getnext)
|
||||||
*arg = eval_next_line(evalarg_used);
|
*arg = eval_next_line(evalarg_used);
|
||||||
|
else
|
||||||
|
*arg = p;
|
||||||
|
|
||||||
result = FALSE;
|
result = FALSE;
|
||||||
if (evaluate)
|
if (evaluate)
|
||||||
@@ -2142,6 +2146,8 @@ eval1(char_u **arg, typval_T *rettv, evalarg_T *evalarg)
|
|||||||
}
|
}
|
||||||
if (getnext)
|
if (getnext)
|
||||||
*arg = eval_next_line(evalarg_used);
|
*arg = eval_next_line(evalarg_used);
|
||||||
|
else
|
||||||
|
*arg = p;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Get the third variable. Recursive!
|
* Get the third variable. Recursive!
|
||||||
@@ -2234,6 +2240,8 @@ eval2(char_u **arg, typval_T *rettv, evalarg_T *evalarg)
|
|||||||
{
|
{
|
||||||
if (getnext)
|
if (getnext)
|
||||||
*arg = eval_next_line(evalarg_used);
|
*arg = eval_next_line(evalarg_used);
|
||||||
|
else
|
||||||
|
*arg = p;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Get the second variable.
|
* Get the second variable.
|
||||||
@@ -2349,6 +2357,8 @@ eval3(char_u **arg, typval_T *rettv, evalarg_T *evalarg)
|
|||||||
{
|
{
|
||||||
if (getnext)
|
if (getnext)
|
||||||
*arg = eval_next_line(evalarg_used);
|
*arg = eval_next_line(evalarg_used);
|
||||||
|
else
|
||||||
|
*arg = p;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Get the second variable.
|
* Get the second variable.
|
||||||
@@ -2575,6 +2585,8 @@ eval5(char_u **arg, typval_T *rettv, evalarg_T *evalarg)
|
|||||||
|
|
||||||
if (getnext)
|
if (getnext)
|
||||||
*arg = eval_next_line(evalarg);
|
*arg = eval_next_line(evalarg);
|
||||||
|
else
|
||||||
|
*arg = p;
|
||||||
evaluate = evalarg == NULL ? 0 : (evalarg->eval_flags & EVAL_EVALUATE);
|
evaluate = evalarg == NULL ? 0 : (evalarg->eval_flags & EVAL_EVALUATE);
|
||||||
if ((op != '+' || (rettv->v_type != VAR_LIST
|
if ((op != '+' || (rettv->v_type != VAR_LIST
|
||||||
&& rettv->v_type != VAR_BLOB))
|
&& rettv->v_type != VAR_BLOB))
|
||||||
@@ -2756,6 +2768,7 @@ eval6(
|
|||||||
int evaluate;
|
int evaluate;
|
||||||
int getnext;
|
int getnext;
|
||||||
typval_T var2;
|
typval_T var2;
|
||||||
|
char_u *p;
|
||||||
int op;
|
int op;
|
||||||
varnumber_T n1, n2;
|
varnumber_T n1, n2;
|
||||||
#ifdef FEAT_FLOAT
|
#ifdef FEAT_FLOAT
|
||||||
@@ -2763,12 +2776,15 @@ eval6(
|
|||||||
#endif
|
#endif
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
op = *eval_next_non_blank(*arg, evalarg, &getnext);
|
p = eval_next_non_blank(*arg, evalarg, &getnext);
|
||||||
|
op = *p;
|
||||||
if (op != '*' && op != '/' && op != '%')
|
if (op != '*' && op != '/' && op != '%')
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (getnext)
|
if (getnext)
|
||||||
*arg = eval_next_line(evalarg);
|
*arg = eval_next_line(evalarg);
|
||||||
|
else
|
||||||
|
*arg = p;
|
||||||
|
|
||||||
#ifdef FEAT_FLOAT
|
#ifdef FEAT_FLOAT
|
||||||
f1 = 0;
|
f1 = 0;
|
||||||
@@ -3115,8 +3131,6 @@ eval7(
|
|||||||
vim_free(alias);
|
vim_free(alias);
|
||||||
}
|
}
|
||||||
|
|
||||||
*arg = skipwhite(*arg);
|
|
||||||
|
|
||||||
// Handle following '[', '(' and '.' for expr[expr], expr.name,
|
// Handle following '[', '(' and '.' for expr[expr], expr.name,
|
||||||
// expr(expr), expr->name(expr)
|
// expr(expr), expr->name(expr)
|
||||||
if (ret == OK)
|
if (ret == OK)
|
||||||
@@ -5152,7 +5166,7 @@ handle_subscript(
|
|||||||
p = eval_next_non_blank(*arg, evalarg, &getnext);
|
p = eval_next_non_blank(*arg, evalarg, &getnext);
|
||||||
if (getnext
|
if (getnext
|
||||||
&& ((rettv->v_type == VAR_DICT && *p == '.' && eval_isdictc(p[1]))
|
&& ((rettv->v_type == VAR_DICT && *p == '.' && eval_isdictc(p[1]))
|
||||||
|| (*p == '-' && p[1] == '>'
|
|| (p[0] == '-' && p[1] == '>'
|
||||||
&& (p[2] == '{' || ASCII_ISALPHA(p[2])))))
|
&& (p[2] == '{' || ASCII_ISALPHA(p[2])))))
|
||||||
{
|
{
|
||||||
*arg = eval_next_line(evalarg);
|
*arg = eval_next_line(evalarg);
|
||||||
@@ -5178,8 +5192,9 @@ handle_subscript(
|
|||||||
dict_unref(selfdict);
|
dict_unref(selfdict);
|
||||||
selfdict = NULL;
|
selfdict = NULL;
|
||||||
}
|
}
|
||||||
else if (**arg == '-' && (*arg)[1] == '>')
|
else if (p[0] == '-' && p[1] == '>')
|
||||||
{
|
{
|
||||||
|
*arg = p;
|
||||||
if (ret == OK)
|
if (ret == OK)
|
||||||
{
|
{
|
||||||
if ((*arg)[2] == '{')
|
if ((*arg)[2] == '{')
|
||||||
|
@@ -1199,7 +1199,7 @@ eval_list(char_u **arg, typval_T *rettv, evalarg_T *evalarg, int do_error)
|
|||||||
had_comma = **arg == ',';
|
had_comma = **arg == ',';
|
||||||
if (had_comma)
|
if (had_comma)
|
||||||
{
|
{
|
||||||
if (vim9script && (*arg)[1] != NUL && !VIM_ISWHITE((*arg)[1]))
|
if (vim9script && !IS_WHITE_OR_NUL((*arg)[1]))
|
||||||
{
|
{
|
||||||
semsg(_(e_white_after), ",");
|
semsg(_(e_white_after), ",");
|
||||||
goto failret;
|
goto failret;
|
||||||
@@ -1231,7 +1231,7 @@ failret:
|
|||||||
return FAIL;
|
return FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
*arg = skipwhite(*arg + 1);
|
*arg += 1;
|
||||||
if (evaluate)
|
if (evaluate)
|
||||||
rettv_list_set(rettv, l);
|
rettv_list_set(rettv, l);
|
||||||
|
|
||||||
|
@@ -642,6 +642,10 @@ get_func_tv(
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
++argcount;
|
++argcount;
|
||||||
|
// The comma should come right after the argument, but this wasn't
|
||||||
|
// checked previously, thus only enforce it in Vim9 script.
|
||||||
|
if (!in_vim9script())
|
||||||
|
argp = skipwhite(argp);
|
||||||
if (*argp != ',')
|
if (*argp != ',')
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@@ -754,6 +754,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1326,
|
||||||
/**/
|
/**/
|
||||||
1325,
|
1325,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user