diff options
author | Benjamin Peterson <benjamin@python.org> | 2011-05-23 21:27:36 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2011-05-23 21:27:36 (GMT) |
commit | 5cc10b00094f06af56dedd02d39bc46886e17c70 (patch) | |
tree | a6bb19f9a5eab8dfa7d1145d92b87c3b9faba61d /Objects/object.c | |
parent | 1dc540702072c381c3e7570f075a3f1147353d92 (diff) | |
parent | f5fcd33be9b21b148774d3fa2832bb0627e94809 (diff) | |
download | cpython-5cc10b00094f06af56dedd02d39bc46886e17c70.zip cpython-5cc10b00094f06af56dedd02d39bc46886e17c70.tar.gz cpython-5cc10b00094f06af56dedd02d39bc46886e17c70.tar.bz2 |
merge 3.2
Diffstat (limited to 'Objects/object.c')
-rw-r--r-- | Objects/object.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/Objects/object.c b/Objects/object.c index db7882a..d8e2ffb 100644 --- a/Objects/object.c +++ b/Objects/object.c @@ -1364,14 +1364,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)) @@ -1381,7 +1382,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; |