blob: 01420da9af0210a65f4b75d27ef9067806099c45 [file] [log] [blame]
Jeremy Hylton6fa82a32002-06-04 20:00:26 +00001"""A simple log mechanism styled after PEP 282."""
2
Andrew M. Kuchlingd448f662002-11-19 13:12:28 +00003# This module should be kept compatible with Python 1.5.2.
4
Jeremy Hylton6fa82a32002-06-04 20:00:26 +00005# The class here is styled after PEP 282 so that it could later be
6# replaced with a standard Python logging implementation.
7
8DEBUG = 1
9INFO = 2
10WARN = 3
11ERROR = 4
12FATAL = 5
13
Andrew M. Kuchlinge2d12142002-11-04 14:27:43 +000014import sys
15
Jeremy Hylton6fa82a32002-06-04 20:00:26 +000016class Log:
17
18 def __init__(self, threshold=WARN):
19 self.threshold = threshold
20
21 def _log(self, level, msg, args):
22 if level >= self.threshold:
23 print msg % args
Andrew M. Kuchlinge2d12142002-11-04 14:27:43 +000024 sys.stdout.flush()
Jeremy Hylton6fa82a32002-06-04 20:00:26 +000025
26 def log(self, level, msg, *args):
27 self._log(level, msg, args)
28
29 def debug(self, msg, *args):
30 self._log(DEBUG, msg, args)
31
32 def info(self, msg, *args):
33 self._log(INFO, msg, args)
34
35 def warn(self, msg, *args):
36 self._log(WARN, msg, args)
37
38 def error(self, msg, *args):
39 self._log(ERROR, msg, args)
40
41 def fatal(self, msg, *args):
42 self._log(FATAL, msg, args)
43
44_global_log = Log()
45log = _global_log.log
46debug = _global_log.debug
47info = _global_log.info
48warn = _global_log.warn
49error = _global_log.error
50fatal = _global_log.fatal
51
52def set_threshold(level):
53 _global_log.threshold = level
54
55def set_verbosity(v):
Guido van Rossuma85dbeb2003-02-20 02:09:30 +000056 if v <= 0:
Jeremy Hylton6fa82a32002-06-04 20:00:26 +000057 set_threshold(WARN)
Guido van Rossuma85dbeb2003-02-20 02:09:30 +000058 elif v == 1:
Jeremy Hylton6fa82a32002-06-04 20:00:26 +000059 set_threshold(INFO)
Guido van Rossuma85dbeb2003-02-20 02:09:30 +000060 elif v >= 2:
Jeremy Hylton6fa82a32002-06-04 20:00:26 +000061 set_threshold(DEBUG)