py: Fix 2 bugs in native emitter: jump_or_pop and stack settling.
Addresses issue #838.
This commit is contained in:
parent
eb4e18f057
commit
02d95d7ce9
@ -503,6 +503,7 @@ STATIC void need_stack_settled(emit_t *emit) {
|
|||||||
for (int i = 0; i < emit->stack_size; i++) {
|
for (int i = 0; i < emit->stack_size; i++) {
|
||||||
stack_info_t *si = &emit->stack_info[i];
|
stack_info_t *si = &emit->stack_info[i];
|
||||||
if (si->kind == STACK_IMM) {
|
if (si->kind == STACK_IMM) {
|
||||||
|
si->kind = STACK_VALUE;
|
||||||
ASM_MOV_IMM_TO_LOCAL_USING(si->u_imm, emit->stack_start + i, REG_TEMP0);
|
ASM_MOV_IMM_TO_LOCAL_USING(si->u_imm, emit->stack_start + i, REG_TEMP0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1131,10 +1132,10 @@ STATIC void emit_native_jump_helper(emit_t *emit, uint label, bool pop) {
|
|||||||
}
|
}
|
||||||
} else if (vtype == VTYPE_PYOBJ) {
|
} else if (vtype == VTYPE_PYOBJ) {
|
||||||
emit_pre_pop_reg(emit, &vtype, REG_ARG_1);
|
emit_pre_pop_reg(emit, &vtype, REG_ARG_1);
|
||||||
emit_call(emit, MP_F_OBJ_IS_TRUE);
|
|
||||||
if (!pop) {
|
if (!pop) {
|
||||||
emit_post_push_reg(emit, VTYPE_PYOBJ, REG_RET);
|
adjust_stack(emit, 1);
|
||||||
}
|
}
|
||||||
|
emit_call(emit, MP_F_OBJ_IS_TRUE);
|
||||||
} else {
|
} else {
|
||||||
printf("ViperTypeError: expecting a bool or pyobj, got %d\n", vtype);
|
printf("ViperTypeError: expecting a bool or pyobj, got %d\n", vtype);
|
||||||
assert(0);
|
assert(0);
|
||||||
|
5
tests/basics/andor.py
Normal file
5
tests/basics/andor.py
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# test short circuit expressions outside if conditionals
|
||||||
|
print(() or 1)
|
||||||
|
print((1,) or 1)
|
||||||
|
print(() and 1)
|
||||||
|
print((1,) and 1)
|
35
tests/basics/ifcond.py
Normal file
35
tests/basics/ifcond.py
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# test if conditions which are optimised by the compiler
|
||||||
|
|
||||||
|
f2 = 0
|
||||||
|
|
||||||
|
def f(t1, t2, f1):
|
||||||
|
if False:
|
||||||
|
print(1)
|
||||||
|
if True:
|
||||||
|
print(1)
|
||||||
|
if ():
|
||||||
|
print(1)
|
||||||
|
if (1,):
|
||||||
|
print(1)
|
||||||
|
if (1, 2):
|
||||||
|
print(1)
|
||||||
|
if t1 and t2:
|
||||||
|
print(1)
|
||||||
|
if (t1 and t2): # parsed differently to above
|
||||||
|
print(1)
|
||||||
|
if not (t1 and f1):
|
||||||
|
print(1)
|
||||||
|
if t1 or t2:
|
||||||
|
print(1)
|
||||||
|
if (t1 or t2): # parse differently to above
|
||||||
|
print(1)
|
||||||
|
if f1 or t1:
|
||||||
|
print(1)
|
||||||
|
if not (f1 or f2):
|
||||||
|
print(1)
|
||||||
|
if t1 and f1 or t1 and t2:
|
||||||
|
print(1)
|
||||||
|
if (f1 or t1) and (f2 or t2):
|
||||||
|
print(1)
|
||||||
|
|
||||||
|
f(True, 1, False)
|
Loading…
Reference in New Issue
Block a user