Tags: patch The function `erc-banlist-update' conditionally modifies the local variable `erc-channel-banlist'." As originally envisioned, this list remains synced with the server's because `erc-banlist-update' runs whenever the client receives a MODE command. But due to a bug in the logic surrounding an internal flag (meant to regulate meaningful action by the function), synchronization is inconsistent and difficult to predict, which makes `erc-channel-banlist' ultimately unreliable. Much of this can be solved by simply wiring in ban-list syncing to the MODE-handling "framework" introduced by bug#67220. So instead of the current situation, in which `erc-banlist-update' only understands "+b" or "-b" but not "+mb", etc., we'll have a reliable solution for handling all such permutations. This *should* have been addressed by bug#67220 along with everything else in that arena, but unscrambling all the aforementioned state-flag business seemed a chore too many at the time, ISTR. The last two of the attached patches aim to improve the situation by updating `erc-channel-banlist' on a rolling basis, unconditionally. On the UX side, they provide third-party modules with a new function, `erc-sync-banlist', that effectively guarantees `erc-channel-banlist' will remain in sync for the remainder of the session, once invoked. I've also run into some related issues on the interactive side with the slash commands /BANLIST and /MASSUNBAN. Currently, issuing a /MASSUNBAN corrupts synchronization, potentially across all sessions. For example, issuing a subsequent /BANLIST won't send a "MODE #chan b" to refresh `erc-channel-banlist' as it usually does. Instead, it will proceed in listing the variable's stale contents, which could potentially confuse a channel operator and lead to unfortunate social situations. The first few patches in the set are mostly unrelated fixes. The second tackles a memory leak introduced by Bug#67677, which added the "msg props" internal framework for organizing per-message text props. The third patch is of a supporting nature and internally binds the current `erc-response' object for hooks and handlers, to allow easier access toward the business end of the call stack. I was hoping to avoid such a change until 5.7, but circumstances dictate otherwise. Thanks. In GNU Emacs 31.0.50 (build 1, x86_64-pc-linux-gnu, GTK+ Version 3.24.43, cairo version 1.18.0) of 2024-08-19 built on localhost Repository revision: a876c4d7a17df152e3e78800c76ddf158f632ee5 Repository branch: master Windowing system distributor 'The X.Org Foundation', version 11.0.12401002 System Description: Fedora Linux 40 (Workstation Edition) Configured using: 'configure --enable-check-lisp-object-type --enable-checking=yes,glyphs 'CFLAGS=-O0 -g3' PKG_CONFIG_PATH=:/usr/lib64/pkgconfig:/usr/share/pkgconfig' Configured features: ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG LCMS2 LIBOTF LIBSELINUX LIBSYSTEMD LIBXML2 M17N_FLT MODULES NATIVE_COMP NOTIFY INOTIFY PDUMPER PNG RSVG SECCOMP SOUND SQLITE3 THREADS TIFF TOOLKIT_SCROLL_BARS WEBP X11 XDBE XIM XINPUT2 XPM GTK3 ZLIB Important settings: value of $LANG: en_US.UTF-8 value of $XMODIFIERS: @im=ibus locale-coding-system: utf-8-unix Major mode: Lisp Interaction Minor modes in effect: tooltip-mode: t global-eldoc-mode: t eldoc-mode: t show-paren-mode: t electric-indent-mode: t mouse-wheel-mode: t tool-bar-mode: t menu-bar-mode: t file-name-shadow-mode: t global-font-lock-mode: t font-lock-mode: t blink-cursor-mode: t minibuffer-regexp-mode: t line-number-mode: t indent-tabs-mode: t transient-mark-mode: t auto-composition-mode: t auto-encryption-mode: t auto-compression-mode: t Load-path shadows: None found. Features: (shadow sort compile comint ansi-osc ansi-color ring comp-run comp-common mail-extr emacsbug message mailcap yank-media puny dired dired-loaddefs rfc822 mml mml-sec epa epg rfc6068 epg-config gnus-util text-property-search time-date mm-decode mm-bodies mm-encode mail-parse rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047 rfc2045 ietf-drums mm-util mail-prsvr mail-utils erc derived auth-source eieio eieio-core icons password-cache json map format-spec erc-backend erc-networks easy-mmode byte-opt bytecomp byte-compile erc-common inline cl-extra help-mode erc-compat cl-seq cl-macs gv pcase rx compat subr-x cl-loaddefs cl-lib erc-loaddefs rmc iso-transl tooltip cconv eldoc paren electric uniquify ediff-hook vc-hooks lisp-float-type elisp-mode mwheel term/x-win x-win term/common-win x-dnd touch-screen tool-bar dnd fontset image regexp-opt fringe tabulated-list replace newcomment text-mode lisp-mode prog-mode register page tab-bar menu-bar rfn-eshadow isearch easymenu timer select scroll-bar mouse jit-lock font-lock syntax font-core term/tty-colors frame minibuffer nadvice seq simple cl-generic indonesian philippine cham georgian utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao korean japanese eucjp-ms cp51932 hebrew greek romanian slovak czech european ethiopic indian cyrillic chinese composite emoji-zwj charscript charprop case-table epa-hook jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button loaddefs theme-loaddefs faces cus-face macroexp files window text-properties overlay sha1 md5 base64 format env code-pages mule custom widget keymap hashtable-print-readable backquote threads dbusbind inotify lcms2 dynamic-setting system-font-setting font-render-setting cairo gtk x-toolkit xinput2 x multi-tty move-toolbar make-network-process native-compile emacs) Memory information: ((conses 16 159110 10474) (symbols 48 11702 0) (strings 32 28787 4600) (string-bytes 1 1011760) (vectors 16 17066) (vector-slots 8 185078 5037) (floats 8 30 1) (intervals 56 357 0) (buffers 984 12))