From: Christian Heller Date: Thu, 11 Sep 2025 22:03:19 +0000 (+0200) Subject: Force logging on implicit creation of items, even if to empty default. X-Git-Url: https://plomlompom.com/repos/te%22?a=commitdiff_plain;h=08008571f12a369a667d903cad4d2b8feb4fd678;p=ircplom Force logging on implicit creation of items, even if to empty default. --- diff --git a/ircplom/client_tui.py b/ircplom/client_tui.py index d3a2d6f..4b338b5 100644 --- a/ircplom/client_tui.py +++ b/ircplom/client_tui.py @@ -25,9 +25,11 @@ _LOG_PREFIX_IN = '<' class _Update: - def __init__(self, path: tuple[str, ...], value: Any) -> None: + def __init__(self, path: tuple[str, ...], value: Any, force_log=False + ) -> None: self.path = path self.value = value + self.force_log = force_log for cls in [cls for cls in locals().values() if isinstance(cls, type) and issubclass(cls, _UpdatingNode) @@ -43,7 +45,7 @@ class _Update: def decremented(self) -> Self: 'Create copy with .path reduced by leftmost step.' - return self.__class__(self.path[1:], self.value) + return self.__class__(self.path[1:], self.value, self.force_log) class _UpdatingNode(AutoAttrMixin): @@ -69,6 +71,7 @@ class _UpdatingNode(AutoAttrMixin): def recursive_set_and_report_change( self, update: _Update) -> Optional[tuple[LogScope, Any]]: 'Apply update, return if that actually made a difference.' + update.force_log = update.force_log or (not self._is_set(update.key)) node = self._get(update.key) if len(update.path) > 1: return node.recursive_set_and_report_change(update.decremented()) @@ -78,15 +81,15 @@ class _UpdatingNode(AutoAttrMixin): self, old_value: '_UpdatingNode', update: _Update ) -> Optional[tuple[LogScope, Any]]: scope = self._scope(update.key) + do_report = update.force_log if update.value is None: if self._is_set(update.key): self._unset(update.key) - return scope, None - return None - if old_value == update.value: - return None - self._set(update.key, update.value) - return scope, update.value + do_report |= True + elif old_value != update.value: + self._set(update.key, update.value) + do_report |= True + return (scope, update.value) if do_report else None def _get(self, key: str) -> Any: return getattr(self, key)