2023-05-03 20:49:55 -04:00
|
|
|
import logging
|
2023-05-03 20:43:17 -04:00
|
|
|
|
2023-12-19 23:38:33 -05:00
|
|
|
logger = logging.getLogger('text-generation-webui')
|
2023-05-03 20:43:17 -04:00
|
|
|
|
2023-05-21 21:42:34 -04:00
|
|
|
|
2023-12-19 23:38:33 -05:00
|
|
|
def setup_logging():
|
|
|
|
'''
|
|
|
|
Copied from: https://github.com/vladmandic/automatic
|
|
|
|
|
|
|
|
All credits to vladmandic.
|
|
|
|
'''
|
|
|
|
|
|
|
|
class RingBuffer(logging.StreamHandler):
|
|
|
|
def __init__(self, capacity):
|
|
|
|
super().__init__()
|
|
|
|
self.capacity = capacity
|
|
|
|
self.buffer = []
|
|
|
|
self.formatter = logging.Formatter('{ "asctime":"%(asctime)s", "created":%(created)f, "facility":"%(name)s", "pid":%(process)d, "tid":%(thread)d, "level":"%(levelname)s", "module":"%(module)s", "func":"%(funcName)s", "msg":"%(message)s" }')
|
|
|
|
|
|
|
|
def emit(self, record):
|
|
|
|
msg = self.format(record)
|
|
|
|
# self.buffer.append(json.loads(msg))
|
|
|
|
self.buffer.append(msg)
|
|
|
|
if len(self.buffer) > self.capacity:
|
|
|
|
self.buffer.pop(0)
|
|
|
|
|
|
|
|
def get(self):
|
|
|
|
return self.buffer
|
|
|
|
|
|
|
|
from rich.console import Console
|
2023-12-20 00:36:57 -05:00
|
|
|
from rich.logging import RichHandler
|
2023-12-19 23:38:33 -05:00
|
|
|
from rich.pretty import install as pretty_install
|
2023-12-20 00:36:57 -05:00
|
|
|
from rich.theme import Theme
|
2023-12-19 23:38:33 -05:00
|
|
|
from rich.traceback import install as traceback_install
|
|
|
|
|
|
|
|
level = logging.DEBUG
|
|
|
|
logger.setLevel(logging.DEBUG) # log to file is always at level debug for facility `sd`
|
|
|
|
console = Console(log_time=True, log_time_format='%H:%M:%S-%f', theme=Theme({
|
|
|
|
"traceback.border": "black",
|
|
|
|
"traceback.border.syntax_error": "black",
|
|
|
|
"inspect.value.border": "black",
|
|
|
|
}))
|
|
|
|
logging.basicConfig(level=logging.ERROR, format='%(asctime)s | %(name)s | %(levelname)s | %(module)s | %(message)s', handlers=[logging.NullHandler()]) # redirect default logger to null
|
|
|
|
pretty_install(console=console)
|
|
|
|
traceback_install(console=console, extra_lines=1, max_frames=10, width=console.width, word_wrap=False, indent_guides=False, suppress=[])
|
|
|
|
while logger.hasHandlers() and len(logger.handlers) > 0:
|
|
|
|
logger.removeHandler(logger.handlers[0])
|
|
|
|
|
|
|
|
# handlers
|
|
|
|
rh = RichHandler(show_time=True, omit_repeated_times=False, show_level=True, show_path=False, markup=False, rich_tracebacks=True, log_time_format='%H:%M:%S-%f', level=level, console=console)
|
|
|
|
rh.setLevel(level)
|
|
|
|
logger.addHandler(rh)
|
|
|
|
|
|
|
|
rb = RingBuffer(100) # 100 entries default in log ring buffer
|
|
|
|
rb.setLevel(level)
|
|
|
|
logger.addHandler(rb)
|
|
|
|
logger.buffer = rb.buffer
|
|
|
|
|
|
|
|
# overrides
|
|
|
|
logging.getLogger("urllib3").setLevel(logging.ERROR)
|
|
|
|
logging.getLogger("httpx").setLevel(logging.ERROR)
|
|
|
|
logging.getLogger("diffusers").setLevel(logging.ERROR)
|
|
|
|
logging.getLogger("torch").setLevel(logging.ERROR)
|
|
|
|
logging.getLogger("lycoris").handlers = logger.handlers
|
|
|
|
|
|
|
|
|
|
|
|
setup_logging()
|