0
0
mirror of https://github.com/vim/vim.git synced 2025-09-25 03:54:15 -04:00

patch 9.0.1897: Vim9: confusing error with .= in compiled functions

Problem:  Vim9: confusing error with .= in compiled functions
Solution: Check in error condition, if .= was attempted and in that case
          give a different error message.

closes: #12972
closes: #13066

Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Christian Brabandt
2023-09-11 20:08:50 +02:00
parent 6b9c202549
commit 504543f98b
3 changed files with 29 additions and 1 deletions

View File

@@ -79,6 +79,25 @@ def Test_vim9cmd()
legacy echo version
END
v9.CheckScriptSuccess(lines)
lines =<< trim END
vim9script
def Func()
var d: dict<string>
d.k .= ''
enddef
defcompile
END
v9.CheckScriptFailure(lines, 'E985:')
lines =<< trim END
vim9script
def Func()
var d: dict<string>
d.k ,= ''
enddef
defcompile
END
v9.CheckScriptFailure(lines, 'E1017:')
enddef
def Test_defcompile_fails()

View File

@@ -699,6 +699,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
1897,
/**/
1896,
/**/

View File

@@ -1669,6 +1669,13 @@ compile_lhs(
{
if (is_decl)
{
// if we come here with what looks like an assignment like .=
// but which has been reject by assignment_len() from may_compile_assignment
// give a better error message
char_u *p = skipwhite(lhs->lhs_end);
if (p[0] == '.' && p[1] == '=')
emsg(_(e_dot_equal_not_supported_with_script_version_two));
else
semsg(_(e_variable_already_declared_str), lhs->lhs_name);
return FAIL;
}