summaryrefslogtreecommitdiffstats
path: root/Objects
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2011-05-23 21:22:42 (GMT)
committerBenjamin Peterson <benjamin@python.org>2011-05-23 21:22:42 (GMT)
commitf5fcd33be9b21b148774d3fa2832bb0627e94809 (patch)
tree2c445e396ed3cd28b9d83d633f62c7708798364e /Objects
parent4b244ef2554bd6e35fb432ad9b55eae90f37b4db (diff)
parent7963a35b417dfde5d97c52c05b73af738c827ca6 (diff)
downloadcpython-f5fcd33be9b21b148774d3fa2832bb0627e94809.zip
cpython-f5fcd33be9b21b148774d3fa2832bb0627e94809.tar.gz
cpython-f5fcd33be9b21b148774d3fa2832bb0627e94809.tar.bz2
merge 3.1
Diffstat (limited to 'Objects')
-rw-r--r--Objects/object.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/Objects/object.c b/Objects/object.c
index 17e5069..a91c46a 100644
--- a/Objects/object.c
+++ b/Objects/object.c
@@ -1366,14 +1366,15 @@ error:
static PyObject *
_dir_object(PyObject *obj)
{
- PyObject * result = NULL;
- PyObject * dirfunc = PyObject_GetAttrString((PyObject*)obj->ob_type,
- "__dir__");
+ PyObject *result = NULL;
+ static PyObject *dir_str = NULL;
+ PyObject *dirfunc = _PyObject_LookupSpecial(obj, "__dir__", &dir_str);
assert(obj);
if (dirfunc == NULL) {
+ if (PyErr_Occurred())
+ return NULL;
/* use default implementation */
- PyErr_Clear();
if (PyModule_Check(obj))
result = _specialized_dir_module(obj);
else if (PyType_Check(obj))
@@ -1383,7 +1384,7 @@ _dir_object(PyObject *obj)
}
else {
/* use __dir__ */
- result = PyObject_CallFunctionObjArgs(dirfunc, obj, NULL);
+ result = PyObject_CallFunctionObjArgs(dirfunc, NULL);
Py_DECREF(dirfunc);
if (result == NULL)
return NULL;