# HG changeset patch # User Bram Moolenaar # Date 1674054006 -3600 # Node ID 8d2bfc85e3c51afbb2e243462be4912bcbaf7888 # Parent a169126bf2a32406804e2addd56f50197da5f318 patch 9.0.1217: using an object member in a closure doesn't work Commit: https://github.com/vim/vim/commit/486fc25a295464d107264b63997bdbe3745e3c71 Author: Bram Moolenaar Date: Wed Jan 18 14:51:07 2023 +0000 patch 9.0.1217: using an object member in a closure doesn't work Problem: Using an object member in a closure doesn't work. Solution: Initialize lv_loop_depth. (closes https://github.com/vim/vim/issues/11840) diff --git a/src/testdir/test_vim9_class.vim b/src/testdir/test_vim9_class.vim --- a/src/testdir/test_vim9_class.vim +++ b/src/testdir/test_vim9_class.vim @@ -1214,5 +1214,23 @@ def Test_abstract_class() v9.CheckScriptFailure(lines, 'E1316:') enddef +def Test_closure_in_class() + var lines =<< trim END + vim9script + + class Foo + this.y: list = ['B'] + + def new() + g:result = filter(['A', 'B'], (_, v) => index(this.y, v) == -1) + enddef + endclass + + Foo.new() + assert_equal(['A'], g:result) + END + v9.CheckScriptSuccess(lines) +enddef + " vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -696,6 +696,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1217, +/**/ 1216, /**/ 1215, diff --git a/src/vim9compile.c b/src/vim9compile.c --- a/src/vim9compile.c +++ b/src/vim9compile.c @@ -66,6 +66,7 @@ lookup_local(char_u *name, size_t len, l if (lvar != NULL) { CLEAR_POINTER(lvar); + lvar->lv_loop_depth = -1; lvar->lv_name = (char_u *)(is_super ? "super" : "this"); if (cctx->ctx_ufunc->uf_class != NULL) {