| | import logging |
| |
|
| | logger = logging.getLogger('text-generation-webui') |
| |
|
| |
|
| | 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(msg) |
| | if len(self.buffer) > self.capacity: |
| | self.buffer.pop(0) |
| |
|
| | def get(self): |
| | return self.buffer |
| |
|
| | from rich.console import Console |
| | from rich.logging import RichHandler |
| | from rich.pretty import install as pretty_install |
| | from rich.theme import Theme |
| | from rich.traceback import install as traceback_install |
| |
|
| | level = logging.DEBUG |
| | logger.setLevel(logging.DEBUG) |
| | 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()]) |
| | 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]) |
| |
|
| | |
| | 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) |
| | rb.setLevel(level) |
| | logger.addHandler(rb) |
| | logger.buffer = rb.buffer |
| |
|
| | |
| | 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() |
| |
|