py/objarray: Detect bytearray(str) without an encoding.
This prevents a very subtle bug caused by writing e.g. `bytearray('\xfd')` which gives you `(0xc3, 0xbd)`. This work was funded through GitHub Sponsors. Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
This commit is contained in:
parent
f8b0ae32d3
commit
2c8dab7ab4
|
@ -192,6 +192,14 @@ STATIC mp_obj_t bytearray_make_new(const mp_obj_type_t *type_in, size_t n_args,
|
|||
return MP_OBJ_FROM_PTR(o);
|
||||
} else {
|
||||
// 1 arg: construct the bytearray from that
|
||||
if (mp_obj_is_str(args[0]) && n_args == 1) {
|
||||
#if MICROPY_ERROR_REPORTING <= MICROPY_ERROR_REPORTING_TERSE
|
||||
// Match bytes_make_new.
|
||||
mp_raise_TypeError(MP_ERROR_TEXT("wrong number of arguments"));
|
||||
#else
|
||||
mp_raise_TypeError(MP_ERROR_TEXT("string argument without an encoding"));
|
||||
#endif
|
||||
}
|
||||
return array_construct(BYTEARRAY_TYPECODE, args[0]);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -233,7 +233,11 @@ STATIC mp_obj_t bytes_make_new(const mp_obj_type_t *type_in, size_t n_args, size
|
|||
|
||||
if (mp_obj_is_str(args[0])) {
|
||||
if (n_args < 2 || n_args > 3) {
|
||||
#if MICROPY_ERROR_REPORTING <= MICROPY_ERROR_REPORTING_TERSE
|
||||
goto wrong_args;
|
||||
#else
|
||||
mp_raise_TypeError(MP_ERROR_TEXT("string argument without an encoding"));
|
||||
#endif
|
||||
}
|
||||
GET_STR_DATA_LEN(args[0], str_data, str_len);
|
||||
GET_STR_HASH(args[0], str_hash);
|
||||
|
|
|
@ -5,3 +5,8 @@ print(bytearray('1234', 'utf-8'))
|
|||
print(bytearray('12345', 'utf-8', 'strict'))
|
||||
print(bytearray((1, 2)))
|
||||
print(bytearray([1, 2]))
|
||||
|
||||
try:
|
||||
print(bytearray('1234'))
|
||||
except TypeError:
|
||||
print("TypeError")
|
||||
|
|
|
@ -21,7 +21,7 @@ def memsum(src: ptr8, n: int) -> int:
|
|||
|
||||
|
||||
# create array and get its address
|
||||
ar = bytearray("0000")
|
||||
ar = bytearray(b"0000")
|
||||
addr = get_addr(ar)
|
||||
print(type(ar))
|
||||
print(type(addr))
|
||||
|
|
Loading…
Reference in New Issue