summaryrefslogtreecommitdiff
path: root/py
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-03-31 04:19:12 +0300
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-03-31 17:22:37 +0300
commit7da0660516e1406808ad212d35faa95de3316fc4 (patch)
tree58a042e14fa21995c3c83758c8113c8e9411d594 /py
parenta2109d93210c391d45a0ced2ce8a85f2471d3543 (diff)
mp_resume: Dare to pass send_value of NULL.
There was thinkos that either send_value or throw_value is specified, but there were cases with both. Note that send_value is pushed onto generator's stack - but that's probably only good, because if we throw exception into gen, it should not ever use send_value, and that will be just extra "assert".
Diffstat (limited to 'py')
-rw-r--r--py/runtime.c1
-rw-r--r--py/vm.c2
2 files changed, 2 insertions, 1 deletions
diff --git a/py/runtime.c b/py/runtime.c
index f7e08e37f..65bb808a9 100644
--- a/py/runtime.c
+++ b/py/runtime.c
@@ -915,6 +915,7 @@ mp_obj_t mp_iternext(mp_obj_t o_in) {
// TODO: Unclear what to do with StopIterarion exception here.
mp_vm_return_kind_t mp_resume(mp_obj_t self_in, mp_obj_t send_value, mp_obj_t throw_value, mp_obj_t *ret_val) {
+ assert((send_value != MP_OBJ_NULL) ^ (throw_value != MP_OBJ_NULL));
mp_obj_type_t *type = mp_obj_get_type(self_in);
if (type == &mp_type_gen_instance) {
diff --git a/py/vm.c b/py/vm.c
index 599a1d862..3ffeb138c 100644
--- a/py/vm.c
+++ b/py/vm.c
@@ -764,7 +764,7 @@ yield:
if (inject_exc != MP_OBJ_NULL) {
t_exc = inject_exc;
inject_exc = MP_OBJ_NULL;
- ret_kind = mp_resume(TOP(), mp_const_none, t_exc, &obj2);
+ ret_kind = mp_resume(TOP(), MP_OBJ_NULL, t_exc, &obj2);
} else {
ret_kind = mp_resume(TOP(), obj1, MP_OBJ_NULL, &obj2);
}