X-Git-Url: https://cgit.sxemacs.org/?a=blobdiff_plain;f=lisp%2Friece-400.el;h=e469edf6d7a6eb565442743305cf5b0a732569ca;hb=ea26c9283b9a4aff978f21cfeb519a0daa7fc213;hp=96816076cc7ea5509ad9974119c8f6547431f9e5;hpb=6c8611183c009716570d6628fa12b53d85e437f0;p=riece diff --git a/lisp/riece-400.el b/lisp/riece-400.el index 9681607..e469edf 100644 --- a/lisp/riece-400.el +++ b/lisp/riece-400.el @@ -28,7 +28,7 @@ (require 'riece-misc) (eval-when-compile - (autoload 'riece-default-handle-numeric-reply "riece-filter")) + (autoload 'riece-default-handle-numeric-reply "riece-handle")) (defun riece-handle-default-400-message (prefix number name string) (riece-default-handle-numeric-reply riece-error-prefix prefix number name string)) @@ -63,6 +63,26 @@ (message "Password incorrect from %s." prefix) (setq riece-reconnect-with-password t)) +(defun riece-handle-475-message (prefix number name string) + "ERR_BADCHANNELKEY \" :Cannot join channel (+k)\"." + (let* ((parameters (riece-split-parameters string)) + (channel-identity (riece-make-identity (car parameters) + riece-server-name)) + key) + (message "%s: %s" (car parameters) (nth 1 parameters)) + (setq key + (condition-case nil + (let (inhibit-quit) + (riece-read-passwd + (format "Key for %s: " + (riece-format-identity channel-identity t)))) + (quit + (message "Key for %s: Quit" + (riece-format-identity channel-identity t)) + 'quit))) + (unless (eq key 'quit) + (riece-command-join-channel channel-identity key)))) + (provide 'riece-400) ;;; riece-400.el ends here