0
0
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:
Bram Moolenaar
2020-07-30 20:08:50 +02:00
parent ea2d8d2571
commit 9d48956681
11 changed files with 62 additions and 37 deletions

View File

@@ -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)

View File

@@ -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] == '{')

View File

@@ -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);

View File

@@ -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;
} }

View File

@@ -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,
/**/ /**/