1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-01 19:10:58 +00:00
trezor-firmware/core/src/trezor/log.py

71 lines
1.9 KiB
Python
Raw Normal View History

2016-04-29 17:54:54 +00:00
import sys
import utime
2018-07-03 14:20:26 +00:00
from micropython import const
from typing import Any
2019-07-03 13:07:04 +00:00
_DEBUG = const(10)
_INFO = const(20)
_WARNING = const(30)
_ERROR = const(40)
_CRITICAL = const(50)
2016-04-29 17:54:54 +00:00
_leveldict = {
_DEBUG: ("DEBUG", "32"),
_INFO: ("INFO", "36"),
_WARNING: ("WARNING", "33"),
_ERROR: ("ERROR", "31"),
_CRITICAL: ("CRITICAL", "1;31"),
2016-04-29 17:54:54 +00:00
}
level = _DEBUG
2016-04-29 17:54:54 +00:00
color = True
2017-06-12 16:16:06 +00:00
2019-07-03 13:07:04 +00:00
def _log(name: str, mlevel: int, msg: str, *args: Any) -> None:
if __debug__ and mlevel >= level:
2016-04-29 17:54:54 +00:00
if color:
2018-07-03 14:20:58 +00:00
fmt = (
"%d \x1b[35m%s\x1b[0m \x1b["
+ _leveldict[mlevel][1]
+ "m%s\x1b[0m "
+ msg
)
2016-04-29 17:54:54 +00:00
else:
2018-07-03 14:20:58 +00:00
fmt = "%d %s %s " + msg
2017-03-06 16:33:42 +00:00
print(fmt % ((utime.ticks_us(), name, _leveldict[mlevel][0]) + args))
2016-04-29 17:54:54 +00:00
2017-06-12 16:16:06 +00:00
2019-07-03 13:07:04 +00:00
def debug(name: str, msg: str, *args: Any) -> None:
_log(name, _DEBUG, msg, *args)
2016-04-29 17:54:54 +00:00
2017-06-12 16:16:06 +00:00
2019-07-03 13:07:04 +00:00
def info(name: str, msg: str, *args: Any) -> None:
_log(name, _INFO, msg, *args)
2016-04-29 17:54:54 +00:00
2017-06-12 16:16:06 +00:00
2019-07-03 13:07:04 +00:00
def warning(name: str, msg: str, *args: Any) -> None:
_log(name, _WARNING, msg, *args)
2016-04-29 17:54:54 +00:00
2017-06-12 16:16:06 +00:00
2019-07-03 13:07:04 +00:00
def error(name: str, msg: str, *args: Any) -> None:
_log(name, _ERROR, msg, *args)
2016-04-29 17:54:54 +00:00
2017-06-12 16:16:06 +00:00
2019-07-03 13:07:04 +00:00
def exception(name: str, exc: BaseException) -> None:
# we are using `__class__.__name__` to avoid importing ui module
# we also need to instruct typechecker to ignore the missing argument
2019-10-02 12:40:25 +00:00
# in ui.Result exception
if exc.__class__.__name__ == "Result":
2019-10-02 12:40:25 +00:00
_log(
name,
_DEBUG,
2019-10-02 12:40:25 +00:00
"ui.Result: %s",
exc.value, # type: ignore[Cannot access member "value" for type "BaseException"]
2019-10-02 12:40:25 +00:00
)
elif exc.__class__.__name__ == "Cancelled":
_log(name, _DEBUG, "ui.Cancelled")
else:
_log(name, _ERROR, "exception:")
# since mypy 0.770 we cannot override sys, so print_exception is unknown
sys.print_exception(exc) # type: ignore ["print_exception" is not a known member of module]