From: Philip Kaludercic Date: Sun, 31 Jul 2022 10:45:29 +0000 (+0200) Subject: Fix electric paring in rcirc buffers X-Git-Tag: emacs-29.0.90~1447^2~607 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=df8dede8585257a2ee76ed93d6ecb6cf117e124a;p=emacs.git Fix electric paring in rcirc buffers * rcirc.el (rcirc--electric-pair-inhibit): Add new predicate function. (rcirc-mode): Use rcirc--electric-pair-inhibit. --- diff --git a/lisp/net/rcirc.el b/lisp/net/rcirc.el index 54d7861f445..065398b64af 100644 --- a/lisp/net/rcirc.el +++ b/lisp/net/rcirc.el @@ -1388,6 +1388,21 @@ Each element looks like (FILENAME . TEXT).") "The current number of responses printed in this channel. This number is independent of the number of lines in the buffer.") +(defun rcirc--electric-pair-inhibit (char) + "Check whether CHAR should be paired by `electric-pair-mode'. +This uses the default value inhibition predicate (as set by +`electric-pair-inhibit-predicate'), but ignores all text prior to +the prompt so that mismatches parentheses by some other message +does not confuse the pairing." + (let ((fallback (default-value 'electric-pair-inhibit-predicate))) + ;; The assumption is that this function is only bound by + ;; `rcirc-mode', and should never be the global default. + (cl-assert (not (eq fallback #'rcirc--electric-pair-inhibit))) + (save-restriction + (widen) + (narrow-to-region rcirc-prompt-start-marker (point-max)) + (funcall fallback char)))) + (defun rcirc-mode (process target) "Initialize an IRC buffer for writing with TARGET. PROCESS is the process object used for communication. @@ -1459,6 +1474,9 @@ PROCESS is the process object used for communication. (when rcirc-cycle-completion-flag (setq-local completion-cycle-threshold t)) + (setq-local electric-pair-inhibit-predicate + #'rcirc--electric-pair-inhibit) + (run-mode-hooks 'rcirc-mode-hook)) (defun rcirc-update-prompt (&optional all)