}
case VAR_CLASS:
- // TODO: Mark methods in class_obj_methods ?
- // Mark initializer expressions?
- break;
+ {
+ class_T *cl = tv->vval.v_class;
+ if (cl != NULL && cl->class_copyID != copyID)
+ {
+ cl->class_copyID = copyID;
+ for (int i = 0; !abort
+ && i < cl->class_class_member_count; ++i)
+ abort = abort || set_ref_in_item(
+ &cl->class_members_tv[i],
+ copyID, ht_stack, list_stack);
+
+
+ for (int i = 0; !abort
+ && i < cl->class_class_function_count; ++i)
+ abort = abort || set_ref_in_func(NULL,
+ cl->class_class_functions[i], copyID);
+
+ for (int i = 0; !abort
+ && i < cl->class_obj_method_count; ++i)
+ abort = abort || set_ref_in_func(NULL,
+ cl->class_obj_methods[i], copyID);
+
+ // Mark initializer expressions?
+ }
+ break;
+ }
case VAR_OBJECT:
{
{
char_u *class_name; // allocated
int class_refcount;
+ int class_copyID; // used by garbage collection
// class members: "static varname"
int class_class_member_count;
v9.CheckScriptFailure(lines, 'E1341: Variable already declared in the class: count')
enddef
+func Test_class_garbagecollect()
+ let lines =<< trim END
+ vim9script
+
+ class Point
+ this.p = [2, 3]
+ static pl = ['a', 'b']
+ static pd = {a: 'a', b: 'b'}
+ endclass
+
+ echo Point.pl Point.pd
+ call test_garbagecollect_now()
+ echo Point.pl Point.pd
+ END
+ call v9.CheckScriptSuccess(lines)
+endfunc
+
def Test_class_function()
var lines =<< trim END
vim9script