Patch 8.1.1563
Problem:    Crash when using closures.
Solution:   Set reference in varlist of funccal when running the garbage
            collector. (Ozaki Kiichi, closes #4554, closes #4547)
Files:      src/testdir/test_vimscript.vim, src/userfunc.c


*** ../vim-8.1.1562/src/testdir/test_vimscript.vim      2019-05-24 
17:32:57.351719237 +0200
--- src/testdir/test_vimscript.vim      2019-06-17 21:14:14.411035228 +0200
***************
*** 1665,1670 ****
--- 1665,1681 ----
      delfunc DictFunc
  endfunc
  
+ func! Test_funccall_garbage_collect()
+     func Func(x, ...)
+         call add(a:x, a:000)
+     endfunc
+     call Func([], [])
+     " Must not crash cause by invalid freeing
+     call test_garbagecollect_now()
+     call assert_true(v:true)
+     delfunc Func
+ endfunc
+ 
  
"-------------------------------------------------------------------------------
  " Modelines                                                               {{{1
  " vim: ts=8 sw=4 tw=80 fdm=marker
*** ../vim-8.1.1562/src/userfunc.c      2019-06-06 19:03:14.388227807 +0200
--- src/userfunc.c      2019-06-17 21:14:14.411035228 +0200
***************
*** 935,946 ****
            v->di_flags |= DI_FLAGS_RO | DI_FLAGS_FIX;
        }
  
!       if (isdefault)
!           v->di_tv = def_rettv;
!       else
!           // Note: the values are copied directly to avoid alloc/free.
!           // "argvars" must have VAR_FIXED for v_lock.
!           v->di_tv = argvars[i];
        v->di_tv.v_lock = VAR_FIXED;
  
        if (addlocal)
--- 935,943 ----
            v->di_flags |= DI_FLAGS_RO | DI_FLAGS_FIX;
        }
  
!       // Note: the values are copied directly to avoid alloc/free.
!       // "argvars" must have VAR_FIXED for v_lock.
!       v->di_tv = isdefault ? def_rettv : argvars[i];
        v->di_tv.v_lock = VAR_FIXED;
  
        if (addlocal)
***************
*** 1540,1546 ****
        }
      }
  
- 
      /*
       * Execute the function if executing and no errors were detected.
       */
--- 1537,1542 ----
***************
*** 3998,4010 ****
      int               abort = FALSE;
      funccall_T        *fc;
  
!     for (fc = previous_funccal; fc != NULL; fc = fc->caller)
      {
        fc->fc_copyID = copyID + 1;
!       abort = abort || set_ref_in_ht(&fc->l_vars.dv_hashtab, copyID + 1,
!                                                                       NULL);
!       abort = abort || set_ref_in_ht(&fc->l_avars.dv_hashtab, copyID + 1,
!                                                                       NULL);
      }
      return abort;
  }
--- 3994,4006 ----
      int               abort = FALSE;
      funccall_T        *fc;
  
!     for (fc = previous_funccal; !abort && fc != NULL; fc = fc->caller)
      {
        fc->fc_copyID = copyID + 1;
!       abort = abort
!           || set_ref_in_ht(&fc->l_vars.dv_hashtab, copyID + 1, NULL)
!           || set_ref_in_ht(&fc->l_avars.dv_hashtab, copyID + 1, NULL)
!           || set_ref_in_list(&fc->l_varlist, copyID + 1, NULL);
      }
      return abort;
  }
***************
*** 4017,4025 ****
      if (fc->fc_copyID != copyID)
      {
        fc->fc_copyID = copyID;
!       abort = abort || set_ref_in_ht(&fc->l_vars.dv_hashtab, copyID, NULL);
!       abort = abort || set_ref_in_ht(&fc->l_avars.dv_hashtab, copyID, NULL);
!       abort = abort || set_ref_in_func(NULL, fc->func, copyID);
      }
      return abort;
  }
--- 4013,4023 ----
      if (fc->fc_copyID != copyID)
      {
        fc->fc_copyID = copyID;
!       abort = abort
!           || set_ref_in_ht(&fc->l_vars.dv_hashtab, copyID, NULL)
!           || set_ref_in_ht(&fc->l_avars.dv_hashtab, copyID, NULL)
!           || set_ref_in_list(&fc->l_varlist, copyID, NULL)
!           || set_ref_in_func(NULL, fc->func, copyID);
      }
      return abort;
  }
*** ../vim-8.1.1562/src/version.c       2019-06-17 20:05:29.570879949 +0200
--- src/version.c       2019-06-17 21:16:54.850284846 +0200
***************
*** 779,780 ****
--- 779,782 ----
  {   /* Add new patch number below this line */
+ /**/
+     1563,
  /**/

-- 
hundred-and-one symptoms of being an internet addict:
217. Your sex life has drastically improved...so what if it's only cyber-sex!

 /// Bram Moolenaar -- [email protected] -- http://www.Moolenaar.net   \\\
///        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\  an exciting new programming language -- http://www.Zimbu.org        ///
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/vim_dev/201906171918.x5HJIuw7023780%40masaka.moolenaar.net.
For more options, visit https://groups.google.com/d/optout.

Raspunde prin e-mail lui