Skip to content

Commit

Permalink
patch 9.1.0992: Vim9: double-free after v9.1.0988
Browse files Browse the repository at this point in the history
Problem:  Vim9: double-free after v9.1.0988
          (h-east)
Solution: clear typval pointer, before setting the type
          (Yegappan Lakshmanan)

Otherwise the contents are still referring to some other value.

fixes: #16386
closes: #16388

Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
  • Loading branch information
yegappan authored and chrisbra committed Jan 6, 2025
1 parent 6655bef commit 2050dcc
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 0 deletions.
27 changes: 27 additions & 0 deletions src/testdir/test_vim9_class.vim
Original file line number Diff line number Diff line change
Expand Up @@ -11839,4 +11839,31 @@ def Test_uninitialized_object_var()
v9.CheckSourceFailure(lines, "E1430: Uninitialized object variable 'x' referenced")
enddef

" Test for initializing member variables of compound type in the constructor
def Test_constructor_init_compound_member_var()
var lines =<< trim END
vim9script

class Foo
var v1: string = "aaa"
var v2: list<number> = [1, 2]
var v3: dict<string> = {a: 'a', b: 'b'}
endclass

class Bar
var v4: string = "bbb"
var v5: Foo = Foo.new()
var v6: list<number> = [1, 2]
endclass

var b: Bar = Bar.new()
assert_equal("aaa", b.v5.v1)
assert_equal([1, 2], b.v5.v2)
assert_equal({a: 'a', b: 'b'}, b.v5.v3)
assert_equal("bbb", b.v4)
assert_equal([1, 2], b.v6)
END
v9.CheckSourceSuccess(lines)
enddef

" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
2 changes: 2 additions & 0 deletions src/version.c
Original file line number Diff line number Diff line change
Expand Up @@ -704,6 +704,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
992,
/**/
991,
/**/
Expand Down
1 change: 1 addition & 0 deletions src/vim9execute.c
Original file line number Diff line number Diff line change
Expand Up @@ -4855,6 +4855,7 @@ exec_instructions(ectx_T *ectx)
+ iptr->isn_arg.jumparg.jump_arg_off
+ STACK_FRAME_SIZE;
type_T *t = ufunc->uf_arg_types[argidx];
CLEAR_POINTER(tv);
tv->v_type = t->tt_type;
}

Expand Down

0 comments on commit 2050dcc

Please sign in to comment.
  NODES
COMMUNITY 1
Note 1
Project 3
USERS 1