"""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 import sys class Log: def __init__(self, threshold=WARN): self.threshold = threshold def _log(self, level, msg, args): if level not in (DEBUG, INFO, WARN, ERROR, FATAL): raise ValueError('%s wrong log level' % str(level)) if level >= self.threshold: if args: msg = msg % args if level in (WARN, ERROR, FATAL): stream = sys.stderr else: stream = sys.stdout if stream.errors == 'strict': # emulate backslashreplace error handler encoding = stream.encoding msg = msg.encode(encoding, "backslashreplace").decode(encoding) stream.write('%s\n' % msg) stream.flush() def log(self, level, msg, *args): self._log(level, msg, args) def debug(self, msg, *args): self._log(DEBUG, msg, args) def info(self, msg, *args): self._log(INFO, msg, args) def warn(self, msg, *args): self._log(WARN, msg, args) def error(self, msg, *args): self._log(ERROR, msg, args) def fatal(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 def set_threshold(level): # return the old threshold for use from tests old = _global_log.threshold _global_log.threshold = level return old def set_verbosity(v): if v <= 0: set_threshold(WARN) elif v == 1: set_threshold(INFO) elif v >= 2: set_threshold(DEBUG)
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
__pycache__ | Folder | 0755 |
|
|
command | Folder | 0755 |
|
|
README | File | 295 B | 0644 |
|
__init__.py | File | 236 B | 0644 |
|
archive_util.py | File | 7.76 KB | 0644 |
|
bcppcompiler.py | File | 14.58 KB | 0644 |
|
ccompiler.py | File | 46.27 KB | 0644 |
|
cmd.py | File | 18.7 KB | 0644 |
|
config.py | File | 4.76 KB | 0644 |
|
core.py | File | 8.7 KB | 0644 |
|
cygwinccompiler.py | File | 16.09 KB | 0644 |
|
debug.py | File | 139 B | 0644 |
|
dep_util.py | File | 3.41 KB | 0644 |
|
dir_util.py | File | 7.6 KB | 0644 |
|
dist.py | File | 48.62 KB | 0644 |
|
errors.py | File | 3.49 KB | 0644 |
|
extension.py | File | 10.09 KB | 0644 |
|
fancy_getopt.py | File | 17.37 KB | 0644 |
|
file_util.py | File | 7.96 KB | 0644 |
|
filelist.py | File | 12.42 KB | 0644 |
|
log.py | File | 1.86 KB | 0644 |
|
msvc9compiler.py | File | 29.8 KB | 0644 |
|
msvccompiler.py | File | 22.93 KB | 0644 |
|
spawn.py | File | 7.34 KB | 0644 |
|
sysconfig.py | File | 20.84 KB | 0644 |
|
text_file.py | File | 12.19 KB | 0644 |
|
unixccompiler.py | File | 13.33 KB | 0644 |
|
util.py | File | 20.18 KB | 0644 |
|
version.py | File | 12.19 KB | 0644 |
|
versionpredicate.py | File | 5.01 KB | 0644 |
|