diff options
author | Damien George <damien.p.george@gmail.com> | 2016-01-03 16:27:55 +0000 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2016-01-03 16:27:55 +0000 |
commit | 8212d97317b6e0c23c49a4ea34dbdb957f380789 (patch) | |
tree | b03b0ac793306aa102828945aab270ccaac90ac8 /py/objstr.c | |
parent | 17f324b83655e68b064f0637f5190000ea0e1f12 (diff) | |
download | micropython-8212d97317b6e0c23c49a4ea34dbdb957f380789.tar.gz micropython-8212d97317b6e0c23c49a4ea34dbdb957f380789.zip |
py: Use polymorphic iterator type where possible to reduce code size.
Only types whose iterator instances still fit in 4 machine words have
been changed to use the polymorphic iterator.
Reduces Thumb2 arch code size by 264 bytes.
Diffstat (limited to 'py/objstr.c')
-rw-r--r-- | py/objstr.c | 21 |
1 files changed, 5 insertions, 16 deletions
diff --git a/py/objstr.c b/py/objstr.c index 7315f40020..8839acbf95 100644 --- a/py/objstr.c +++ b/py/objstr.c @@ -2061,6 +2061,7 @@ const byte *mp_obj_str_get_data_no_check(mp_obj_t self_in, size_t *len) { typedef struct _mp_obj_str8_it_t { mp_obj_base_t base; + mp_fun_1_t iternext; mp_obj_t str; mp_uint_t cur; } mp_obj_str8_it_t; @@ -2078,16 +2079,10 @@ STATIC mp_obj_t str_it_iternext(mp_obj_t self_in) { } } -STATIC const mp_obj_type_t mp_type_str_it = { - { &mp_type_type }, - .name = MP_QSTR_iterator, - .getiter = mp_identity, - .iternext = str_it_iternext, -}; - STATIC mp_obj_t mp_obj_new_str_iterator(mp_obj_t str) { mp_obj_str8_it_t *o = m_new_obj(mp_obj_str8_it_t); - o->base.type = &mp_type_str_it; + o->base.type = &mp_type_polymorph_iter; + o->iternext = str_it_iternext; o->str = str; o->cur = 0; return o; @@ -2106,16 +2101,10 @@ STATIC mp_obj_t bytes_it_iternext(mp_obj_t self_in) { } } -STATIC const mp_obj_type_t mp_type_bytes_it = { - { &mp_type_type }, - .name = MP_QSTR_iterator, - .getiter = mp_identity, - .iternext = bytes_it_iternext, -}; - mp_obj_t mp_obj_new_bytes_iterator(mp_obj_t str) { mp_obj_str8_it_t *o = m_new_obj(mp_obj_str8_it_t); - o->base.type = &mp_type_bytes_it; + o->base.type = &mp_type_polymorph_iter; + o->iternext = bytes_it_iternext; o->str = str; o->cur = 0; return MP_OBJ_FROM_PTR(o); |