Commit d905a0ef authored by Benjamin Peterson's avatar Benjamin Peterson

add gc support to the AST base type (closes #15293)

parent 2531f393
...@@ -615,6 +615,19 @@ ast_dealloc(AST_object *self) ...@@ -615,6 +615,19 @@ ast_dealloc(AST_object *self)
Py_TYPE(self)->tp_free(self); Py_TYPE(self)->tp_free(self);
} }
static int
ast_traverse(AST_object *self, visitproc visit, void *arg)
{
Py_VISIT(self->dict);
return 0;
}
static void
ast_clear(AST_object *self)
{
Py_CLEAR(self->dict);
}
static int static int
ast_type_init(PyObject *self, PyObject *args, PyObject *kw) ast_type_init(PyObject *self, PyObject *args, PyObject *kw)
{ {
...@@ -718,10 +731,10 @@ static PyTypeObject AST_type = { ...@@ -718,10 +731,10 @@ static PyTypeObject AST_type = {
PyObject_GenericGetAttr, /* tp_getattro */ PyObject_GenericGetAttr, /* tp_getattro */
PyObject_GenericSetAttr, /* tp_setattro */ PyObject_GenericSetAttr, /* tp_setattro */
0, /* tp_as_buffer */ 0, /* tp_as_buffer */
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */ Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HAVE_GC, /* tp_flags */
0, /* tp_doc */ 0, /* tp_doc */
0, /* tp_traverse */ (traverseproc)ast_traverse, /* tp_traverse */
0, /* tp_clear */ (inquiry)ast_clear, /* tp_clear */
0, /* tp_richcompare */ 0, /* tp_richcompare */
0, /* tp_weaklistoffset */ 0, /* tp_weaklistoffset */
0, /* tp_iter */ 0, /* tp_iter */
...@@ -737,7 +750,7 @@ static PyTypeObject AST_type = { ...@@ -737,7 +750,7 @@ static PyTypeObject AST_type = {
(initproc)ast_type_init, /* tp_init */ (initproc)ast_type_init, /* tp_init */
PyType_GenericAlloc, /* tp_alloc */ PyType_GenericAlloc, /* tp_alloc */
PyType_GenericNew, /* tp_new */ PyType_GenericNew, /* tp_new */
PyObject_Del, /* tp_free */ PyObject_GC_Del, /* tp_free */
}; };
......
...@@ -467,6 +467,19 @@ ast_dealloc(AST_object *self) ...@@ -467,6 +467,19 @@ ast_dealloc(AST_object *self)
Py_TYPE(self)->tp_free(self); Py_TYPE(self)->tp_free(self);
} }
static int
ast_traverse(AST_object *self, visitproc visit, void *arg)
{
Py_VISIT(self->dict);
return 0;
}
static void
ast_clear(AST_object *self)
{
Py_CLEAR(self->dict);
}
static int static int
ast_type_init(PyObject *self, PyObject *args, PyObject *kw) ast_type_init(PyObject *self, PyObject *args, PyObject *kw)
{ {
...@@ -570,10 +583,10 @@ static PyTypeObject AST_type = { ...@@ -570,10 +583,10 @@ static PyTypeObject AST_type = {
PyObject_GenericGetAttr, /* tp_getattro */ PyObject_GenericGetAttr, /* tp_getattro */
PyObject_GenericSetAttr, /* tp_setattro */ PyObject_GenericSetAttr, /* tp_setattro */
0, /* tp_as_buffer */ 0, /* tp_as_buffer */
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */ Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HAVE_GC, /* tp_flags */
0, /* tp_doc */ 0, /* tp_doc */
0, /* tp_traverse */ (traverseproc)ast_traverse, /* tp_traverse */
0, /* tp_clear */ (inquiry)ast_clear, /* tp_clear */
0, /* tp_richcompare */ 0, /* tp_richcompare */
0, /* tp_weaklistoffset */ 0, /* tp_weaklistoffset */
0, /* tp_iter */ 0, /* tp_iter */
...@@ -589,7 +602,7 @@ static PyTypeObject AST_type = { ...@@ -589,7 +602,7 @@ static PyTypeObject AST_type = {
(initproc)ast_type_init, /* tp_init */ (initproc)ast_type_init, /* tp_init */
PyType_GenericAlloc, /* tp_alloc */ PyType_GenericAlloc, /* tp_alloc */
PyType_GenericNew, /* tp_new */ PyType_GenericNew, /* tp_new */
PyObject_Del, /* tp_free */ PyObject_GC_Del, /* tp_free */
}; };
......
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