Commit a0c154c9 authored by Xavier Thompson's avatar Xavier Thompson

Deallocate cypclass wrapper in cyobject destructor

parent 85befcc0
......@@ -589,7 +589,6 @@ def generate_cyp_class_attrs_destructor_definition(entry, code):
code.putln("Cy_XDECREF(this->%s);" % attr.cname)
code.putln("}")
def generate_cyp_class_activate_function(entry, code):
"""
Generate activate function for activable cypclass entries
......@@ -1042,7 +1041,9 @@ def generate_cyp_class_wrapper_definition(type, wrapper_entry, constructor_entry
objstruct_cname = type.wrapper_type.objstruct_cname
cclass_wrapper_base = type.wrapped_base_type().wrapper_type
code.putln("if(self) {")
code.putln("%s * wrapper = new %s();" % (objstruct_cname, objstruct_cname))
code.putln("printf(\"allocating wrapper for %s cypclass\\n\");" % type.name)
code.putln("%s * wrapper = (%s *) ::operator new(sizeof *wrapper);" % (objstruct_cname, objstruct_cname))
code.putln("printf(\"allocated wrapper object @ %p\\n\\n\", wrapper);")
code.putln("((%s *)wrapper)->%s = self;" % (cclass_wrapper_base.objstruct_cname, Naming.cypclass_attr_cname))
code.putln("PyObject * wrapper_as_py = (PyObject *) wrapper;")
code.putln("wrapper_as_py->ob_refcnt = 0;")
......
......@@ -63,8 +63,8 @@
RecursiveUpgradeableRWLock ob_lock;
public:
PyObject * cy_pyobject;
CyObject(): nogil_ob_refcnt(1) {}
virtual ~CyObject() {}
CyObject(): nogil_ob_refcnt(1), cy_pyobject(NULL) {}
virtual ~CyObject();
void CyObject_INCREF();
int CyObject_DECREF();
void CyObject_RLOCK();
......@@ -446,6 +446,14 @@ int RecursiveUpgradeableRWLock::trywlock() {
return 0;
}
CyObject::~CyObject() {
if (cy_pyobject) {
printf("deleting wrapper object @ %p\n", cy_pyobject);
printf("python refcount: %ld\n", cy_pyobject->ob_refcnt);
::operator delete(cy_pyobject);
printf("wrapper deleted\n\n");
}
}
void CyObject::CyObject_INCREF()
{
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment