2014-12-11 17:10:25 +00:00
|
|
|
import _io as io # uPy does not have io module builtin
|
2014-12-10 18:35:10 +00:00
|
|
|
import sys
|
|
|
|
if hasattr(sys, 'print_exception'):
|
|
|
|
print_exception = sys.print_exception
|
|
|
|
else:
|
|
|
|
import traceback
|
|
|
|
print_exception = lambda e, f: traceback.print_exception(None, e, None, file=f)
|
|
|
|
|
|
|
|
try:
|
2014-12-10 21:45:51 +00:00
|
|
|
XXX
|
2014-12-10 18:35:10 +00:00
|
|
|
except Exception as e:
|
|
|
|
print('caught')
|
|
|
|
buf = io.StringIO()
|
|
|
|
print_exception(e, buf)
|
|
|
|
s = buf.getvalue()
|
|
|
|
for l in s.split("\n"):
|
2014-12-18 13:37:56 +00:00
|
|
|
# uPy on pyboard prints <stdin> as file, so remove filename.
|
|
|
|
if l.startswith(" File "):
|
|
|
|
print(l[:8], l[-23:])
|
2014-12-10 18:35:10 +00:00
|
|
|
# uPy and CPy tracebacks differ in that CPy prints a source line for
|
|
|
|
# each traceback entry. In this case, we know that offending line
|
|
|
|
# has 4-space indent, so filter it out.
|
2014-12-18 13:37:56 +00:00
|
|
|
elif not l.startswith(" "):
|
2014-12-10 18:35:10 +00:00
|
|
|
print(l)
|