correctly lookup __dir__

This commit is contained in:
Benjamin Peterson 2011-05-23 16:11:05 -05:00
parent 4ef33dc381
commit 8de87a6403
3 changed files with 9 additions and 3 deletions

View File

@ -1718,6 +1718,7 @@ order (MRO) for bases """
("__exit__", run_context, swallow, set(), {"__enter__" : iden}),
("__complex__", complex, complex_num, set(), {}),
("__format__", format, format_impl, set(), {}),
("__dir__", dir, empty_seq, set(), {}),
]
class Checker(object):

View File

@ -9,6 +9,9 @@ What's New in Python 2.7.2?
Core and Builtins
-----------------
- Correct lookup of __dir__ on objects. Among other things, this causes errors
besides AttributeError found on lookup to be propagated.
- Issue #1195: Fix input() if it is interrupted by CTRL+d and then CTRL+c,
clear the end-of-file indicator after CTRL+d.

View File

@ -1905,11 +1905,13 @@ static PyObject *
_dir_object(PyObject *obj)
{
PyObject *result = NULL;
PyObject *dirfunc = PyObject_GetAttrString((PyObject *)obj->ob_type,
"__dir__");
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))
@ -1921,7 +1923,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;