Commit 69da74e5 authored by Damien George's avatar Damien George

py/modbuiltins: Use existing utf8_get_char helper in builtin ord func.

parent dc948e4d
...@@ -348,31 +348,16 @@ STATIC mp_obj_t mp_builtin_ord(mp_obj_t o_in) { ...@@ -348,31 +348,16 @@ STATIC mp_obj_t mp_builtin_ord(mp_obj_t o_in) {
if (MP_OBJ_IS_STR(o_in)) { if (MP_OBJ_IS_STR(o_in)) {
len = unichar_charlen(str, len); len = unichar_charlen(str, len);
if (len == 1) { if (len == 1) {
if (!UTF8_IS_NONASCII(*str)) { return mp_obj_new_int(utf8_get_char((const byte*)str));
goto return_first_byte;
}
mp_int_t ord = *str++ & 0x7F;
for (mp_int_t mask = 0x40; ord & mask; mask >>= 1) {
ord &= ~mask;
}
while (UTF8_IS_CONT(*str)) {
ord = (ord << 6) | (*str++ & 0x3F);
}
return mp_obj_new_int(ord);
} }
} else { } else
// a bytes object #endif
{
// a bytes object, or a str without unicode support (don't sign extend the char)
if (len == 1) { if (len == 1) {
return_first_byte:
return MP_OBJ_NEW_SMALL_INT(((const byte*)str)[0]); return MP_OBJ_NEW_SMALL_INT(((const byte*)str)[0]);
} }
} }
#else
if (len == 1) {
// don't sign extend when converting to ord
return mp_obj_new_int(((const byte*)str)[0]);
}
#endif
if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) { if (MICROPY_ERROR_REPORTING == MICROPY_ERROR_REPORTING_TERSE) {
mp_raise_TypeError("ord expects a character"); mp_raise_TypeError("ord expects a character");
......
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