summaryrefslogtreecommitdiffstats
path: root/Objects/dictobject.c
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2009-05-27 03:08:59 (GMT)
committerBenjamin Peterson <benjamin@python.org>2009-05-27 03:08:59 (GMT)
commita720559878f25f3f8ed46a81260844231bfc9d4b (patch)
tree57b4275ac5e113bbbd889c9521d9e6b2aad3a007 /Objects/dictobject.c
parent499b2ee8a8c2a498cb068f09f6be1bfb6da85225 (diff)
downloadcpython-a720559878f25f3f8ed46a81260844231bfc9d4b.zip
cpython-a720559878f25f3f8ed46a81260844231bfc9d4b.tar.gz
cpython-a720559878f25f3f8ed46a81260844231bfc9d4b.tar.bz2
Merged revisions 72957 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r72957 | benjamin.peterson | 2009-05-26 21:43:46 -0500 (Tue, 26 May 2009) | 1 line correctly handle descrs with __missing__ ........
Diffstat (limited to 'Objects/dictobject.c')
-rw-r--r--Objects/dictobject.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/Objects/dictobject.c b/Objects/dictobject.c
index b39c614..97fa60b 100644
--- a/Objects/dictobject.c
+++ b/Objects/dictobject.c
@@ -1128,13 +1128,14 @@ dict_subscript(PyDictObject *mp, register PyObject *key)
/* Look up __missing__ method if we're a subclass. */
PyObject *missing;
static PyObject *missing_str = NULL;
- if (missing_str == NULL)
- missing_str =
- PyUnicode_InternFromString("__missing__");
- missing = _PyType_Lookup(Py_TYPE(mp), missing_str);
+ missing = _PyObject_LookupSpecial((PyObject *)mp,
+ "__missing__",
+ &missing_str);
if (missing != NULL)
return PyObject_CallFunctionObjArgs(missing,
- (PyObject *)mp, key, NULL);
+ key, NULL);
+ else if (PyErr_Occurred())
+ return NULL;
}
set_key_error(key);
return NULL;