mirror of
https://github.com/vim/vim.git
synced 2025-09-23 03:43:49 -04:00
patch 9.1.0992: Vim9: double-free after v9.1.0988
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>
This commit is contained in:
committed by
Christian Brabandt
parent
6655bef330
commit
2050dcc20f
@@ -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
|
||||
|
@@ -704,6 +704,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
992,
|
||||
/**/
|
||||
991,
|
||||
/**/
|
||||
|
@@ -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;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user