| [case testForInRange] |
| def f() -> None: |
| x = 0 |
| for i in range(5): |
| x = x + i |
| [out] |
| def f(): |
| x :: int |
| r0 :: short_int |
| i :: int |
| r1 :: bit |
| r2 :: int |
| r3 :: short_int |
| L0: |
| x = 0 |
| r0 = 0 |
| i = r0 |
| L1: |
| r1 = int_lt r0, 10 |
| if r1 goto L2 else goto L4 :: bool |
| L2: |
| r2 = CPyTagged_Add(x, i) |
| x = r2 |
| L3: |
| r3 = r0 + 2 |
| r0 = r3 |
| i = r3 |
| goto L1 |
| L4: |
| return 1 |
| |
| [case testForInRangeVariableEndIndxe] |
| def f(a: int) -> None: |
| for i in range(a): |
| pass |
| [out] |
| def f(a): |
| a, r0, i :: int |
| r1 :: bit |
| r2 :: int |
| L0: |
| r0 = 0 |
| i = r0 |
| L1: |
| r1 = int_lt r0, a |
| if r1 goto L2 else goto L4 :: bool |
| L2: |
| L3: |
| r2 = CPyTagged_Add(r0, 2) |
| r0 = r2 |
| i = r2 |
| goto L1 |
| L4: |
| return 1 |
| |
| [case testForInNegativeRange] |
| def f() -> None: |
| for i in range(10, 0, -1): |
| pass |
| [out] |
| def f(): |
| r0 :: short_int |
| i :: int |
| r1 :: bit |
| r2 :: short_int |
| L0: |
| r0 = 20 |
| i = r0 |
| L1: |
| r1 = int_gt r0, 0 |
| if r1 goto L2 else goto L4 :: bool |
| L2: |
| L3: |
| r2 = r0 + -2 |
| r0 = r2 |
| i = r2 |
| goto L1 |
| L4: |
| return 1 |
| |
| [case testBreak] |
| def f() -> None: |
| n = 0 |
| while n < 5: |
| break |
| [out] |
| def f(): |
| n :: int |
| r0 :: bit |
| L0: |
| n = 0 |
| L1: |
| r0 = int_lt n, 10 |
| if r0 goto L2 else goto L3 :: bool |
| L2: |
| L3: |
| return 1 |
| |
| [case testBreakFor] |
| def f() -> None: |
| for n in range(5): |
| break |
| [out] |
| def f(): |
| r0 :: short_int |
| n :: int |
| r1 :: bit |
| r2 :: short_int |
| L0: |
| r0 = 0 |
| n = r0 |
| L1: |
| r1 = int_lt r0, 10 |
| if r1 goto L2 else goto L4 :: bool |
| L2: |
| goto L4 |
| L3: |
| r2 = r0 + 2 |
| r0 = r2 |
| n = r2 |
| goto L1 |
| L4: |
| return 1 |
| |
| [case testBreakNested] |
| def f() -> None: |
| n = 0 |
| while n < 5: |
| while n < 4: |
| break |
| break |
| [out] |
| def f(): |
| n :: int |
| r0, r1 :: bit |
| L0: |
| n = 0 |
| L1: |
| r0 = int_lt n, 10 |
| if r0 goto L2 else goto L6 :: bool |
| L2: |
| L3: |
| r1 = int_lt n, 8 |
| if r1 goto L4 else goto L5 :: bool |
| L4: |
| L5: |
| L6: |
| return 1 |
| |
| [case testContinue] |
| def f() -> None: |
| n = 0 |
| while n < 5: |
| continue |
| [out] |
| def f(): |
| n :: int |
| r0 :: bit |
| L0: |
| n = 0 |
| L1: |
| r0 = int_lt n, 10 |
| if r0 goto L2 else goto L3 :: bool |
| L2: |
| goto L1 |
| L3: |
| return 1 |
| |
| [case testContinueFor] |
| def f() -> None: |
| for n in range(5): |
| continue |
| [out] |
| def f(): |
| r0 :: short_int |
| n :: int |
| r1 :: bit |
| r2 :: short_int |
| L0: |
| r0 = 0 |
| n = r0 |
| L1: |
| r1 = int_lt r0, 10 |
| if r1 goto L2 else goto L4 :: bool |
| L2: |
| L3: |
| r2 = r0 + 2 |
| r0 = r2 |
| n = r2 |
| goto L1 |
| L4: |
| return 1 |
| |
| [case testContinueNested] |
| def f() -> None: |
| n = 0 |
| while n < 5: |
| while n < 4: |
| continue |
| continue |
| [out] |
| def f(): |
| n :: int |
| r0, r1 :: bit |
| L0: |
| n = 0 |
| L1: |
| r0 = int_lt n, 10 |
| if r0 goto L2 else goto L6 :: bool |
| L2: |
| L3: |
| r1 = int_lt n, 8 |
| if r1 goto L4 else goto L5 :: bool |
| L4: |
| goto L3 |
| L5: |
| goto L1 |
| L6: |
| return 1 |
| |
| [case testForList] |
| from typing import List |
| |
| def f(ls: List[int]) -> int: |
| y = 0 |
| for x in ls: |
| y = y + x |
| return y |
| [out] |
| def f(ls): |
| ls :: list |
| y :: int |
| r0, r1 :: native_int |
| r2 :: bit |
| r3 :: object |
| r4, x, r5 :: int |
| r6 :: native_int |
| L0: |
| y = 0 |
| r0 = 0 |
| L1: |
| r1 = var_object_size ls |
| r2 = r0 < r1 :: signed |
| if r2 goto L2 else goto L4 :: bool |
| L2: |
| r3 = list_get_item_unsafe ls, r0 |
| r4 = unbox(int, r3) |
| x = r4 |
| r5 = CPyTagged_Add(y, x) |
| y = r5 |
| L3: |
| r6 = r0 + 1 |
| r0 = r6 |
| goto L1 |
| L4: |
| return y |
| |
| [case testForDictBasic] |
| from typing import Dict |
| |
| def f(d: Dict[int, int]) -> None: |
| for key in d: |
| d[key] |
| [out] |
| def f(d): |
| d :: dict |
| r0 :: short_int |
| r1 :: native_int |
| r2 :: object |
| r3 :: tuple[bool, short_int, object] |
| r4 :: short_int |
| r5 :: bool |
| r6 :: object |
| r7, key :: int |
| r8, r9 :: object |
| r10 :: int |
| r11, r12 :: bit |
| L0: |
| r0 = 0 |
| r1 = PyDict_Size(d) |
| r2 = CPyDict_GetKeysIter(d) |
| L1: |
| r3 = CPyDict_NextKey(r2, r0) |
| r4 = r3[1] |
| r0 = r4 |
| r5 = r3[0] |
| if r5 goto L2 else goto L4 :: bool |
| L2: |
| r6 = r3[2] |
| r7 = unbox(int, r6) |
| key = r7 |
| r8 = box(int, key) |
| r9 = CPyDict_GetItem(d, r8) |
| r10 = unbox(int, r9) |
| L3: |
| r11 = CPyDict_CheckSize(d, r1) |
| goto L1 |
| L4: |
| r12 = CPy_NoErrOccurred() |
| L5: |
| return 1 |
| |
| [case testForDictContinue] |
| from typing import Dict |
| |
| def sum_over_even_values(d: Dict[int, int]) -> int: |
| s = 0 |
| for key in d: |
| if d[key] % 2: |
| continue |
| s = s + d[key] |
| return s |
| [out] |
| def sum_over_even_values(d): |
| d :: dict |
| s :: int |
| r0 :: short_int |
| r1 :: native_int |
| r2 :: object |
| r3 :: tuple[bool, short_int, object] |
| r4 :: short_int |
| r5 :: bool |
| r6 :: object |
| r7, key :: int |
| r8, r9 :: object |
| r10, r11 :: int |
| r12 :: bit |
| r13, r14 :: object |
| r15, r16 :: int |
| r17, r18 :: bit |
| L0: |
| s = 0 |
| r0 = 0 |
| r1 = PyDict_Size(d) |
| r2 = CPyDict_GetKeysIter(d) |
| L1: |
| r3 = CPyDict_NextKey(r2, r0) |
| r4 = r3[1] |
| r0 = r4 |
| r5 = r3[0] |
| if r5 goto L2 else goto L6 :: bool |
| L2: |
| r6 = r3[2] |
| r7 = unbox(int, r6) |
| key = r7 |
| r8 = box(int, key) |
| r9 = CPyDict_GetItem(d, r8) |
| r10 = unbox(int, r9) |
| r11 = CPyTagged_Remainder(r10, 4) |
| r12 = r11 != 0 |
| if r12 goto L3 else goto L4 :: bool |
| L3: |
| goto L5 |
| L4: |
| r13 = box(int, key) |
| r14 = CPyDict_GetItem(d, r13) |
| r15 = unbox(int, r14) |
| r16 = CPyTagged_Add(s, r15) |
| s = r16 |
| L5: |
| r17 = CPyDict_CheckSize(d, r1) |
| goto L1 |
| L6: |
| r18 = CPy_NoErrOccurred() |
| L7: |
| return s |
| |
| [case testMultipleAssignmentWithNoUnpacking] |
| from typing import Tuple |
| |
| def f(x: int, y: int) -> Tuple[int, int]: |
| x, y = y, x |
| return (x, y) |
| |
| def f2(x: int, y: str, z: float) -> Tuple[float, str, int]: |
| a, b, c = x, y, z |
| return (c, b, a) |
| |
| def f3(x: int, y: int) -> Tuple[int, int]: |
| [x, y] = [y, x] |
| return (x, y) |
| [out] |
| def f(x, y): |
| x, y, r0, r1 :: int |
| r2 :: tuple[int, int] |
| L0: |
| r0 = y |
| r1 = x |
| x = r0 |
| y = r1 |
| r2 = (x, y) |
| return r2 |
| def f2(x, y, z): |
| x :: int |
| y :: str |
| z :: float |
| r0 :: int |
| r1 :: str |
| r2 :: float |
| a :: int |
| b :: str |
| c :: float |
| r3 :: tuple[float, str, int] |
| L0: |
| r0 = x |
| r1 = y |
| r2 = z |
| a = r0 |
| b = r1 |
| c = r2 |
| r3 = (c, b, a) |
| return r3 |
| def f3(x, y): |
| x, y, r0, r1 :: int |
| r2 :: tuple[int, int] |
| L0: |
| r0 = y |
| r1 = x |
| x = r0 |
| y = r1 |
| r2 = (x, y) |
| return r2 |
| |
| [case testMultipleAssignmentBasicUnpacking] |
| from typing import Tuple, Any |
| |
| def from_tuple(t: Tuple[bool, None]) -> None: |
| x, y = t |
| |
| def from_any(a: Any) -> None: |
| x, y = a |
| [out] |
| def from_tuple(t): |
| t :: tuple[bool, None] |
| r0, x :: bool |
| r1, y :: None |
| L0: |
| r0 = t[0] |
| x = r0 |
| r1 = t[1] |
| y = r1 |
| return 1 |
| def from_any(a): |
| a, r0, r1 :: object |
| r2 :: bool |
| x, r3 :: object |
| r4 :: bool |
| y, r5 :: object |
| r6 :: bool |
| L0: |
| r0 = PyObject_GetIter(a) |
| r1 = PyIter_Next(r0) |
| if is_error(r1) goto L1 else goto L2 |
| L1: |
| r2 = raise ValueError('not enough values to unpack') |
| unreachable |
| L2: |
| x = r1 |
| r3 = PyIter_Next(r0) |
| if is_error(r3) goto L3 else goto L4 |
| L3: |
| r4 = raise ValueError('not enough values to unpack') |
| unreachable |
| L4: |
| y = r3 |
| r5 = PyIter_Next(r0) |
| if is_error(r5) goto L6 else goto L5 |
| L5: |
| r6 = raise ValueError('too many values to unpack') |
| unreachable |
| L6: |
| return 1 |
| |
| [case testMultiAssignmentCoercions] |
| from typing import Tuple, Any |
| |
| def from_tuple(t: Tuple[int, Any]) -> None: |
| x: object |
| y: int |
| x, y = t |
| |
| def from_any(a: Any) -> None: |
| x: int |
| x, y = a |
| [out] |
| def from_tuple(t): |
| t :: tuple[int, object] |
| r0 :: int |
| r1 :: object |
| r2 :: int |
| r3, x, r4 :: object |
| r5, y :: int |
| L0: |
| r0 = borrow t[0] |
| r1 = borrow t[1] |
| keep_alive steal t |
| r2 = unborrow r0 |
| r3 = box(int, r2) |
| x = r3 |
| r4 = unborrow r1 |
| r5 = unbox(int, r4) |
| y = r5 |
| return 1 |
| def from_any(a): |
| a, r0, r1 :: object |
| r2 :: bool |
| r3, x :: int |
| r4 :: object |
| r5 :: bool |
| y, r6 :: object |
| r7 :: bool |
| L0: |
| r0 = PyObject_GetIter(a) |
| r1 = PyIter_Next(r0) |
| if is_error(r1) goto L1 else goto L2 |
| L1: |
| r2 = raise ValueError('not enough values to unpack') |
| unreachable |
| L2: |
| r3 = unbox(int, r1) |
| x = r3 |
| r4 = PyIter_Next(r0) |
| if is_error(r4) goto L3 else goto L4 |
| L3: |
| r5 = raise ValueError('not enough values to unpack') |
| unreachable |
| L4: |
| y = r4 |
| r6 = PyIter_Next(r0) |
| if is_error(r6) goto L6 else goto L5 |
| L5: |
| r7 = raise ValueError('too many values to unpack') |
| unreachable |
| L6: |
| return 1 |
| |
| [case testMultiAssignmentNested] |
| from typing import Tuple, Any, List |
| |
| class A: |
| x: int |
| |
| def multi_assign(t: Tuple[int, Tuple[str, Any]], a: A, l: List[str]) -> None: |
| z: int |
| a.x, (l[0], z) = t |
| [out] |
| def multi_assign(t, a, l): |
| t :: tuple[int, tuple[str, object]] |
| a :: __main__.A |
| l :: list |
| r0 :: int |
| r1 :: bool |
| r2 :: tuple[str, object] |
| r3 :: str |
| r4 :: bit |
| r5 :: object |
| r6, z :: int |
| L0: |
| r0 = t[0] |
| a.x = r0; r1 = is_error |
| r2 = t[1] |
| r3 = r2[0] |
| r4 = CPyList_SetItem(l, 0, r3) |
| r5 = r2[1] |
| r6 = unbox(int, r5) |
| z = r6 |
| return 1 |
| |
| [case testMultipleAssignmentUnpackFromSequence] |
| from typing import List, Tuple |
| |
| def f(l: List[int], t: Tuple[int, ...]) -> None: |
| x: object |
| y: int |
| x, y = l |
| x, y = t |
| [out] |
| def f(l, t): |
| l :: list |
| t :: tuple |
| r0 :: i32 |
| r1 :: bit |
| r2, r3, x :: object |
| r4, y :: int |
| r5 :: i32 |
| r6 :: bit |
| r7, r8 :: object |
| r9 :: int |
| L0: |
| r0 = CPySequence_CheckUnpackCount(l, 2) |
| r1 = r0 >= 0 :: signed |
| r2 = list_get_item_unsafe l, 0 |
| r3 = list_get_item_unsafe l, 1 |
| x = r2 |
| r4 = unbox(int, r3) |
| y = r4 |
| r5 = CPySequence_CheckUnpackCount(t, 2) |
| r6 = r5 >= 0 :: signed |
| r7 = CPySequenceTuple_GetItemUnsafe(t, 0) |
| r8 = CPySequenceTuple_GetItemUnsafe(t, 1) |
| x = r7 |
| r9 = unbox(int, r8) |
| y = r9 |
| return 1 |
| |
| [case testAssert] |
| from typing import Optional |
| |
| def no_msg(x: bool) -> int: |
| assert x |
| return 1 |
| |
| def literal_msg(x: object) -> int: |
| assert x, 'message' |
| return 2 |
| |
| def complex_msg(x: Optional[str], s: str) -> None: |
| assert x, s |
| [out] |
| def no_msg(x): |
| x, r0 :: bool |
| L0: |
| if x goto L2 else goto L1 :: bool |
| L1: |
| r0 = raise AssertionError |
| unreachable |
| L2: |
| return 2 |
| def literal_msg(x): |
| x :: object |
| r0 :: i32 |
| r1 :: bit |
| r2, r3 :: bool |
| L0: |
| r0 = PyObject_IsTrue(x) |
| r1 = r0 >= 0 :: signed |
| r2 = truncate r0: i32 to builtins.bool |
| if r2 goto L2 else goto L1 :: bool |
| L1: |
| r3 = raise AssertionError('message') |
| unreachable |
| L2: |
| return 4 |
| def complex_msg(x, s): |
| x :: union[str, None] |
| s :: str |
| r0 :: object |
| r1 :: bit |
| r2 :: str |
| r3 :: bit |
| r4 :: object |
| r5 :: str |
| r6 :: object |
| r7 :: object[1] |
| r8 :: object_ptr |
| r9 :: object |
| L0: |
| r0 = load_address _Py_NoneStruct |
| r1 = x != r0 |
| if r1 goto L1 else goto L2 :: bool |
| L1: |
| r2 = cast(str, x) |
| r3 = CPyStr_IsTrue(r2) |
| if r3 goto L3 else goto L2 :: bool |
| L2: |
| r4 = builtins :: module |
| r5 = 'AssertionError' |
| r6 = CPyObject_GetAttr(r4, r5) |
| r7 = [s] |
| r8 = load_address r7 |
| r9 = PyObject_Vectorcall(r6, r8, 1, 0) |
| keep_alive s |
| CPy_Raise(r9) |
| unreachable |
| L3: |
| return 1 |
| |
| [case testDelList] |
| def delList() -> None: |
| l = [1, 2] |
| del l[1] |
| def delListMultiple() -> None: |
| l = [1, 2, 3, 4, 5, 6, 7] |
| del l[1], l[2], l[3] |
| [out] |
| def delList(): |
| r0 :: list |
| r1, r2 :: object |
| r3 :: ptr |
| l :: list |
| r4 :: object |
| r5 :: i32 |
| r6 :: bit |
| L0: |
| r0 = PyList_New(2) |
| r1 = object 1 |
| r2 = object 2 |
| r3 = list_items r0 |
| buf_init_item r3, 0, r1 |
| buf_init_item r3, 1, r2 |
| keep_alive r0 |
| l = r0 |
| r4 = object 1 |
| r5 = PyObject_DelItem(l, r4) |
| r6 = r5 >= 0 :: signed |
| return 1 |
| def delListMultiple(): |
| r0 :: list |
| r1, r2, r3, r4, r5, r6, r7 :: object |
| r8 :: ptr |
| l :: list |
| r9 :: object |
| r10 :: i32 |
| r11 :: bit |
| r12 :: object |
| r13 :: i32 |
| r14 :: bit |
| r15 :: object |
| r16 :: i32 |
| r17 :: bit |
| L0: |
| r0 = PyList_New(7) |
| r1 = object 1 |
| r2 = object 2 |
| r3 = object 3 |
| r4 = object 4 |
| r5 = object 5 |
| r6 = object 6 |
| r7 = object 7 |
| r8 = list_items r0 |
| buf_init_item r8, 0, r1 |
| buf_init_item r8, 1, r2 |
| buf_init_item r8, 2, r3 |
| buf_init_item r8, 3, r4 |
| buf_init_item r8, 4, r5 |
| buf_init_item r8, 5, r6 |
| buf_init_item r8, 6, r7 |
| keep_alive r0 |
| l = r0 |
| r9 = object 1 |
| r10 = PyObject_DelItem(l, r9) |
| r11 = r10 >= 0 :: signed |
| r12 = object 2 |
| r13 = PyObject_DelItem(l, r12) |
| r14 = r13 >= 0 :: signed |
| r15 = object 3 |
| r16 = PyObject_DelItem(l, r15) |
| r17 = r16 >= 0 :: signed |
| return 1 |
| |
| [case testDelDict] |
| def delDict() -> None: |
| d = {"one":1, "two":2} |
| del d["one"] |
| def delDictMultiple() -> None: |
| d = {"one":1, "two":2, "three":3, "four":4} |
| del d["one"], d["four"] |
| [out] |
| def delDict(): |
| r0, r1 :: str |
| r2, r3 :: object |
| r4, d :: dict |
| r5 :: str |
| r6 :: i32 |
| r7 :: bit |
| L0: |
| r0 = 'one' |
| r1 = 'two' |
| r2 = object 1 |
| r3 = object 2 |
| r4 = CPyDict_Build(2, r0, r2, r1, r3) |
| d = r4 |
| r5 = 'one' |
| r6 = PyObject_DelItem(d, r5) |
| r7 = r6 >= 0 :: signed |
| return 1 |
| def delDictMultiple(): |
| r0, r1, r2, r3 :: str |
| r4, r5, r6, r7 :: object |
| r8, d :: dict |
| r9, r10 :: str |
| r11 :: i32 |
| r12 :: bit |
| r13 :: i32 |
| r14 :: bit |
| L0: |
| r0 = 'one' |
| r1 = 'two' |
| r2 = 'three' |
| r3 = 'four' |
| r4 = object 1 |
| r5 = object 2 |
| r6 = object 3 |
| r7 = object 4 |
| r8 = CPyDict_Build(4, r0, r4, r1, r5, r2, r6, r3, r7) |
| d = r8 |
| r9 = 'one' |
| r10 = 'four' |
| r11 = PyObject_DelItem(d, r9) |
| r12 = r11 >= 0 :: signed |
| r13 = PyObject_DelItem(d, r10) |
| r14 = r13 >= 0 :: signed |
| return 1 |
| |
| [case testDelAttribute] |
| class Dummy(): |
| __deletable__ = ('x', 'y') |
| def __init__(self, x: int, y: int) -> None: |
| self.x = x |
| self.y = y |
| def delAttribute() -> None: |
| dummy = Dummy(1, 2) |
| del dummy.x |
| def delAttributeMultiple() -> None: |
| dummy = Dummy(1, 2) |
| del dummy.x, dummy.y |
| [out] |
| def Dummy.__init__(self, x, y): |
| self :: __main__.Dummy |
| x, y :: int |
| L0: |
| self.x = x |
| self.y = y |
| return 1 |
| def delAttribute(): |
| r0, dummy :: __main__.Dummy |
| r1 :: str |
| r2 :: i32 |
| r3 :: bit |
| L0: |
| r0 = Dummy(2, 4) |
| dummy = r0 |
| r1 = 'x' |
| r2 = PyObject_DelAttr(dummy, r1) |
| r3 = r2 >= 0 :: signed |
| return 1 |
| def delAttributeMultiple(): |
| r0, dummy :: __main__.Dummy |
| r1 :: str |
| r2 :: i32 |
| r3 :: bit |
| r4 :: str |
| r5 :: i32 |
| r6 :: bit |
| L0: |
| r0 = Dummy(2, 4) |
| dummy = r0 |
| r1 = 'x' |
| r2 = PyObject_DelAttr(dummy, r1) |
| r3 = r2 >= 0 :: signed |
| r4 = 'y' |
| r5 = PyObject_DelAttr(dummy, r4) |
| r6 = r5 >= 0 :: signed |
| return 1 |
| |
| [case testForEnumerate] |
| from typing import List, Iterable |
| |
| def f(a: List[int]) -> None: |
| for i, x in enumerate(a): |
| i + x |
| def g(x: Iterable[int]) -> None: |
| for i, n in enumerate(x): |
| pass |
| [out] |
| def f(a): |
| a :: list |
| r0 :: short_int |
| r1, r2 :: native_int |
| r3 :: bit |
| i :: int |
| r4 :: object |
| r5, x, r6 :: int |
| r7 :: short_int |
| r8 :: native_int |
| L0: |
| r0 = 0 |
| r1 = 0 |
| L1: |
| r2 = var_object_size a |
| r3 = r1 < r2 :: signed |
| if r3 goto L2 else goto L4 :: bool |
| L2: |
| i = r0 |
| r4 = list_get_item_unsafe a, r1 |
| r5 = unbox(int, r4) |
| x = r5 |
| r6 = CPyTagged_Add(i, x) |
| L3: |
| r7 = r0 + 2 |
| r0 = r7 |
| r8 = r1 + 1 |
| r1 = r8 |
| goto L1 |
| L4: |
| L5: |
| return 1 |
| def g(x): |
| x :: object |
| r0 :: short_int |
| r1, r2 :: object |
| i, r3, n :: int |
| r4 :: short_int |
| r5 :: bit |
| L0: |
| r0 = 0 |
| r1 = PyObject_GetIter(x) |
| L1: |
| r2 = PyIter_Next(r1) |
| if is_error(r2) goto L4 else goto L2 |
| L2: |
| i = r0 |
| r3 = unbox(int, r2) |
| n = r3 |
| L3: |
| r4 = r0 + 2 |
| r0 = r4 |
| goto L1 |
| L4: |
| r5 = CPy_NoErrOccurred() |
| L5: |
| return 1 |
| |
| [case testForZip] |
| from typing import List, Iterable, Sequence |
| |
| def f(a: List[int], b: Sequence[bool]) -> None: |
| for x, y in zip(a, b): |
| if b: |
| x = 1 |
| |
| def g(a: Iterable[bool], b: List[int]) -> None: |
| for x, y, z in zip(a, b, range(5)): |
| x = False |
| [out] |
| def f(a, b): |
| a :: list |
| b :: object |
| r0 :: native_int |
| r1 :: object |
| r2 :: native_int |
| r3 :: bit |
| r4, r5 :: object |
| r6, x :: int |
| r7, y :: bool |
| r8 :: i32 |
| r9 :: bit |
| r10 :: bool |
| r11 :: native_int |
| r12 :: bit |
| L0: |
| r0 = 0 |
| r1 = PyObject_GetIter(b) |
| L1: |
| r2 = var_object_size a |
| r3 = r0 < r2 :: signed |
| if r3 goto L2 else goto L7 :: bool |
| L2: |
| r4 = PyIter_Next(r1) |
| if is_error(r4) goto L7 else goto L3 |
| L3: |
| r5 = list_get_item_unsafe a, r0 |
| r6 = unbox(int, r5) |
| x = r6 |
| r7 = unbox(bool, r4) |
| y = r7 |
| r8 = PyObject_IsTrue(b) |
| r9 = r8 >= 0 :: signed |
| r10 = truncate r8: i32 to builtins.bool |
| if r10 goto L4 else goto L5 :: bool |
| L4: |
| x = 2 |
| L5: |
| L6: |
| r11 = r0 + 1 |
| r0 = r11 |
| goto L1 |
| L7: |
| r12 = CPy_NoErrOccurred() |
| L8: |
| return 1 |
| def g(a, b): |
| a :: object |
| b :: list |
| r0 :: object |
| r1 :: native_int |
| r2 :: short_int |
| z :: int |
| r3 :: object |
| r4 :: native_int |
| r5, r6 :: bit |
| r7, x :: bool |
| r8 :: object |
| r9, y :: int |
| r10 :: native_int |
| r11 :: short_int |
| r12 :: bit |
| L0: |
| r0 = PyObject_GetIter(a) |
| r1 = 0 |
| r2 = 0 |
| z = r2 |
| L1: |
| r3 = PyIter_Next(r0) |
| if is_error(r3) goto L6 else goto L2 |
| L2: |
| r4 = var_object_size b |
| r5 = r1 < r4 :: signed |
| if r5 goto L3 else goto L6 :: bool |
| L3: |
| r6 = int_lt r2, 10 |
| if r6 goto L4 else goto L6 :: bool |
| L4: |
| r7 = unbox(bool, r3) |
| x = r7 |
| r8 = list_get_item_unsafe b, r1 |
| r9 = unbox(int, r8) |
| y = r9 |
| x = 0 |
| L5: |
| r10 = r1 + 1 |
| r1 = r10 |
| r11 = r2 + 2 |
| r2 = r11 |
| z = r11 |
| goto L1 |
| L6: |
| r12 = CPy_NoErrOccurred() |
| L7: |
| return 1 |
| |
| [case testConditionalFunctionDefinition] |
| if int(): |
| def foo() -> int: |
| return 0 |
| else: |
| def foo() -> int: # E |
| return 1 |
| |
| def bar() -> int: |
| return 0 |
| |
| if int(): |
| def bar() -> int: # E |
| return 1 |
| [out] |
| main:5: error: Duplicate definition of "foo" not supported by mypyc |
| main:12: error: Duplicate definition of "bar" not supported by mypyc |
| |
| [case testRepeatedUnderscoreFunctions] |
| def _(arg): pass |
| def _(arg): pass |
| [out] |
| main:2: error: Duplicate definition of "_" not supported by mypyc |