mirror of
https://github.com/vim/vim
synced 2025-07-16 09:12:00 +00:00
patch 9.0.1239: cannot have a line break before an object member access
Problem: Cannot have a line break before an object member access. Solution: Check for "." in next line. (closes #11864)
This commit is contained in:
@ -6747,7 +6747,10 @@ handle_subscript(
|
|||||||
// the next line then consume the line break.
|
// the next line then consume the line break.
|
||||||
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]))
|
&& ((*p == '.'
|
||||||
|
&& ((rettv->v_type == VAR_DICT && eval_isdictc(p[1]))
|
||||||
|
|| rettv->v_type == VAR_CLASS
|
||||||
|
|| rettv->v_type == VAR_OBJECT))
|
||||||
|| (p[0] == '-' && p[1] == '>' && (p[2] == '{'
|
|| (p[0] == '-' && p[1] == '>' && (p[2] == '{'
|
||||||
|| ASCII_ISALPHA(in_vim9script() ? *skipwhite(p + 2)
|
|| ASCII_ISALPHA(in_vim9script() ? *skipwhite(p + 2)
|
||||||
: p[2])))))
|
: p[2])))))
|
||||||
|
@ -439,6 +439,32 @@ def Test_class_object_member_access()
|
|||||||
var c = MyCar.new("def")
|
var c = MyCar.new("def")
|
||||||
END
|
END
|
||||||
v9.CheckScriptFailure(lines, 'E1041:')
|
v9.CheckScriptFailure(lines, 'E1041:')
|
||||||
|
|
||||||
|
lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
|
||||||
|
class Foo
|
||||||
|
this.x: list<number> = []
|
||||||
|
|
||||||
|
def Add(n: number): any
|
||||||
|
this.x->add(n)
|
||||||
|
return this
|
||||||
|
enddef
|
||||||
|
endclass
|
||||||
|
|
||||||
|
echo Foo.new().Add(1).Add(2).x
|
||||||
|
echo Foo.new().Add(1).Add(2)
|
||||||
|
.x
|
||||||
|
echo Foo.new().Add(1)
|
||||||
|
.Add(2).x
|
||||||
|
echo Foo.new()
|
||||||
|
.Add(1).Add(2).x
|
||||||
|
echo Foo.new()
|
||||||
|
.Add(1)
|
||||||
|
.Add(2)
|
||||||
|
.x
|
||||||
|
END
|
||||||
|
v9.CheckScriptSuccess(lines)
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
def Test_class_object_compare()
|
def Test_class_object_compare()
|
||||||
|
@ -695,6 +695,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 */
|
||||||
|
/**/
|
||||||
|
1239,
|
||||||
/**/
|
/**/
|
||||||
1238,
|
1238,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user