From: Christian Heller Date: Wed, 24 Sep 2025 06:56:15 +0000 (+0200) Subject: Log date changes, sort log files into dates. X-Git-Url: https://plomlompom.com/repos/%7B%7B%20web_path%20%7D%7D/static/%7B%7Bprefix%7D%7D/blog?a=commitdiff_plain;h=7f6f9a6582ac281e5b719d4899dac080ecb68ab9;p=ircplom Log date changes, sort log files into dates. --- diff --git a/ircplom/client_tui.py b/ircplom/client_tui.py index 26ea085..185964f 100644 --- a/ircplom/client_tui.py +++ b/ircplom/client_tui.py @@ -46,10 +46,10 @@ class _ClientWindow(Window, ClientQueueMixin): def log(self, msg: str) -> None: super().log(msg) - if not exists(_PATH_LOGS): - makedirs(_PATH_LOGS) - with open(f'{_PATH_LOGS}/{self._title}.txt', 'a', encoding='utf8' - ) as f: + ldir = f'{_PATH_LOGS}/{self._title}' + if not exists(ldir): + makedirs(ldir) + with open(f'{ldir}/{self._last_today}.txt', 'a', encoding='utf8') as f: f.write(msg + '\n') def _send_msg(self, verb: str, params: tuple[str, ...]) -> None: diff --git a/ircplom/tui_base.py b/ircplom/tui_base.py index f6a3f96..73115a1 100644 --- a/ircplom/tui_base.py +++ b/ircplom/tui_base.py @@ -322,6 +322,7 @@ class Window: _drawable = False prompt: PromptWidget _title = ':start' + _last_today = '' def __init__(self, idx: int, term: 'Terminal', **kwargs) -> None: super().__init__(**kwargs) @@ -333,6 +334,12 @@ class Window: if hasattr(self._term, 'size'): self.set_geometry() + def ensure_date(self, today: str) -> None: + 'Log date of today if it has not been logged yet.' + if today != self._last_today: + self._last_today = today + self.log(today) + def log(self, msg: str) -> None: 'Append msg to .history.' self.history.append(msg) @@ -449,10 +456,13 @@ class BaseTui(QueueMixin): prefix = kwargs.get('prefix', _LOG_PREFIX_DEFAULT) if kwargs.get('alert', False): prefix = _LOG_PREFIX_ALERT + prefix - msg = f'{str(datetime.now())[11:19]} {prefix} {msg}' + now = str(datetime.now()) + today, time = now[:10], now[11:19] + msg = f'{time} {prefix} {msg}' affected_win_indices = [] for win in self._log_target_wins(**kwargs): affected_win_indices += [win.idx] + win.ensure_date(today) win.log(msg) if win != self.window: self._status_line.taint()