summaryrefslogtreecommitdiffstats
path: root/Objects
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2002-05-24 21:40:08 (GMT)
committerGuido van Rossum <guido@python.org>2002-05-24 21:40:08 (GMT)
commit9fc8a29663268a3ed5b8db15c4b7b7786f80e13e (patch)
tree7f22a30e0645c62f2dd4e2d3b4e0ce9d82cb2eb0 /Objects
parenta2a206b917d7634fa43be1d4062b03f1f4404300 (diff)
downloadcpython-9fc8a29663268a3ed5b8db15c4b7b7786f80e13e.zip
cpython-9fc8a29663268a3ed5b8db15c4b7b7786f80e13e.tar.gz
cpython-9fc8a29663268a3ed5b8db15c4b7b7786f80e13e.tar.bz2
Fix for SF bug 551412. When _PyType_Lookup() is called on a type
whose tp_mro hasn't been initialized, it would dump core. Fix this by checking for NULL and calling PyType_Ready(). Will fix this in 2.2.1 too.
Diffstat (limited to 'Objects')
-rw-r--r--Objects/typeobject.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/Objects/typeobject.c b/Objects/typeobject.c
index 61cbeae..af133ea 100644
--- a/Objects/typeobject.c
+++ b/Objects/typeobject.c
@@ -1221,6 +1221,12 @@ _PyType_Lookup(PyTypeObject *type, PyObject *name)
/* Look in tp_dict of types in MRO */
mro = type->tp_mro;
+ if (mro == NULL) {
+ if (PyType_Ready(type) < 0)
+ return NULL;
+ mro = type->tp_mro;
+ assert(mro != NULL);
+ }
assert(PyTuple_Check(mro));
n = PyTuple_GET_SIZE(mro);
for (i = 0; i < n; i++) {