2016-11-21 17:39:23 +11:00
|
|
|
# test that we can generate a traceback without allocating
|
|
|
|
|
|
|
|
import micropython
|
|
|
|
import sys
|
2017-03-09 10:26:31 +01:00
|
|
|
try:
|
|
|
|
import uio
|
|
|
|
except ImportError:
|
|
|
|
print("SKIP")
|
2017-06-10 20:14:16 +03:00
|
|
|
raise SystemExit
|
2016-11-21 17:39:23 +11:00
|
|
|
|
|
|
|
# preallocate exception instance with some room for a traceback
|
|
|
|
global_exc = StopIteration()
|
|
|
|
try:
|
|
|
|
raise global_exc
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
|
|
|
|
def test():
|
|
|
|
global global_exc
|
|
|
|
global_exc.__traceback__ = None
|
|
|
|
try:
|
|
|
|
raise global_exc
|
2016-12-15 11:11:57 +11:00
|
|
|
except StopIteration:
|
|
|
|
print('StopIteration')
|
2016-11-21 17:39:23 +11:00
|
|
|
|
|
|
|
# call test() with heap allocation disabled
|
|
|
|
micropython.heap_lock()
|
|
|
|
test()
|
|
|
|
micropython.heap_unlock()
|
2016-12-15 11:11:57 +11:00
|
|
|
|
|
|
|
# print the exception that was raised
|
|
|
|
buf = uio.StringIO()
|
|
|
|
sys.print_exception(global_exc, buf)
|
|
|
|
for l in buf.getvalue().split("\n"):
|
|
|
|
# uPy on pyboard prints <stdin> as file, so remove filename.
|
|
|
|
if l.startswith(" File "):
|
|
|
|
l = l.split('"')
|
|
|
|
print(l[0], l[2])
|
|
|
|
else:
|
|
|
|
print(l)
|