1
0
forked from aniani/vim

patch 8.2.2575: Vim9: a function name with "->" in the next line doesn't work

Problem:    Vim9: a function name with "->" in the next line doesn't work.
Solution:   Recognize a function name by itself. (closes #7770)
This commit is contained in:
Bram Moolenaar
2021-03-06 21:01:09 +01:00
parent 04947cc6ed
commit 6914e87d3c
3 changed files with 43 additions and 3 deletions

View File

@@ -355,6 +355,25 @@ def Test_method_call_linebreak()
END END
CheckDefAndScriptSuccess(lines) CheckDefAndScriptSuccess(lines)
lines =<< trim END
new
def Foo(): string
return 'the text'
enddef
def Bar(F: func): string
return F()
enddef
def Test()
Foo
->Bar()
->setline(1)
enddef
Test()
assert_equal('the text', getline(1))
bwipe!
END
CheckDefAndScriptSuccess(lines)
lines =<< trim END lines =<< trim END
new new
g:shortlist g:shortlist

View File

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

View File

@@ -386,6 +386,26 @@ variable_exists(char_u *name, size_t len, cctx_T *cctx)
|| find_imported(name, len, cctx) != NULL; || find_imported(name, len, cctx) != NULL;
} }
/*
* Return TRUE if "name" is a local variable, argument, script variable,
* imported or function.
*/
static int
item_exists(char_u *name, size_t len, cctx_T *cctx)
{
int is_global;
if (variable_exists(name, len, cctx))
return TRUE;
// Find a function, so that a following "->" works. Skip "g:" before a
// function name.
// Do not check for an internal function, since it might also be a
// valid command, such as ":split" versuse "split()".
is_global = (name[0] == 'g' && name[1] == ':');
return find_func(is_global ? name + 2 : name, is_global, cctx) != NULL;
}
/* /*
* Check if "p[len]" is already defined, either in script "import_sid" or in * Check if "p[len]" is already defined, either in script "import_sid" or in
* compilation context "cctx". "cctx" is NULL at the script level. * compilation context "cctx". "cctx" is NULL at the script level.
@@ -728,7 +748,7 @@ get_compare_isn(exprtype_T exprtype, vartype_T type1, vartype_T type2)
} }
else if (type1 == VAR_ANY || type2 == VAR_ANY else if (type1 == VAR_ANY || type2 == VAR_ANY
|| ((type1 == VAR_NUMBER || type1 == VAR_FLOAT) || ((type1 == VAR_NUMBER || type1 == VAR_FLOAT)
&& (type2 == VAR_NUMBER || type2 ==VAR_FLOAT))) && (type2 == VAR_NUMBER || type2 == VAR_FLOAT)))
isntype = ISN_COMPAREANY; isntype = ISN_COMPAREANY;
if ((exprtype == EXPR_IS || exprtype == EXPR_ISNOT) if ((exprtype == EXPR_IS || exprtype == EXPR_ISNOT)
@@ -8399,8 +8419,7 @@ compile_def_function(
} }
} }
p = find_ex_command(&ea, NULL, starts_with_colon ? NULL p = find_ex_command(&ea, NULL, starts_with_colon ? NULL
: (int (*)(char_u *, size_t, cctx_T *))variable_exists, : (int (*)(char_u *, size_t, cctx_T *))item_exists, &cctx);
&cctx);
if (p == NULL) if (p == NULL)
{ {