From: Lars Ingebrigtsen Date: Sun, 5 Feb 2012 06:31:38 +0000 (+0000) Subject: nnimap.el: Fix inloop if the server dies before the async -finish is called X-Git-Tag: emacs-pretest-24.0.94~309 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=98366438c7163579bfc47b0d2eabe875081d51b6;p=emacs.git nnimap.el: Fix inloop if the server dies before the async -finish is called --- diff --git a/lisp/gnus/ChangeLog b/lisp/gnus/ChangeLog index 10505cd8e48..740a2340243 100644 --- a/lisp/gnus/ChangeLog +++ b/lisp/gnus/ChangeLog @@ -1,3 +1,11 @@ +2012-02-05 Lars Ingebrigtsen + + * nnimap.el (nnimap-open-server): Allow switching the nnoo server + without reconnecting. + (nnimap-possibly-change-group): Ditto. + (nnimap-finish-retrieve-group-infos): Don't reconnect if the server + connection has died before being called. + 2012-02-02 Lars Ingebrigtsen * nnimap.el (nnimap-retrieve-group-data-early): Don't say we're doing diff --git a/lisp/gnus/nnimap.el b/lisp/gnus/nnimap.el index a5e82389ab5..09cf554312b 100644 --- a/lisp/gnus/nnimap.el +++ b/lisp/gnus/nnimap.el @@ -269,14 +269,16 @@ textual parts.") result)) (mapconcat #'identity (nreverse result) ","))))) -(deffoo nnimap-open-server (server &optional defs) +(deffoo nnimap-open-server (server &optional defs no-reconnect) (if (nnimap-server-opened server) t (unless (assq 'nnimap-address defs) (setq defs (append defs (list (list 'nnimap-address server))))) (nnoo-change-server 'nnimap server defs) - (or (nnimap-find-connection nntp-server-buffer) - (nnimap-open-connection nntp-server-buffer)))) + (if no-reconnect + (nnimap-find-connection nntp-server-buffer) + (or (nnimap-find-connection nntp-server-buffer) + (nnimap-open-connection nntp-server-buffer))))) (defun nnimap-make-process-buffer (buffer) (with-current-buffer @@ -1278,7 +1280,7 @@ textual parts.") (deffoo nnimap-finish-retrieve-group-infos (server infos sequences) (when (and sequences - (nnimap-possibly-change-group nil server) + (nnimap-possibly-change-group nil server t) ;; Check that the process is still alive. (get-buffer-process (nnimap-buffer)) (memq (process-status (get-buffer-process (nnimap-buffer))) @@ -1633,11 +1635,11 @@ textual parts.") (cdr (assoc "SEARCH" (cdr result)))))) nil t)))))) -(defun nnimap-possibly-change-group (group server) +(defun nnimap-possibly-change-group (group server &optional no-reconnect) (let ((open-result t)) (when (and server (not (nnimap-server-opened server))) - (setq open-result (nnimap-open-server server))) + (setq open-result (nnimap-open-server server nil no-reconnect))) (cond ((not open-result) nil)