various: Use mp_obj_get_type_qstr more widely
This removes runtime allocations of the cstring version of the qstring. It is not a size improvement
This commit is contained in:
parent
c37a25f0e5
commit
89797fd3f9
@ -42,7 +42,7 @@ const byte fresult_to_errno_table[20] = {
|
|||||||
|
|
||||||
STATIC void file_obj_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
|
STATIC void file_obj_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
|
||||||
(void)kind;
|
(void)kind;
|
||||||
mp_printf(print, "<io.%s %p>", mp_obj_get_type_str(self_in), MP_OBJ_TO_PTR(self_in));
|
mp_printf(print, "<io.%q %p>", mp_obj_get_type_qstr(self_in), MP_OBJ_TO_PTR(self_in));
|
||||||
}
|
}
|
||||||
|
|
||||||
STATIC mp_uint_t file_obj_read(mp_obj_t self_in, void *buf, mp_uint_t size, int *errcode) {
|
STATIC mp_uint_t file_obj_read(mp_obj_t self_in, void *buf, mp_uint_t size, int *errcode) {
|
||||||
|
@ -34,7 +34,7 @@ STATIC void check_fd_is_open(const mp_obj_vfs_posix_file_t *o) {
|
|||||||
STATIC void vfs_posix_file_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
|
STATIC void vfs_posix_file_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
|
||||||
(void)kind;
|
(void)kind;
|
||||||
mp_obj_vfs_posix_file_t *self = MP_OBJ_TO_PTR(self_in);
|
mp_obj_vfs_posix_file_t *self = MP_OBJ_TO_PTR(self_in);
|
||||||
mp_printf(print, "<io.%s %d>", mp_obj_get_type_str(self_in), self->fd);
|
mp_printf(print, "<io.%q %d>", mp_obj_get_type_qstr(self_in), self->fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
mp_obj_t mp_vfs_posix_file_open(const mp_obj_type_t *type, mp_obj_t file_in, mp_obj_t mode_in) {
|
mp_obj_t mp_vfs_posix_file_open(const mp_obj_type_t *type, mp_obj_t file_in, mp_obj_t mode_in) {
|
||||||
|
@ -60,7 +60,7 @@ extern const mp_obj_type_t mp_type_textio;
|
|||||||
STATIC void fdfile_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
|
STATIC void fdfile_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
|
||||||
(void)kind;
|
(void)kind;
|
||||||
mp_obj_fdfile_t *self = MP_OBJ_TO_PTR(self_in);
|
mp_obj_fdfile_t *self = MP_OBJ_TO_PTR(self_in);
|
||||||
mp_printf(print, "<io.%s %d>", mp_obj_get_type_str(self_in), self->fd);
|
mp_printf(print, "<io.%q %d>", mp_obj_get_type_qstr(self_in), self->fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
STATIC mp_uint_t fdfile_read(mp_obj_t o_in, void *buf, mp_uint_t size, int *errcode) {
|
STATIC mp_uint_t fdfile_read(mp_obj_t o_in, void *buf, mp_uint_t size, int *errcode) {
|
||||||
|
14
py/obj.c
14
py/obj.c
@ -381,7 +381,7 @@ void mp_obj_get_array(mp_obj_t o, size_t *len, mp_obj_t **items) {
|
|||||||
mp_raise_TypeError(translate("expected tuple/list"));
|
mp_raise_TypeError(translate("expected tuple/list"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("object '%s' is not a tuple or list"), mp_obj_get_type_str(o));
|
translate("object '%q' is not a tuple or list"), mp_obj_get_type_qstr(o));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -410,8 +410,8 @@ size_t mp_get_index(const mp_obj_type_t *type, size_t len, mp_obj_t index, bool
|
|||||||
mp_raise_TypeError(translate("indices must be integers"));
|
mp_raise_TypeError(translate("indices must be integers"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("%q indices must be integers, not %s"),
|
translate("%q indices must be integers, not %q"),
|
||||||
type->name, mp_obj_get_type_str(index));
|
type->name, mp_obj_get_type_qstr(index));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -465,7 +465,7 @@ mp_obj_t mp_obj_len(mp_obj_t o_in) {
|
|||||||
mp_raise_TypeError(translate("object has no len"));
|
mp_raise_TypeError(translate("object has no len"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("object of type '%s' has no len()"), mp_obj_get_type_str(o_in));
|
translate("object of type '%q' has no len()"), mp_obj_get_type_qstr(o_in));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return len;
|
return len;
|
||||||
@ -508,21 +508,21 @@ mp_obj_t mp_obj_subscr(mp_obj_t base, mp_obj_t index, mp_obj_t value) {
|
|||||||
mp_raise_TypeError(translate("object does not support item deletion"));
|
mp_raise_TypeError(translate("object does not support item deletion"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("'%s' object does not support item deletion"), mp_obj_get_type_str(base));
|
translate("'%q' object does not support item deletion"), mp_obj_get_type_qstr(base));
|
||||||
}
|
}
|
||||||
} else if (value == MP_OBJ_SENTINEL) {
|
} else if (value == MP_OBJ_SENTINEL) {
|
||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("object is not subscriptable"));
|
mp_raise_TypeError(translate("object is not subscriptable"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("'%s' object is not subscriptable"), mp_obj_get_type_str(base));
|
translate("'%q' object is not subscriptable"), mp_obj_get_type_qstr(base));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("object does not support item assignment"));
|
mp_raise_TypeError(translate("object does not support item assignment"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("'%s' object does not support item assignment"), mp_obj_get_type_str(base));
|
translate("'%q' object does not support item assignment"), mp_obj_get_type_qstr(base));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
14
py/objstr.c
14
py/objstr.c
@ -1280,8 +1280,8 @@ STATIC vstr_t mp_obj_str_format_helper(const char *str, const char *top, int *ar
|
|||||||
terse_str_format_value_error();
|
terse_str_format_value_error();
|
||||||
} else {
|
} else {
|
||||||
mp_raise_ValueError_varg(
|
mp_raise_ValueError_varg(
|
||||||
translate("unknown format code '%c' for object of type '%s'"),
|
translate("unknown format code '%c' for object of type '%q'"),
|
||||||
type, mp_obj_get_type_str(arg));
|
type, mp_obj_get_type_qstr(arg));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1352,8 +1352,8 @@ STATIC vstr_t mp_obj_str_format_helper(const char *str, const char *top, int *ar
|
|||||||
terse_str_format_value_error();
|
terse_str_format_value_error();
|
||||||
} else {
|
} else {
|
||||||
mp_raise_ValueError_varg(
|
mp_raise_ValueError_varg(
|
||||||
translate("unknown format code '%c' for object of type '%s'"),
|
translate("unknown format code '%c' for object of type '%q'"),
|
||||||
type, mp_obj_get_type_str(arg));
|
type, mp_obj_get_type_qstr(arg));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -1388,8 +1388,8 @@ STATIC vstr_t mp_obj_str_format_helper(const char *str, const char *top, int *ar
|
|||||||
terse_str_format_value_error();
|
terse_str_format_value_error();
|
||||||
} else {
|
} else {
|
||||||
mp_raise_ValueError_varg(
|
mp_raise_ValueError_varg(
|
||||||
translate("unknown format code '%c' for object of type '%s'"),
|
translate("unknown format code '%c' for object of type '%q'"),
|
||||||
type, mp_obj_get_type_str(arg));
|
type, mp_obj_get_type_qstr(arg));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2133,7 +2133,7 @@ STATIC NORETURN void bad_implicit_conversion(mp_obj_t self_in) {
|
|||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("can't convert to str implicitly"));
|
mp_raise_TypeError(translate("can't convert to str implicitly"));
|
||||||
} else {
|
} else {
|
||||||
const qstr src_name = mp_obj_get_type(self_in)->name;
|
const qstr src_name = mp_obj_get_type_qstr(self_in);
|
||||||
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_TypeError,
|
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_TypeError,
|
||||||
translate("can't convert '%q' object to %q implicitly"),
|
translate("can't convert '%q' object to %q implicitly"),
|
||||||
src_name, src_name == MP_QSTR_str ? MP_QSTR_bytes : MP_QSTR_str));
|
src_name, src_name == MP_QSTR_str ? MP_QSTR_bytes : MP_QSTR_str));
|
||||||
|
@ -151,7 +151,7 @@ const byte *str_index_to_ptr(const mp_obj_type_t *type, const byte *self_data, s
|
|||||||
if (MP_OBJ_IS_SMALL_INT(index)) {
|
if (MP_OBJ_IS_SMALL_INT(index)) {
|
||||||
i = MP_OBJ_SMALL_INT_VALUE(index);
|
i = MP_OBJ_SMALL_INT_VALUE(index);
|
||||||
} else if (!mp_obj_get_int_maybe(index, &i)) {
|
} else if (!mp_obj_get_int_maybe(index, &i)) {
|
||||||
mp_raise_TypeError_varg(translate("string indices must be integers, not %s"), mp_obj_get_type_str(index));
|
mp_raise_TypeError_varg(translate("string indices must be integers, not %q"), mp_obj_get_type_qstr(index));
|
||||||
}
|
}
|
||||||
const byte *s, *top = self_data + self_len;
|
const byte *s, *top = self_data + self_len;
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
|
12
py/objtype.c
12
py/objtype.c
@ -193,7 +193,7 @@ STATIC void mp_obj_class_lookup(struct class_lookup_data *lookup, const mp_obj_
|
|||||||
printf("mp_obj_class_lookup: Returning: ");
|
printf("mp_obj_class_lookup: Returning: ");
|
||||||
mp_obj_print(lookup->dest[0], PRINT_REPR); printf(" ");
|
mp_obj_print(lookup->dest[0], PRINT_REPR); printf(" ");
|
||||||
// Don't try to repr() lookup->dest[1], as we can be called recursively
|
// Don't try to repr() lookup->dest[1], as we can be called recursively
|
||||||
printf("<%s @%p>\n", mp_obj_get_type_str(lookup->dest[1]), lookup->dest[1]);
|
printf("<%q @%p>\n", mp_obj_get_type_qstr(lookup->dest[1]), lookup->dest[1]);
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -285,7 +285,7 @@ STATIC void instance_print(const mp_print_t *print, mp_obj_t self_in, mp_print_k
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO: CPython prints fully-qualified type name
|
// TODO: CPython prints fully-qualified type name
|
||||||
mp_printf(print, "<%s object at %p>", mp_obj_get_type_str(self_in), self);
|
mp_printf(print, "<%q object at %p>", mp_obj_get_type_qstr(self_in), self);
|
||||||
}
|
}
|
||||||
|
|
||||||
mp_obj_t mp_obj_instance_make_new(const mp_obj_type_t *self, size_t n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
mp_obj_t mp_obj_instance_make_new(const mp_obj_type_t *self, size_t n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
@ -376,8 +376,8 @@ mp_obj_t mp_obj_instance_make_new(const mp_obj_type_t *self, size_t n_args, cons
|
|||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("__init__() should return None"));
|
mp_raise_TypeError(translate("__init__() should return None"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(translate("__init__() should return None, not '%s'"),
|
mp_raise_TypeError_varg(translate("__init__() should return None, not '%q'"),
|
||||||
mp_obj_get_type_str(init_ret));
|
mp_obj_get_type_qstr(init_ret));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -891,8 +891,8 @@ mp_obj_t mp_obj_instance_call(mp_obj_t self_in, size_t n_args, size_t n_kw, cons
|
|||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("object not callable"));
|
mp_raise_TypeError(translate("object not callable"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(translate("'%s' object is not callable"),
|
mp_raise_TypeError_varg(translate("'%q' object is not callable"),
|
||||||
mp_obj_get_type_str(self_in));
|
mp_obj_get_type_qstr(self_in));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mp_obj_instance_t *self = MP_OBJ_TO_PTR(self_in);
|
mp_obj_instance_t *self = MP_OBJ_TO_PTR(self_in);
|
||||||
|
@ -45,6 +45,6 @@ const void *mp_proto_get_or_throw(uint16_t name, mp_const_obj_t obj) {
|
|||||||
if (proto) {
|
if (proto) {
|
||||||
return proto;
|
return proto;
|
||||||
}
|
}
|
||||||
mp_raise_TypeError_varg(translate("'%s' object does not support '%q'"),
|
mp_raise_TypeError_varg(translate("'%q' object does not support '%q'"),
|
||||||
mp_obj_get_type_str(obj), name);
|
mp_obj_get_type_qstr(obj), name);
|
||||||
}
|
}
|
||||||
|
28
py/runtime.c
28
py/runtime.c
@ -279,8 +279,8 @@ mp_obj_t mp_unary_op(mp_unary_op_t op, mp_obj_t arg) {
|
|||||||
mp_raise_TypeError(translate("unsupported type for operator"));
|
mp_raise_TypeError(translate("unsupported type for operator"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("unsupported type for %q: '%s'"),
|
translate("unsupported type for %q: '%q'"),
|
||||||
mp_unary_op_method_name[op], mp_obj_get_type_str(arg));
|
mp_unary_op_method_name[op], mp_obj_get_type_qstr(arg));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -586,8 +586,8 @@ unsupported_op:
|
|||||||
mp_raise_TypeError(translate("unsupported type for operator"));
|
mp_raise_TypeError(translate("unsupported type for operator"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("unsupported types for %q: '%s', '%s'"),
|
translate("unsupported types for %q: '%q', '%q'"),
|
||||||
mp_binary_op_method_name[op], mp_obj_get_type_str(lhs), mp_obj_get_type_str(rhs));
|
mp_binary_op_method_name[op], mp_obj_get_type_qstr(lhs), mp_obj_get_type_qstr(rhs));
|
||||||
}
|
}
|
||||||
|
|
||||||
zero_division:
|
zero_division:
|
||||||
@ -627,7 +627,7 @@ mp_obj_t mp_call_function_n_kw(mp_obj_t fun_in, size_t n_args, size_t n_kw, cons
|
|||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("object not callable"));
|
mp_raise_TypeError(translate("object not callable"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(translate("'%s' object is not callable"), mp_obj_get_type_str(fun_in));
|
mp_raise_TypeError_varg(translate("'%q' object is not callable"), mp_obj_get_type_qstr(fun_in));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1104,8 +1104,8 @@ void mp_load_method(mp_obj_t base, qstr attr, mp_obj_t *dest) {
|
|||||||
((mp_obj_type_t*)MP_OBJ_TO_PTR(base))->name, attr));
|
((mp_obj_type_t*)MP_OBJ_TO_PTR(base))->name, attr));
|
||||||
} else {
|
} else {
|
||||||
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_AttributeError,
|
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_AttributeError,
|
||||||
translate("'%s' object has no attribute '%q'"),
|
translate("'%q' object has no attribute '%q'"),
|
||||||
mp_obj_get_type_str(base), attr));
|
mp_obj_get_type_qstr(base), attr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1172,8 +1172,8 @@ void mp_store_attr(mp_obj_t base, qstr attr, mp_obj_t value) {
|
|||||||
mp_raise_AttributeError(translate("no such attribute"));
|
mp_raise_AttributeError(translate("no such attribute"));
|
||||||
} else {
|
} else {
|
||||||
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_AttributeError,
|
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_AttributeError,
|
||||||
translate("'%s' object cannot assign attribute '%q'"),
|
translate("'%q' object cannot assign attribute '%q'"),
|
||||||
mp_obj_get_type_str(base), attr));
|
mp_obj_get_type_qstr(base), attr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1213,7 +1213,7 @@ mp_obj_t mp_getiter(mp_obj_t o_in, mp_obj_iter_buf_t *iter_buf) {
|
|||||||
mp_raise_TypeError(translate("object not iterable"));
|
mp_raise_TypeError(translate("object not iterable"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(
|
mp_raise_TypeError_varg(
|
||||||
translate("'%s' object is not iterable"), mp_obj_get_type_str(o_in));
|
translate("'%q' object is not iterable"), mp_obj_get_type_qstr(o_in));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1234,8 +1234,8 @@ mp_obj_t mp_iternext_allow_raise(mp_obj_t o_in) {
|
|||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("object not an iterator"));
|
mp_raise_TypeError(translate("object not an iterator"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(translate("'%s' object is not an iterator"),
|
mp_raise_TypeError_varg(translate("'%q' object is not an iterator"),
|
||||||
mp_obj_get_type_str(o_in));
|
mp_obj_get_type_qstr(o_in));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1270,8 +1270,8 @@ mp_obj_t mp_iternext(mp_obj_t o_in) {
|
|||||||
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
|
||||||
mp_raise_TypeError(translate("object not an iterator"));
|
mp_raise_TypeError(translate("object not an iterator"));
|
||||||
} else {
|
} else {
|
||||||
mp_raise_TypeError_varg(translate("'%s' object is not an iterator"),
|
mp_raise_TypeError_varg(translate("'%q' object is not an iterator"),
|
||||||
mp_obj_get_type_str(o_in));
|
mp_obj_get_type_qstr(o_in));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user