]> granicus.if.org Git - vim/commitdiff
patch 8.2.1175: Vim9: cannot split a line before ".member" v8.2.1175
authorBram Moolenaar <Bram@vim.org>
Fri, 10 Jul 2020 19:50:41 +0000 (21:50 +0200)
committerBram Moolenaar <Bram@vim.org>
Fri, 10 Jul 2020 19:50:41 +0000 (21:50 +0200)
Problem:    Vim9: Cannot split a line before ".member".
Solution:   Check for ".member" after line break.

src/testdir/test_vim9_expr.vim
src/version.c
src/vim9compile.c

index 83b7692090ac5db0d0dd347170a7ba86c03dd0cd..1f4bde9123f94fb628cf68342306a8e9e2e51965 100644 (file)
@@ -1016,7 +1016,8 @@ def Test_expr7_list()
   call CheckDefFailure(["let x = g:list_mixed[xxx]"], 'E1001:')
   call CheckDefFailure(["let x = [1,2,3]"], 'E1069:')
   call CheckDefExecFailure(["let x = g:list_mixed['xx']"], 'E39:')
-  call CheckDefFailure(["let x = g:list_mixed[0"], 'E111:')
+  call CheckDefFailure(["let x = g:list_mixed["], 'E1097:')
+  call CheckDefFailure(["let x = g:list_mixed[0"], 'E1097:')
   call CheckDefExecFailure(["let x = g:list_empty[3]"], 'E684:')
 enddef
 
@@ -1135,6 +1136,11 @@ def Test_expr_member()
   assert_equal(1, g:dict_one.one)
   let d: dict<number> = g:dict_one
   assert_equal(1, d['one'])
+  assert_equal(1, d[
+                 'one'
+                 ])
+  assert_equal(1, d
+       .one)
 
   # getting the one member should clear the dict after getting the item
   assert_equal('one', #{one: 'one'}.one)
index 3d8f86c64046a7bdec30d482205afc4492a5af4d..ac5425ddd5c2f416813f51e45d6b421ff26dff3b 100644 (file)
@@ -754,6 +754,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1175,
 /**/
     1174,
 /**/
index 93ab3c8c05b128c935a9d7546e7cc06ce255585e..3c0336ac4ae68c1192b46ed43181d73a6f861ff3 100644 (file)
@@ -2501,6 +2501,21 @@ may_get_next_line(char_u *whitep, char_u **arg, cctx_T *cctx)
     return OK;
 }
 
+/*
+ * Idem, and give an error when failed.
+ */
+    static int
+may_get_next_line_error(char_u *whitep, char_u **arg, cctx_T *cctx)
+{
+    if (may_get_next_line(whitep, arg, cctx) == FAIL)
+    {
+       emsg(_("E1097: line incomplete"));
+       return FAIL;
+    }
+    return OK;
+}
+
+
 // Structure passed between the compile_expr* functions to keep track of
 // constants that have been parsed but for which no code was produced yet.  If
 // possible expressions on these constants are applied at compile time.  If
@@ -3588,8 +3603,11 @@ compile_subscript(
 
            // If a following line starts with "->{" or "->X" advance to that
            // line, so that a line break before "->" is allowed.
-           if (next != NULL && next[0] == '-' && next[1] == '>'
-                   && (next[2] == '{' || ASCII_ISALPHA(next[2])))
+           // Also if a following line starts with ".x".
+           if (next != NULL &&
+                   ((next[0] == '-' && next[1] == '>'
+                                && (next[2] == '{' || ASCII_ISALPHA(next[2])))
+                   || (next[0] == '.' && ASCII_ISALPHA(next[1]))))
            {
                next = next_line_from_context(cctx, TRUE);
                if (next == NULL)
@@ -3672,11 +3690,13 @@ compile_subscript(
 
            ++p;
            *arg = skipwhite(p);
-           if (may_get_next_line(p, arg, cctx) == FAIL)
+           if (may_get_next_line_error(p, arg, cctx) == FAIL)
                return FAIL;
            if (compile_expr0(arg, cctx) == FAIL)
                return FAIL;
 
+           if (may_get_next_line_error(p, arg, cctx) == FAIL)
+               return FAIL;
            if (**arg != ']')
            {
                emsg(_(e_missbrac));