mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.2.2250: Vim9: sublist is ambiguous
Problem: Vim9: sublist is ambiguous. Solution: Require white space around the colon. (closes #7409)
This commit is contained in:
parent
2a5c61a019
commit
de4f95b041
17
src/eval.c
17
src/eval.c
@ -3725,6 +3725,7 @@ eval_index(
|
|||||||
int range = FALSE;
|
int range = FALSE;
|
||||||
char_u *key = NULL;
|
char_u *key = NULL;
|
||||||
int keylen = -1;
|
int keylen = -1;
|
||||||
|
int vim9 = in_vim9script();
|
||||||
|
|
||||||
if (check_can_index(rettv, evaluate, verbose) == FAIL)
|
if (check_can_index(rettv, evaluate, verbose) == FAIL)
|
||||||
return FAIL;
|
return FAIL;
|
||||||
@ -3755,6 +3756,12 @@ eval_index(
|
|||||||
empty1 = TRUE;
|
empty1 = TRUE;
|
||||||
else if (eval1(arg, &var1, evalarg) == FAIL) // recursive!
|
else if (eval1(arg, &var1, evalarg) == FAIL) // recursive!
|
||||||
return FAIL;
|
return FAIL;
|
||||||
|
else if (vim9 && **arg == ':')
|
||||||
|
{
|
||||||
|
semsg(_(e_white_space_required_before_and_after_str), ":");
|
||||||
|
clear_tv(&var1);
|
||||||
|
return FAIL;
|
||||||
|
}
|
||||||
else if (evaluate && tv_get_string_chk(&var1) == NULL)
|
else if (evaluate && tv_get_string_chk(&var1) == NULL)
|
||||||
{
|
{
|
||||||
// not a number or string
|
// not a number or string
|
||||||
@ -3769,7 +3776,15 @@ eval_index(
|
|||||||
if (**arg == ':')
|
if (**arg == ':')
|
||||||
{
|
{
|
||||||
range = TRUE;
|
range = TRUE;
|
||||||
*arg = skipwhite_and_linebreak(*arg + 1, evalarg);
|
++*arg;
|
||||||
|
if (!IS_WHITE_OR_NUL(**arg) && **arg != ']')
|
||||||
|
{
|
||||||
|
semsg(_(e_white_space_required_before_and_after_str), ":");
|
||||||
|
if (!empty1)
|
||||||
|
clear_tv(&var1);
|
||||||
|
return FAIL;
|
||||||
|
}
|
||||||
|
*arg = skipwhite_and_linebreak(*arg, evalarg);
|
||||||
if (**arg == ']')
|
if (**arg == ']')
|
||||||
empty2 = TRUE;
|
empty2 = TRUE;
|
||||||
else if (eval1(arg, &var2, evalarg) == FAIL) // recursive!
|
else if (eval1(arg, &var2, evalarg) == FAIL) // recursive!
|
||||||
|
@ -1718,6 +1718,15 @@ def Test_expr7_list()
|
|||||||
Main()
|
Main()
|
||||||
END
|
END
|
||||||
CheckScriptFailure(lines, 'E1127:')
|
CheckScriptFailure(lines, 'E1127:')
|
||||||
|
|
||||||
|
lines =<< trim END
|
||||||
|
var numbers = [1, 2, 3, 4]
|
||||||
|
var a = 1
|
||||||
|
var b = 2
|
||||||
|
END
|
||||||
|
CheckDefAndScriptFailure(lines + ['echo numbers[1:b]'], 'E1004:', 4)
|
||||||
|
CheckDefAndScriptFailure(lines + ['echo numbers[1: b]'], 'E1004:', 4)
|
||||||
|
CheckDefAndScriptFailure(lines + ['echo numbers[a :b]'], 'E1004:', 4)
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
def Test_expr7_list_vim9script()
|
def Test_expr7_list_vim9script()
|
||||||
|
@ -750,6 +750,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 */
|
||||||
|
/**/
|
||||||
|
2250,
|
||||||
/**/
|
/**/
|
||||||
2249,
|
2249,
|
||||||
/**/
|
/**/
|
||||||
|
@ -3695,19 +3695,33 @@ compile_subscript(
|
|||||||
if (may_get_next_line_error(p, arg, cctx) == FAIL)
|
if (may_get_next_line_error(p, arg, cctx) == FAIL)
|
||||||
return FAIL;
|
return FAIL;
|
||||||
if (**arg == ':')
|
if (**arg == ':')
|
||||||
|
{
|
||||||
// missing first index is equal to zero
|
// missing first index is equal to zero
|
||||||
generate_PUSHNR(cctx, 0);
|
generate_PUSHNR(cctx, 0);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (compile_expr0(arg, cctx) == FAIL)
|
if (compile_expr0(arg, cctx) == FAIL)
|
||||||
return FAIL;
|
return FAIL;
|
||||||
|
if (**arg == ':')
|
||||||
|
{
|
||||||
|
semsg(_(e_white_space_required_before_and_after_str), ":");
|
||||||
|
return FAIL;
|
||||||
|
}
|
||||||
if (may_get_next_line_error(p, arg, cctx) == FAIL)
|
if (may_get_next_line_error(p, arg, cctx) == FAIL)
|
||||||
return FAIL;
|
return FAIL;
|
||||||
*arg = skipwhite(*arg);
|
*arg = skipwhite(*arg);
|
||||||
}
|
}
|
||||||
if (**arg == ':')
|
if (**arg == ':')
|
||||||
{
|
{
|
||||||
*arg = skipwhite(*arg + 1);
|
is_slice = TRUE;
|
||||||
|
++*arg;
|
||||||
|
if (!IS_WHITE_OR_NUL(**arg) && **arg != ']')
|
||||||
|
{
|
||||||
|
semsg(_(e_white_space_required_before_and_after_str), ":");
|
||||||
|
return FAIL;
|
||||||
|
}
|
||||||
|
*arg = skipwhite(*arg);
|
||||||
if (may_get_next_line_error(p, arg, cctx) == FAIL)
|
if (may_get_next_line_error(p, arg, cctx) == FAIL)
|
||||||
return FAIL;
|
return FAIL;
|
||||||
if (**arg == ']')
|
if (**arg == ']')
|
||||||
@ -3721,7 +3735,6 @@ compile_subscript(
|
|||||||
return FAIL;
|
return FAIL;
|
||||||
*arg = skipwhite(*arg);
|
*arg = skipwhite(*arg);
|
||||||
}
|
}
|
||||||
is_slice = TRUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (**arg != ']')
|
if (**arg != ']')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user