# HG changeset patch # User Bram Moolenaar # Date 1639583103 -3600 # Node ID 9f75681047260bad94d378e610ac8946b8cf4f5a # Parent 696b10f0898acdf1634e651719db6a6f38087c6d patch 8.2.3815: Vim9: cannot have a multi-line dict inside a block Commit: https://github.com/vim/vim/commit/ce7eada12ea16c830332042f0021a9564bbb25af Author: Bram Moolenaar Date: Wed Dec 15 15:41:44 2021 +0000 patch 8.2.3815: Vim9: cannot have a multi-line dict inside a block Problem: Vim9: cannot have a multi-line dict inside a block. Solution: Do not split the command at a line break, handle NL characters as white space. diff --git a/src/charset.c b/src/charset.c --- a/src/charset.c +++ b/src/charset.c @@ -1459,14 +1459,27 @@ getvcols( } /* - * skipwhite: skip over ' ' and '\t'. + * Skip over ' ' and '\t'. */ char_u * skipwhite(char_u *q) { char_u *p = q; - while (VIM_ISWHITE(*p)) // skip to next non-white + while (VIM_ISWHITE(*p)) + ++p; + return p; +} + +/* + * skip over ' ', '\t' and '\n'. + */ + char_u * +skipwhite_and_nl(char_u *q) +{ + char_u *p = q; + + while (VIM_ISWHITE(*p) || *p == NL) ++p; return p; } diff --git a/src/eval.c b/src/eval.c --- a/src/eval.c +++ b/src/eval.c @@ -2150,7 +2150,7 @@ eval_next_line(evalarg_T *evalarg) skipwhite_and_linebreak(char_u *arg, evalarg_T *evalarg) { int getnext; - char_u *p = skipwhite(arg); + char_u *p = skipwhite_and_nl(arg); if (evalarg == NULL) return skipwhite(arg); diff --git a/src/ex_docmd.c b/src/ex_docmd.c --- a/src/ex_docmd.c +++ b/src/ex_docmd.c @@ -2305,7 +2305,7 @@ do_one_cmd( // versions. if (*p == '\\' && p[1] == '\n') STRMOVE(p, p + 1); - else if (*p == '\n') + else if (*p == '\n' && (ea.argt & EX_TRLBAR)) { ea.nextcmd = p + 1; *p = NUL; diff --git a/src/proto/charset.pro b/src/proto/charset.pro --- a/src/proto/charset.pro +++ b/src/proto/charset.pro @@ -36,6 +36,7 @@ colnr_T getvcol_nolist(pos_T *posp); void getvvcol(win_T *wp, pos_T *pos, colnr_T *start, colnr_T *cursor, colnr_T *end); void getvcols(win_T *wp, pos_T *pos1, pos_T *pos2, colnr_T *left, colnr_T *right); char_u *skipwhite(char_u *q); +char_u *skipwhite_and_nl(char_u *q); int getwhitecols_curline(void); int getwhitecols(char_u *p); char_u *skipdigits(char_u *q); diff --git a/src/testdir/test_vim9_expr.vim b/src/testdir/test_vim9_expr.vim --- a/src/testdir/test_vim9_expr.vim +++ b/src/testdir/test_vim9_expr.vim @@ -2549,6 +2549,20 @@ def Test_expr7_dict_vim9script() CheckScriptSuccess(lines) enddef +def Test_expr7_dict_in_block() + var lines =<< trim END + vim9script + command MyCommand { + echo { + k: 0, } + } + MyCommand + END + CheckScriptSuccess(lines) + + delcommand MyCommand +enddef + def Test_expr7_call_2bool() var lines =<< trim END vim9script diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -750,6 +750,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 3815, +/**/ 3814, /**/ 3813,