]> granicus.if.org Git - vim/commitdiff
patch 8.2.1257: Vim9: list unpack doesn't work at the script level v8.2.1257
authorBram Moolenaar <Bram@vim.org>
Mon, 20 Jul 2020 20:37:44 +0000 (22:37 +0200)
committerBram Moolenaar <Bram@vim.org>
Mon, 20 Jul 2020 20:37:44 +0000 (22:37 +0200)
Problem:    Vim9: list unpack doesn't work at the script level.
Solution:   Detect unpack assignment better. (closes #6494)

src/ex_docmd.c
src/testdir/test_vim9_script.vim
src/version.c

index 91a51681afdbbe512f37df9a6551b5e6db989496..db1df0d7265f729569144e13c1d2e51cd23a0f40 100644 (file)
@@ -3282,10 +3282,19 @@ find_ex_command(
        // after the "]" by to_name_const_end(): check if a "=" follows.
        // If "[...]" has a line break "p" still points at the "[" and it can't
        // be an assignment.
-       if (*eap->cmd == '[' && (p == eap->cmd || *skipwhite(p) != '='))
+       if (*eap->cmd == '[')
        {
-           eap->cmdidx = CMD_eval;
-           return eap->cmd;
+           p = to_name_const_end(eap->cmd);
+           if (p == eap->cmd || *skipwhite(p) != '=')
+           {
+               eap->cmdidx = CMD_eval;
+               return eap->cmd;
+           }
+           if (p > eap->cmd && *skipwhite(p) == '=')
+           {
+               eap->cmdidx = CMD_let;
+               return eap->cmd;
+           }
        }
 
        // Recognize an assignment if we recognize the variable name:
index fa5ee3c12d28f471074fb12984b01ea23b40bbf3..59727a2fd4af888ede30adb1b1c8d01a8c8d0dec 100644 (file)
@@ -169,6 +169,18 @@ def Test_assignment_list()
   let somelist = rand() > 0 ? [1, 2, 3] : ['a', 'b', 'c']
 enddef
 
+def Test_assignment_list_vim9script()
+  let lines =<< trim END
+    vim9script
+    let v1: number
+    let v2: number
+    let v3: number
+    [v1, v2, v3] = [1, 2, 3]
+    assert_equal([1, 2, 3], [v1, v2, v3])
+  END
+  call CheckScriptSuccess(lines)
+enddef
+
 def Test_assignment_dict()
   let dict1: dict<bool> = #{one: false, two: true}
   let dict2: dict<number> = #{one: 1, two: 2}
index ee1e3f44c4f00c3443b8e8578771a8ec223bb2d2..cc7fbfbfe6652c7ea628fee4ce142d40fb7d1f9f 100644 (file)
@@ -754,6 +754,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1257,
 /**/
     1256,
 /**/