]> git.eshelyaron.com Git - emacs.git/commitdiff
Merge changes made in Gnus trunk.
authorAndrew Cohen <cohen@andy.bu.edu>
Wed, 20 Jul 2011 14:19:52 +0000 (14:19 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Wed, 20 Jul 2011 14:19:52 +0000 (14:19 +0000)
nnimap.el (nnimap-make-thread-query): New utility function to format an imap thread search query.
 (nnimap-request-thread): Use it.
gnus-sum.el (gnus-handle-ephemeral-exit): Ensure we are setting the right select-method if we are not going back to the group buffer.

lisp/gnus/ChangeLog
lisp/gnus/gnus-sum.el
lisp/gnus/nnimap.el

index d18be47fb9de07ece5ad3cd04764760271ac99fc..3dc1fe142bf88def65351767b69c4370875992f5 100644 (file)
@@ -1,3 +1,12 @@
+2011-07-20  Andrew Cohen  <cohen@andy.bu.edu>
+
+       * nnimap.el (nnimap-make-thread-query): New utility function to format
+       an imap thread search query.
+       (nnimap-request-thread): Use it.
+
+       * gnus-sum.el (gnus-handle-ephemeral-exit): Ensure we are setting the
+       right select-method if we are not going back to the group buffer.
+
 2011-07-19  Lars Magne Ingebrigtsen  <larsi@gnus.org>
 
        * gnus-group.el (gnus-group-read-ephemeral-group): Make sure we don't
index 86ff0180f55f288d76cca4b21c30b6039e228d6b..6e8fc63d79f85d15c407e49765d957e2f47b5321 100644 (file)
@@ -7339,6 +7339,9 @@ The state which existed when entering the ephemeral is reset."
   (if (not (buffer-name (car quit-config)))
       (gnus-configure-windows 'group 'force)
     (set-buffer (car quit-config))
+    (unless (eq (cdr quit-config) 'group)
+      (setq gnus-current-select-method
+           (gnus-find-method-for-group gnus-newsgroup-name)))
     (cond ((eq major-mode 'gnus-summary-mode)
           (gnus-set-global-variables))
          ((eq major-mode 'gnus-article-mode)
index ef5bee716299e56991dde32d9c6d7c67cc996fab..385522759b66429d678883fcb425a39eed923828 100644 (file)
@@ -1567,25 +1567,14 @@ textual parts.")
 
 (deffoo nnimap-request-thread (header &optional group server)
   (when (nnimap-possibly-change-group group server)
-      (let* ((id (mail-header-id header))
-        (refs (split-string
-               (or (mail-header-references header)
-                   "")))
-        (cmd (let ((value
-                    (format
-                     "(OR HEADER REFERENCES %s HEADER Message-Id %s)"
-                     id id)))
-               (dolist (refid refs value)
-                 (setq value (format
-                              "(OR (OR HEADER Message-Id %s HEADER REFERENCES %s) %s)"
-                              refid refid value)))))
-        (result (with-current-buffer (nnimap-buffer)
-                  (nnimap-command  "UID SEARCH %s" cmd))))
-    (when result
-      (gnus-fetch-headers
-       (and (car result) (delete 0 (mapcar #'string-to-number
-                                          (cdr (assoc "SEARCH" (cdr result))))))
-       nil t)))))
+    (let* ((cmd (nnimap-make-thread-query header))
+          (result (with-current-buffer (nnimap-buffer)
+                    (nnimap-command  "UID SEARCH %s" cmd))))
+      (when result
+       (gnus-fetch-headers
+        (and (car result) (delete 0 (mapcar #'string-to-number
+                                            (cdr (assoc "SEARCH" (cdr result))))))
+        nil t)))))
 
 (defun nnimap-possibly-change-group (group server)
   (let ((open-result t))
@@ -1951,6 +1940,21 @@ textual parts.")
                  group-art))
          nnimap-incoming-split-list)))
 
+(defun nnimap-make-thread-query (header)
+  (let* ((id  (mail-header-id header))
+        (refs (split-string
+               (or (mail-header-references header)
+                   "")))
+       (value
+        (format
+         "(OR HEADER REFERENCES %s HEADER Message-Id %s)"
+         id id)))
+    (dolist (refid refs value)
+      (setq value (format
+                  "(OR (OR HEADER Message-Id %s HEADER REFERENCES %s) %s)"
+                  refid refid value)))))
+
+
 (provide 'nnimap)
 
 ;;; nnimap.el ends here