(:nickname riece-nickname)
(:username riece-username)
(:password)
- (:function #'open-network-stream)
+ (:function riece-default-open-connection-function)
(:coding riece-default-coding-system))
"Mapping from keywords to default values.
All keywords that can be used must be listed here."))
(error "Server closed"))))
(put 'riece-with-server-buffer 'lisp-indent-function 1)
+(put 'riece-with-server-buffer 'edebug-form-spec '(form body))
+
+(defun riece-flush-send-queue (process &optional reset)
+ (with-current-buffer (process-buffer process)
+ (let ((length 0)
+ string)
+ (if reset
+ (setq riece-send-size 0))
+ (while (and riece-send-queue
+ (<= riece-send-size riece-max-send-size))
+ (setq string (riece-encode-coding-string (car riece-send-queue))
+ length (length string))
+ (if (> length riece-max-send-size)
+ (message "Long message (%d > %d)" length riece-max-send-size)
+ (setq riece-send-size (+ riece-send-size length))
+ (if (<= riece-send-size riece-max-send-size)
+ (process-send-string process string)))
+ (setq riece-send-queue (cdr riece-send-queue)))
+ (if riece-send-queue
+ (riece-run-at-time riece-send-delay nil
+ #'riece-flush-send-queue process t)))))
(defun riece-process-send-string (process string)
(with-current-buffer (process-buffer process)
- (process-send-string process (riece-encode-coding-string string))))
+ (setq riece-send-queue (nconc riece-send-queue (list string))))
+ (riece-flush-send-queue process nil))
(defun riece-current-server-name ()
(or riece-overriding-server-name
(riece-process-send-string process string)))
(defun riece-open-server (server server-name)
- (riece-server-keyword-bind server
- (let (selective-display
- (coding-system-for-read 'binary)
- (coding-system-for-write 'binary)
- process)
- (if (equal server-name "")
- (message "Connecting to IRC server...")
- (message "Connecting to %s..." server-name))
- (setq process
- (funcall function (riece-server-process-name server-name)
- (concat " *IRC*" server-name)
- host service))
- (if (equal server-name "")
- (message "Connecting to IRC server...done")
- (message "Connecting to %s...done" server-name))
- (riece-reset-process-buffer process)
+ (let ((protocol (or (plist-get server :protocol)
+ riece-protocol))
+ function
+ process)
+ (condition-case nil
+ (require (intern (concat "riece-" (symbol-name protocol))))
+ (error))
+ (setq function (intern-soft (concat "riece-"
+ (symbol-name protocol)
+ "-open-server")))
+ (unless function
+ (error "\"%S\" is not supported" protocol))
+ (condition-case nil
+ (setq process (funcall function server server-name))
+ (error))
+ (when process
(with-current-buffer (process-buffer process)
- (setq riece-server-name server-name))
- (set-process-sentinel process 'riece-sentinel)
- (set-process-filter process 'riece-filter)
- (if (equal server-name "")
- (message "Logging in to IRC server...")
- (message "Logging in to %s..." server-name))
- (if riece-reconnect-with-password ;password incorrect or not set.
- (unwind-protect
- ;; XEmacs signals an error when the keyboard cannot be grabbed.
- (condition-case nil
- (setq password (riece-read-passwd "Password: "))
- (error))
- (setq riece-reconnect-with-password nil)))
- (if password
- (riece-process-send-string process
- (format "PASS %s\r\n" password)))
- (riece-process-send-string process
- (format "USER %s * * :%s\r\n"
- (user-real-login-name)
- (or username
- "No information given")))
- (riece-process-send-string process (format "NICK %s\r\n" nickname))
- (with-current-buffer (process-buffer process)
- (setq riece-last-nickname riece-real-nickname
- riece-nick-accepted 'sent
- riece-coding-system coding))
+ (make-local-variable 'riece-protocol)
+ (setq riece-protocol protocol))
(setq riece-server-process-alist
(cons (cons server-name process)
riece-server-process-alist)))))
+(defun riece-quit-server-process (process &optional message)
+ (let ((function (intern-soft
+ (concat "riece-"
+ (with-current-buffer (process-buffer process)
+ (symbol-name riece-protocol))
+ "-quit-server-process"))))
+ (if function
+ (funcall function process message))))
+
(defun riece-reset-process-buffer (process)
(save-excursion
(set-buffer (process-buffer process))
(make-local-variable 'riece-channel-filter)
(make-local-variable 'riece-server-name)
(make-local-variable 'riece-read-point)
+ (make-local-variable 'riece-send-queue)
+ (make-local-variable 'riece-send-size)
+ (setq riece-send-size 0)
(setq riece-read-point (point-min))
(make-local-variable 'riece-obarray)
(setq riece-obarray (make-vector riece-obarray-size 0))
(erase-buffer)))
(defun riece-close-server-process (process)
- (if riece-debug
- (delete-process process)
- (kill-buffer (process-buffer process)))
+ (kill-buffer (process-buffer process))
(setq riece-server-process-alist
(delq (rassq process riece-server-process-alist)
riece-server-process-alist)))
(throw 'found t))
(setq alist (cdr alist)))))))
-(eval-when-compile
- (autoload 'riece-exit "riece"))
-(defun riece-quit-server-process (process &optional message)
- (riece-run-at-time riece-quit-timeout nil
- (lambda (process)
- (when (rassq process riece-server-process-alist)
- (riece-close-server-process process)
- ;; If no server process is available, exit.
- (unless riece-server-process-alist
- (riece-exit))))
- process)
- (riece-process-send-string process
- (if message
- (format "QUIT :%s\r\n" message)
- "QUIT\r\n")))
-
(provide 'riece-server)
;;; riece-server.el ends here