rt_load_method(): Add missing qstr_str() when getting type name.

This commit is contained in:
Paul Sokolovsky 2014-03-25 00:55:39 +02:00
parent da5e269e51
commit 7f8b31345b
2 changed files with 7 additions and 1 deletions

View File

@ -1001,7 +1001,8 @@ void rt_load_method(mp_obj_t base, qstr attr, mp_obj_t *dest) {
// no attribute/method called attr // no attribute/method called attr
// following CPython, we give a more detailed error message for type objects // following CPython, we give a more detailed error message for type objects
if (MP_OBJ_IS_TYPE(base, &mp_type_type)) { if (MP_OBJ_IS_TYPE(base, &mp_type_type)) {
nlr_jump(mp_obj_new_exception_msg_varg(&mp_type_AttributeError, "type object '%s' has no attribute '%s'", ((mp_obj_type_t*)base)->name, qstr_str(attr))); nlr_jump(mp_obj_new_exception_msg_varg(&mp_type_AttributeError,
"type object '%s' has no attribute '%s'", qstr_str(((mp_obj_type_t*)base)->name), qstr_str(attr)));
} else { } else {
nlr_jump(mp_obj_new_exception_msg_varg(&mp_type_AttributeError, "'%s' object has no attribute '%s'", mp_obj_get_type_str(base), qstr_str(attr))); nlr_jump(mp_obj_new_exception_msg_varg(&mp_type_AttributeError, "'%s' object has no attribute '%s'", mp_obj_get_type_str(base), qstr_str(attr)));
} }

View File

@ -26,3 +26,8 @@ print(type(()) == tuple)
print(type([]) == list) print(type([]) == list)
print(type({None}) == set) print(type({None}) == set)
print(type({}) == dict) print(type({}) == dict)
try:
bool.foo
except AttributeError:
print("AttributeError")