/
loggers.py
38 lines (27 loc) · 1.03 KB
/
loggers.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
"""Script to create a `logger` for Parcels"""
import logging
__all__ = ['logger']
warning_once_level = 25
class DuplicateFilter(object):
"""Utility class to prevent warning_once warnings from being
displayed more than once"""
def __init__(self):
self.msgs = set()
def filter(self, record):
rv = record.msg not in self.msgs
if record.levelno == warning_once_level:
self.msgs.add(record.msg)
return rv
def warning_once(self, message, *args, **kws):
"""Custom logging level for warnings that need to be displayed only once"""
if self.isEnabledFor(warning_once_level):
self._log(warning_once_level, message, args, **kws)
logger = logging.getLogger(__name__)
handler = logging.StreamHandler()
handler.setFormatter(logging.Formatter(fmt="%(levelname)s: %(message)s"))
logger.addHandler(handler)
logging.addLevelName(warning_once_level, "WARNING")
logging.Logger.warning_once = warning_once
dup_filter = DuplicateFilter()
logger.addFilter(dup_filter)
logger.setLevel(10)