-
-
Notifications
You must be signed in to change notification settings - Fork 8
/
util.py
43 lines (37 loc) · 1.16 KB
/
util.py
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
34
35
36
37
38
39
40
41
42
43
"""Some utilities, e.g. setup logging."""
from __future__ import annotations
import logging
import os
try:
from coloredlogs import ColoredFormatter as Formatter
except ImportError:
from logging import Formatter
def setup_logging(
name: str = "amsthm",
level: str = "INFO",
env_var: str = "AMSTHMLOGLEVEL",
fmt: str = "%(name)s %(levelname)s %(message)s",
Handler: type[logging.Handler] = logging.StreamHandler,
Formatter: type[logging.Formatter] = Formatter,
) -> logging.Logger:
"""Setup logging.
:param env_var: if not empty, set log level from this environment variable.
"""
logger = logging.getLogger(name)
handler = Handler()
handler.setFormatter(Formatter(fmt))
logger.addHandler(handler)
if env_var:
try:
logger.setLevel(level=(_level := os.environ.get(env_var, level)))
except ValueError:
logger.setLevel(level=level)
logger.error(
"%s=%s is not a valid logging level, set to default %s.",
env_var,
_level,
level,
)
else:
logger.setLevel(level=level)
return logger