- Notifications
You must be signed in to change notification settings - Fork 31.8k
/
Copy pathlog.py
77 lines (61 loc) · 1.92 KB
/
log.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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
"""A simple log mechanism styled after PEP 282."""
# The class here is styled after PEP 282 so that it could later be
# replaced with a standard Python logging implementation.
DEBUG=1
INFO=2
WARN=3
ERROR=4
FATAL=5
importsys
classLog:
def__init__(self, threshold=WARN):
self.threshold=threshold
def_log(self, level, msg, args):
iflevelnotin (DEBUG, INFO, WARN, ERROR, FATAL):
raiseValueError('%s wrong log level'%str(level))
iflevel>=self.threshold:
ifargs:
msg=msg%args
iflevelin (WARN, ERROR, FATAL):
stream=sys.stderr
else:
stream=sys.stdout
try:
stream.write('%s\n'%msg)
exceptUnicodeEncodeError:
# emulate backslashreplace error handler
encoding=stream.encoding
msg=msg.encode(encoding, "backslashreplace").decode(encoding)
stream.write('%s\n'%msg)
stream.flush()
deflog(self, level, msg, *args):
self._log(level, msg, args)
defdebug(self, msg, *args):
self._log(DEBUG, msg, args)
definfo(self, msg, *args):
self._log(INFO, msg, args)
defwarn(self, msg, *args):
self._log(WARN, msg, args)
deferror(self, msg, *args):
self._log(ERROR, msg, args)
deffatal(self, msg, *args):
self._log(FATAL, msg, args)
_global_log=Log()
log=_global_log.log
debug=_global_log.debug
info=_global_log.info
warn=_global_log.warn
error=_global_log.error
fatal=_global_log.fatal
defset_threshold(level):
# return the old threshold for use from tests
old=_global_log.threshold
_global_log.threshold=level
returnold
defset_verbosity(v):
ifv<=0:
set_threshold(WARN)
elifv==1:
set_threshold(INFO)
elifv>=2:
set_threshold(DEBUG)