X-Git-Url: https://cgit.sxemacs.org/?a=blobdiff_plain;f=lisp%2Friece-unread.el;h=06973672a678a29e9b40821afb6201102aecb7cc;hb=acb16fddc18c48ef52cb680a911d8fae18da3ef3;hp=6f64b2e6d6ab6de01c898fa9341074f1d75b9455;hpb=503a6a2b826a93e8acca3dbbe1c282babb77c3ff;p=riece diff --git a/lisp/riece-unread.el b/lisp/riece-unread.el index 6f64b2e..0697367 100644 --- a/lisp/riece-unread.el +++ b/lisp/riece-unread.el @@ -60,29 +60,38 @@ (defvar riece-unread-channels nil) +(defvar riece-unread-enabled nil) + +(defconst riece-unread-description + "Mark channels where \"unread\" messages arrived") + (defun riece-unread-after-display-message-function (message) - (unless (or (riece-message-own-p message) - (riece-message-type message) - (riece-identity-equal (riece-message-target message) - riece-current-channel) - (riece-identity-member (riece-message-target message) - riece-unread-channels)) - (setq riece-unread-channels - (cons (riece-message-target message) riece-unread-channels)) - (riece-emit-signal 'channel-list-changed))) + (if riece-unread-enabled + (let ((target (if (riece-message-private-p message) + (riece-message-speaker message) + (riece-message-target message)))) + (unless (or (riece-message-own-p message) + (riece-message-type message) + (riece-identity-equal target riece-current-channel) + (riece-identity-member target riece-unread-channels)) + (setq riece-unread-channels (cons target riece-unread-channels)) + (riece-emit-signal 'channel-list-changed))))) (defun riece-unread-after-switch-to-channel-function (last) - (setq riece-unread-channels - (delete riece-current-channel - riece-unread-channels))) + (if riece-unread-enabled + (setq riece-unread-channels + (delete riece-current-channel + riece-unread-channels)))) (defun riece-unread-format-identity-for-channel-list-buffer (index identity) - (if (riece-identity-member identity riece-unread-channels) + (if (and riece-unread-enabled + (riece-identity-member identity riece-unread-channels)) (concat (format "%2d:!" index) (riece-format-identity identity)))) (defun riece-unread-format-identity-for-channel-list-indicator (index identity) - (if (riece-identity-member identity riece-unread-channels) + (if (and riece-unread-enabled + (riece-identity-member identity riece-unread-channels)) (let ((string (riece-format-identity identity)) (start 0)) ;; Escape % -> %%. @@ -107,10 +116,6 @@ (defun riece-guess-channel-from-unread () riece-unread-channels) -(defvar riece-command-mode-map) -(defvar riece-dialogue-mode-map) -(defvar riece-channel-list-mode-map) - (defun riece-unread-requires () (let (requires) (if (memq 'riece-highlight riece-addons) @@ -128,12 +133,6 @@ 'riece-unread-format-identity-for-channel-list-buffer) (add-hook 'riece-format-identity-for-channel-list-indicator-functions 'riece-unread-format-identity-for-channel-list-indicator) - (define-key riece-command-mode-map - "\C-c\C-u" 'riece-unread-switch-to-channel) - (define-key riece-dialogue-mode-map - "u" 'riece-unread-switch-to-channel) - (define-key riece-channel-list-mode-map - "u" 'riece-unread-switch-to-channel) (if (memq 'riece-highlight riece-addons) (setq riece-channel-list-mark-face-alist (cons '(?! . riece-channel-list-unread-face) @@ -143,6 +142,30 @@ ;;; 'riece-guess-channel-from-unread)) ) +(defvar riece-command-mode-map) +(defvar riece-dialogue-mode-map) +(defvar riece-channel-list-mode-map) +(defun riece-unread-enable () + (define-key riece-command-mode-map + "\C-c\C-u" 'riece-unread-switch-to-channel) + (define-key riece-dialogue-mode-map + "u" 'riece-unread-switch-to-channel) + (define-key riece-channel-list-mode-map + "u" 'riece-unread-switch-to-channel) + (setq riece-unread-enabled t) + (riece-emit-signal 'channel-list-changed)) + +(defun riece-unread-disable () + (define-key riece-command-mode-map + "\C-c\C-u" nil) + (define-key riece-dialogue-mode-map + "u" nil) + (define-key riece-channel-list-mode-map + "u" nil) + (setq riece-unread-channels nil + riece-unread-enabled nil) + (riece-emit-signal 'channel-list-changed)) + (provide 'riece-unread) ;;; riece-unread.el ends here