From: Jack Jansen Date: Thu, 15 Jul 2004 21:24:07 +0000 (+0000) Subject: Call the correct tp_dealloc. X-Git-Tag: v2.4a2~241 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c572e42fb46d69da1ac6aadf919837b5f5ed58ff;p=python Call the correct tp_dealloc. --- diff --git a/Tools/bgen/bgen/bgenObjectDefinition.py b/Tools/bgen/bgen/bgenObjectDefinition.py index 40435ad2ac..9c205e392b 100644 --- a/Tools/bgen/bgen/bgenObjectDefinition.py +++ b/Tools/bgen/bgen/bgenObjectDefinition.py @@ -135,7 +135,7 @@ class ObjectDefinition(GeneratorGroup): OutLbrace() self.outputCleanupStructMembers() if self.basetype: - Output("%s.tp_dealloc(self)", self.basetype) + Output("self->ob_type->tp_base->tp_dealloc((PyObject *)self);") elif hasattr(self, 'output_tp_free'): # This is a new-style object with tp_free slot Output("self->ob_type->tp_free((PyObject *)self);") @@ -210,7 +210,7 @@ class ObjectDefinition(GeneratorGroup): def outputTypeObjectInitializer(self): Output("""%s.ob_type = &PyType_Type;""", self.typename) if self.basetype: - Output("%s.tp_base = %s;", self.typename, self.basetype) + Output("%s.tp_base = &%s;", self.typename, self.basetype) Output("if (PyType_Ready(&%s) < 0) return;", self.typename) Output("""Py_INCREF(&%s);""", self.typename) Output("PyModule_AddObject(m, \"%s\", (PyObject *)&%s);", self.name, self.typename);