Spaces:
Runtime error
Runtime error
| 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(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 | |
| 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) # 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() | |