]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0992: Vim9: double-free after v9.1.0988 v9.1.0992
authorYegappan Lakshmanan <yegappan@yahoo.com>
Mon, 6 Jan 2025 17:34:49 +0000 (18:34 +0100)
committerChristian Brabandt <cb@256bit.org>
Mon, 6 Jan 2025 17:34:49 +0000 (18:34 +0100)
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>
src/testdir/test_vim9_class.vim
src/version.c
src/vim9execute.c

index c7a0fbefa7de7b3664ca5c72785e14a7468c232e..0c11c078e721ec25fa86f8860134b34ef62cf0d3 100644 (file)
@@ -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
index dc04ffc0935d32ecac5df08836f5088834ab4ae8..e8feb96f40159da11b1a1286411c775c7f77abdc 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    992,
 /**/
     991,
 /**/
index dde95b511509cdd21868292fbac106a6d54ee3de..d6962804b361d72b9a7e3874f6c65fc5f9492b19 100644 (file)
@@ -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;
                }