Crude attempt to implement RAISE_VARARGS (with args=1 so far only).

pull/135/head
Paul Sokolovsky 2014-01-10 16:09:55 +02:00
rodzic bab5cfb34f
commit 5388a3c29a
2 zmienionych plików z 12 dodań i 0 usunięć

Wyświetl plik

@ -474,6 +474,13 @@ bool mp_execute_byte_code_2(const byte **ip_in_out, mp_obj_t *fastn, mp_obj_t **
assert(exc_sp == &exc_stack[0] - 1);
return false;
case MP_BC_RAISE_VARARGS:
unum = *ip++;
assert(unum == 1);
obj1 = POP();
nlr_jump(obj1);
return false;
case MP_BC_YIELD_VALUE:
nlr_pop();
*ip_in_out = ip;

Wyświetl plik

@ -4,3 +4,8 @@ try:
x.a()
except:
print(x)
try:
raise IndexError
except IndexError:
print("caught")