summaryrefslogtreecommitdiffstats
path: root/Objects/methodobject.c
diff options
context:
space:
mode:
authorNeil Schemenauer <nascheme@enme.ucalgary.ca>2001-07-12 13:27:35 (GMT)
committerNeil Schemenauer <nascheme@enme.ucalgary.ca>2001-07-12 13:27:35 (GMT)
commit10c66927742269936ce51b21c790efb8bcbc67dc (patch)
treef624d99f4860f89fe37ccfc4b1de83009940a8b8 /Objects/methodobject.c
parent7eac9b72d45f68d82e1dc463d1050aa86af94709 (diff)
downloadcpython-10c66927742269936ce51b21c790efb8bcbc67dc.zip
cpython-10c66927742269936ce51b21c790efb8bcbc67dc.tar.gz
cpython-10c66927742269936ce51b21c790efb8bcbc67dc.tar.bz2
GC for method objects.
Diffstat (limited to 'Objects/methodobject.c')
-rw-r--r--Objects/methodobject.c42
1 files changed, 31 insertions, 11 deletions
diff --git a/Objects/methodobject.c b/Objects/methodobject.c
index f0bbeea..bff79ed 100644
--- a/Objects/methodobject.c
+++ b/Objects/methodobject.c
@@ -24,6 +24,7 @@ PyCFunction_New(PyMethodDef *ml, PyObject *self)
op->m_ml = ml;
Py_XINCREF(self);
op->m_self = self;
+ PyObject_GC_Init(op);
return (PyObject *)op;
}
@@ -62,11 +63,21 @@ PyCFunction_GetFlags(PyObject *op)
static void
meth_dealloc(PyCFunctionObject *m)
{
+ PyObject_GC_Fini(m);
Py_XDECREF(m->m_self);
m->m_self = (PyObject *)free_list;
free_list = m;
}
+static int
+meth_traverse(PyCFunctionObject *m, visitproc visit, void *arg)
+{
+ if (m->m_self != NULL)
+ return visit(m->m_self, arg);
+ else
+ return 0;
+}
+
static PyObject *
meth_getattr(PyCFunctionObject *m, char *name)
{
@@ -152,18 +163,26 @@ PyTypeObject PyCFunction_Type = {
PyObject_HEAD_INIT(&PyType_Type)
0,
"builtin_function_or_method",
- sizeof(PyCFunctionObject),
+ sizeof(PyCFunctionObject) + PyGC_HEAD_SIZE,
0,
- (destructor)meth_dealloc, /*tp_dealloc*/
- 0, /*tp_print*/
- (getattrfunc)meth_getattr, /*tp_getattr*/
- 0, /*tp_setattr*/
- (cmpfunc)meth_compare, /*tp_compare*/
- (reprfunc)meth_repr, /*tp_repr*/
- 0, /*tp_as_number*/
- 0, /*tp_as_sequence*/
- 0, /*tp_as_mapping*/
- (hashfunc)meth_hash, /*tp_hash*/
+ (destructor)meth_dealloc, /* tp_dealloc */
+ 0, /* tp_print */
+ (getattrfunc)meth_getattr, /* tp_getattr */
+ 0, /* tp_setattr */
+ (cmpfunc)meth_compare, /* tp_compare */
+ (reprfunc)meth_repr, /* tp_repr */
+ 0, /* tp_as_number */
+ 0, /* tp_as_sequence */
+ 0, /* tp_as_mapping */
+ (hashfunc)meth_hash, /* tp_hash */
+ 0, /* tp_call */
+ 0, /* tp_str */
+ 0, /* tp_getattro */
+ 0, /* tp_setattro */
+ 0, /* tp_as_buffer */
+ Py_TPFLAGS_DEFAULT | Py_TPFLAGS_GC, /* tp_flags */
+ 0, /* tp_doc */
+ (traverseproc)meth_traverse, /* tp_traverse */
};
/* List all methods in a chain -- helper for findmethodinchain */
@@ -245,6 +264,7 @@ PyCFunction_Fini(void)
while (free_list) {
PyCFunctionObject *v = free_list;
free_list = (PyCFunctionObject *)(v->m_self);
+ v = (PyCFunctionObject *) PyObject_AS_GC(v);
PyObject_DEL(v);
}
}