]> granicus.if.org Git - vim/commitdiff
patch 8.2.3177: Vim9: can not use "for _ in expr" at script level v8.2.3177
authorBram Moolenaar <Bram@vim.org>
Sun, 18 Jul 2021 15:08:50 +0000 (17:08 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 18 Jul 2021 15:08:50 +0000 (17:08 +0200)
Problem:    Vim9: can not use "for _ in expr" at script level.
Solution:   Skip assignment if the loop variable is "_".

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

index 2e8ab3d8fc29e0b9a17909a3f23c7f9da86e37b0..058b2d3bed8e0f2e3cd70eab0a169bae986be423 100644 (file)
@@ -1784,6 +1784,8 @@ next_for_item(void *fi_void, char_u *arg)
                             | ASSIGN_NO_MEMBER_TYPE)
                         : 0);
     listitem_T *item;
+    int                skip_assign = in_vim9script() && arg[0] == '_'
+                                                     && !eval_isnamec(arg[1]);
 
     if (fi->fi_blob != NULL)
     {
@@ -1795,6 +1797,8 @@ next_for_item(void *fi_void, char_u *arg)
        tv.v_lock = VAR_FIXED;
        tv.vval.v_number = blob_get(fi->fi_blob, fi->fi_bi);
        ++fi->fi_bi;
+       if (skip_assign)
+           return TRUE;
        return ex_let_vars(arg, &tv, TRUE, fi->fi_semicolon,
                                            fi->fi_varcount, flag, NULL) == OK;
     }
@@ -1812,7 +1816,10 @@ next_for_item(void *fi_void, char_u *arg)
        tv.vval.v_string = vim_strnsave(fi->fi_string + fi->fi_byte_idx, len);
        fi->fi_byte_idx += len;
        ++fi->fi_bi;
-       result = ex_let_vars(arg, &tv, TRUE, fi->fi_semicolon,
+       if (skip_assign)
+           result = TRUE;
+       else
+           result = ex_let_vars(arg, &tv, TRUE, fi->fi_semicolon,
                                            fi->fi_varcount, flag, NULL) == OK;
        vim_free(tv.vval.v_string);
        return result;
@@ -1825,7 +1832,10 @@ next_for_item(void *fi_void, char_u *arg)
     {
        fi->fi_lw.lw_item = item->li_next;
        ++fi->fi_bi;
-       result = (ex_let_vars(arg, &item->li_tv, TRUE, fi->fi_semicolon,
+       if (skip_assign)
+           result = TRUE;
+       else
+           result = (ex_let_vars(arg, &item->li_tv, TRUE, fi->fi_semicolon,
                                           fi->fi_varcount, flag, NULL) == OK);
     }
     return result;
index bd06f7a2e9e8b57249957425dc7ec3a2e3ab93ff..592da6d0f9d9ac29865e243d77e6177e2d9661d0 100644 (file)
@@ -2557,6 +2557,12 @@ def Test_for_loop()
         dd.counter = 12
       endfor
       assert_equal([{a: 'Cat', counter: 12}], foo)
+
+      reslist = []
+      for _ in range(3)
+        reslist->add('x')
+      endfor
+      assert_equal(['x', 'x', 'x'], reslist)
   END
   CheckDefAndScriptSuccess(lines)
 enddef
index c1a4f3f8fa132753fb7e741acffff87fab326784..0eb4b442b283c75c3a294ca02b9dab8c0fd456ce 100644 (file)
@@ -755,6 +755,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    3177,
 /**/
     3176,
 /**/