Commit 7963a35b authored by Benjamin Peterson's avatar Benjamin Peterson

correctly lookup __dir__

parent 2cca0572
......@@ -1595,6 +1595,7 @@ order (MRO) for bases """
# probably not worth it.
# ("__enter__", run_context, iden),
# ("__exit__", run_context, iden),
("__dir__", dir, empty_seq, set(), {}),
]
class Checker(object):
......
......@@ -10,6 +10,9 @@ What's New in Python 3.1.4?
Core and Builtins
-----------------
- Correct lookup of __dir__ on objects. Among other things, this causes errors
besides AttributeError found on lookup to be propagated.
- Issue #12060: Use sig_atomic_t type and volatile keyword in the signal
module. Patch written by Charles-François Natali.
......
......@@ -1348,14 +1348,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))
......@@ -1365,7 +1366,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;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment