summaryrefslogtreecommitdiff
path: root/py/modbuiltins.c
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2018-05-10 23:03:30 +1000
committerDamien George <damien.p.george@gmail.com>2018-05-10 23:03:30 +1000
commit529860643bc321267376272356886ef39c4c6bd1 (patch)
tree5b4dac5760e2b498a5be83aaa9749ef958dd3aee /py/modbuiltins.c
parentbc87b862fd22afb38ed7392b69474286fa5fe19f (diff)
py/modbuiltins: Make built-in hasattr work properly for user types.
It now allows __getattr__ in a user type to raise AttributeError when the attribute does not exist.
Diffstat (limited to 'py/modbuiltins.c')
-rw-r--r--py/modbuiltins.c8
1 files changed, 1 insertions, 7 deletions
diff --git a/py/modbuiltins.c b/py/modbuiltins.c
index e45c714e9..2f3526415 100644
--- a/py/modbuiltins.c
+++ b/py/modbuiltins.c
@@ -525,14 +525,8 @@ MP_DEFINE_CONST_FUN_OBJ_2(mp_builtin_delattr_obj, mp_builtin_delattr);
STATIC mp_obj_t mp_builtin_hasattr(mp_obj_t object_in, mp_obj_t attr_in) {
qstr attr = mp_obj_str_get_qstr(attr_in);
-
mp_obj_t dest[2];
- // TODO: https://docs.python.org/3/library/functions.html?highlight=hasattr#hasattr
- // explicitly says "This is implemented by calling getattr(object, name) and seeing
- // whether it raises an AttributeError or not.", so we should explicitly wrap this
- // in nlr_push and handle exception.
- mp_load_method_maybe(object_in, attr, dest);
-
+ mp_load_method_protected(object_in, attr, dest, false);
return mp_obj_new_bool(dest[0] != MP_OBJ_NULL);
}
MP_DEFINE_CONST_FUN_OBJ_2(mp_builtin_hasattr_obj, mp_builtin_hasattr);