diff options
author | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2016-04-28 01:54:23 +0300 |
---|---|---|
committer | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2016-04-28 02:08:43 +0300 |
commit | eff85bb1dcca0602cef055986ea3b8192dea1d71 (patch) | |
tree | 679500b7f6741516eca8e03917f3ea70ca379376 /py | |
parent | d54290f6e270818379e0ae8f608d62d25b7e3dea (diff) | |
download | micropython-eff85bb1dcca0602cef055986ea3b8192dea1d71.tar.gz micropython-eff85bb1dcca0602cef055986ea3b8192dea1d71.zip |
py/vm: "yield from" didn't handle MP_OBJ_STOP_ITERATION optimization.
E.g. crashed when yielding from already stopped generators.
Diffstat (limited to 'py')
-rw-r--r-- | py/objgenerator.c | 1 | ||||
-rw-r--r-- | py/vm.c | 3 |
2 files changed, 3 insertions, 1 deletions
diff --git a/py/objgenerator.c b/py/objgenerator.c index 93df7ce13f..2480b0a4b8 100644 --- a/py/objgenerator.c +++ b/py/objgenerator.c @@ -99,6 +99,7 @@ mp_vm_return_kind_t mp_obj_gen_resume(mp_obj_t self_in, mp_obj_t send_value, mp_ assert(MP_OBJ_IS_TYPE(self_in, &mp_type_gen_instance)); mp_obj_gen_instance_t *self = MP_OBJ_TO_PTR(self_in); if (self->code_state.ip == 0) { + // Trying to resume already stopped generator *ret_val = MP_OBJ_STOP_ITERATION; return MP_VM_RETURN_NORMAL; } @@ -1144,7 +1144,8 @@ yield: if (ret_kind == MP_VM_RETURN_NORMAL) { // Pop exhausted gen sp--; - if (ret_value == MP_OBJ_NULL) { + // TODO: When ret_value can be MP_OBJ_NULL here?? + if (ret_value == MP_OBJ_NULL || ret_value == MP_OBJ_STOP_ITERATION) { // Optimize StopIteration // TODO: get StopIteration's value PUSH(mp_const_none); |