patch 9.0.0732: no check for white space before and after "=<<"
Problem: No check for white space before and after "=<<". (Doug Kearns)
Solution: Check for white space in Vim9 script. (closes #11351)
diff --git a/src/evalvars.c b/src/evalvars.c
index c4b95bc..fd443cd 100644
--- a/src/evalvars.c
+++ b/src/evalvars.c
@@ -1066,11 +1066,18 @@
}
else if (expr[0] == '=' && expr[1] == '<' && expr[2] == '<')
{
- list_T *l;
+ list_T *l = NULL;
long cur_lnum = SOURCING_LNUM;
- // HERE document
- l = heredoc_get(eap, expr + 3, FALSE, FALSE);
+ // :let text =<< [trim] [eval] END
+ // :var text =<< [trim] [eval] END
+ if (vim9script && !eap->skip && (!VIM_ISWHITE(expr[-1])
+ || !IS_WHITE_OR_NUL(expr[3])))
+ semsg(_(e_white_space_required_before_and_after_str_at_str),
+ "=<<", expr);
+ else
+ l = heredoc_get(eap, expr + 3, FALSE, FALSE);
+
if (l != NULL)
{
rettv_list_set(&rettv, l);
diff --git a/src/testdir/test_vim9_assign.vim b/src/testdir/test_vim9_assign.vim
index 3957942..c552461 100644
--- a/src/testdir/test_vim9_assign.vim
+++ b/src/testdir/test_vim9_assign.vim
@@ -1904,6 +1904,25 @@
STOP
END
v9.CheckDefAndScriptFailure(lines, 'E1012: Type mismatch; expected number but got list<string>', 1)
+
+ lines =<< trim END
+ var lines=<< STOP
+ xxx
+ STOP
+ END
+ v9.CheckDefAndScriptFailure(lines, 'E1004: White space required before and after ''=<<'' at "=<< STOP"', 1)
+ lines =<< trim END
+ var lines =<<STOP
+ xxx
+ STOP
+ END
+ v9.CheckDefAndScriptFailure(lines, 'E1004: White space required before and after ''=<<'' at "=<<STOP"', 1)
+ lines =<< trim END
+ var lines=<<STOP
+ xxx
+ STOP
+ END
+ v9.CheckDefAndScriptFailure(lines, 'E1004: White space required before and after ''=<<'' at "=<<STOP"', 1)
enddef
def Test_var_func_call()
diff --git a/src/version.c b/src/version.c
index b44101e..37d64fb 100644
--- a/src/version.c
+++ b/src/version.c
@@ -700,6 +700,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 732,
+/**/
731,
/**/
730,