summaryrefslogtreecommitdiff
path: root/tests/basics/int_big_to_small.py
blob: c92d263fc283732f776399d6f1ed41a0503785ce (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
try:
    import micropython
    micropython.heap_lock
except:
    print("SKIP")
    raise SystemExit

# Skip this test on "REPR B" where (1<<29 + 1) is not a small int.
k = 1 << 29
micropython.heap_lock()
try:
    k = k + 1
except MemoryError:
    print("SKIP")
    raise SystemExit
finally:
    micropython.heap_unlock()

# All less than small int max.
for d in (0, 27, 1<<29, -1861, -(1<<29)):
    i = 1<<70
    print(i)
    j = (1<<70) + d
    print(j)
    # k should now be a small int.
    k = j - i
    print(k)

    # Now verify that working with k doesn't allocate (i.e. it's a small int).
    micropython.heap_lock()
    print(k + 20)
    print(k // 20)
    micropython.heap_unlock()