summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRonald Oussoren <ronaldoussoren@mac.com>2013-07-19 09:11:25 (GMT)
committerRonald Oussoren <ronaldoussoren@mac.com>2013-07-19 09:11:25 (GMT)
commit138d080a28431a3437601e3297e7fe5d39edb574 (patch)
tree417c87d98c5ec9ef492b53a21fdf145e8b56bcbb
parent45e90394e728d94c0840010d4b47803456539d09 (diff)
downloadcpython-138d080a28431a3437601e3297e7fe5d39edb574.zip
cpython-138d080a28431a3437601e3297e7fe5d39edb574.tar.gz
cpython-138d080a28431a3437601e3297e7fe5d39edb574.tar.bz2
#18480: Add missing PyType_Ready call to _elementtree extension
-rw-r--r--Misc/NEWS2
-rw-r--r--Modules/_elementtree.c14
2 files changed, 11 insertions, 5 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 6650d0d..de16f7b 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -49,6 +49,8 @@ Core and Builtins
Library
-------
+- Issue #18480: Add missing call to PyType_Ready to the _elementtree extension.
+
- Issue #17778: Fix test discovery for test_multiprocessing. (Patch by
Zachary Ware.)
diff --git a/Modules/_elementtree.c b/Modules/_elementtree.c
index d3784e8..9789527 100644
--- a/Modules/_elementtree.c
+++ b/Modules/_elementtree.c
@@ -100,6 +100,13 @@ do { memory -= size; printf("%8d - %s\n", memory, comment); } while (0)
#define JOIN_SET(p, flag) ((void*) ((Py_uintptr_t) (JOIN_OBJ(p)) | (flag)))
#define JOIN_OBJ(p) ((PyObject*) ((Py_uintptr_t) (p) & ~(Py_uintptr_t)1))
+/* Types defined by this extension */
+static PyTypeObject Element_Type;
+static PyTypeObject ElementIter_Type;
+static PyTypeObject TreeBuilder_Type;
+static PyTypeObject XMLParser_Type;
+
+
/* glue functions (see the init function for details) */
static PyObject* elementtree_parseerror_obj;
static PyObject* elementtree_deepcopy_obj;
@@ -200,7 +207,6 @@ typedef struct {
} ElementObject;
-static PyTypeObject Element_Type;
#define Element_CheckExact(op) (Py_TYPE(op) == &Element_Type)
@@ -2204,8 +2210,6 @@ typedef struct {
PyObject *end_ns_event_obj;
} TreeBuilderObject;
-static PyTypeObject TreeBuilder_Type;
-
#define TreeBuilder_CheckExact(op) (Py_TYPE(op) == &TreeBuilder_Type)
/* -------------------------------------------------------------------- */
@@ -2717,8 +2721,6 @@ typedef struct {
} XMLParserObject;
-static PyTypeObject XMLParser_Type;
-
#define XMLParser_CheckExact(op) (Py_TYPE(op) == &XMLParser_Type)
/* helpers */
@@ -3653,6 +3655,8 @@ PyInit__elementtree(void)
PyObject *m, *temp;
/* Initialize object types */
+ if (PyType_Ready(&ElementIter_Type) < 0)
+ return NULL;
if (PyType_Ready(&TreeBuilder_Type) < 0)
return NULL;
if (PyType_Ready(&Element_Type) < 0)