mirror of
https://github.com/lilydjwg/nvchecker
synced 2024-12-14 02:35:08 +00:00
nicelogger update
This commit is contained in:
parent
dcdfaa7d25
commit
e71d56b671
@ -1,3 +1,9 @@
|
|||||||
|
'''
|
||||||
|
A Tornado-inspired logging formatter, with displayed time with millisecond accuracy
|
||||||
|
|
||||||
|
FYI: pyftpdlib also has a Tornado-style logger.
|
||||||
|
'''
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
import logging
|
import logging
|
||||||
@ -9,7 +15,7 @@ class TornadoLogFormatter(logging.Formatter):
|
|||||||
if color:
|
if color:
|
||||||
import curses
|
import curses
|
||||||
curses.setupterm()
|
curses.setupterm()
|
||||||
if sys.hexversion < 50463728:
|
if sys.hexversion < 0x30203f0:
|
||||||
fg_color = str(curses.tigetstr("setaf") or
|
fg_color = str(curses.tigetstr("setaf") or
|
||||||
curses.tigetstr("setf") or "", "ascii")
|
curses.tigetstr("setf") or "", "ascii")
|
||||||
else:
|
else:
|
||||||
@ -23,6 +29,8 @@ class TornadoLogFormatter(logging.Formatter):
|
|||||||
"ascii"),
|
"ascii"),
|
||||||
logging.ERROR: str(curses.tparm(fg_color, 1), # Red
|
logging.ERROR: str(curses.tparm(fg_color, 1), # Red
|
||||||
"ascii"),
|
"ascii"),
|
||||||
|
logging.CRITICAL: str(curses.tparm(fg_color, 9), # Bright Red
|
||||||
|
"ascii"),
|
||||||
}
|
}
|
||||||
self._normal = str(curses.tigetstr("sgr0"), "ascii")
|
self._normal = str(curses.tigetstr("sgr0"), "ascii")
|
||||||
|
|
||||||
@ -47,23 +55,30 @@ class TornadoLogFormatter(logging.Formatter):
|
|||||||
formatted = formatted.rstrip() + "\n" + record.exc_text
|
formatted = formatted.rstrip() + "\n" + record.exc_text
|
||||||
return formatted.replace("\n", "\n ")
|
return formatted.replace("\n", "\n ")
|
||||||
|
|
||||||
def enable_pretty_logging(level=logging.DEBUG):
|
def enable_pretty_logging(level=logging.DEBUG, handler=None, color=None):
|
||||||
|
'''
|
||||||
|
handler: specify a handler instead of default StreamHandler
|
||||||
|
color: boolean, force color to be on / off. Default to be on only when
|
||||||
|
``handler`` isn't specified and the term supports color
|
||||||
|
'''
|
||||||
logger = logging.getLogger()
|
logger = logging.getLogger()
|
||||||
|
if handler is None:
|
||||||
h = logging.StreamHandler()
|
h = logging.StreamHandler()
|
||||||
formatter = logging.Formatter('%(asctime)s:%(levelname)-7s:%(name)-12s:%(message)s')
|
else:
|
||||||
|
h = handler
|
||||||
|
if color is None:
|
||||||
|
color = False
|
||||||
|
if handler is None and sys.stderr.isatty():
|
||||||
try:
|
try:
|
||||||
import curses
|
import curses
|
||||||
color = False
|
|
||||||
curses.setupterm()
|
curses.setupterm()
|
||||||
if curses.tigetnum("colors") > 0:
|
if curses.tigetnum("colors") > 0:
|
||||||
color = True
|
color = True
|
||||||
formatter = TornadoLogFormatter(color=color)
|
|
||||||
except:
|
except:
|
||||||
import traceback
|
import traceback
|
||||||
traceback.print_exc()
|
traceback.print_exc()
|
||||||
finally:
|
formatter = TornadoLogFormatter(color=color)
|
||||||
h.setLevel(level)
|
h.setLevel(level)
|
||||||
h.setFormatter(formatter)
|
h.setFormatter(formatter)
|
||||||
logger.setLevel(level)
|
logger.setLevel(level)
|
||||||
logger.addHandler(h)
|
logger.addHandler(h)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user