]> git.eshelyaron.com Git - emacs.git/commitdiff
gnus-msg.el: Fix detection of nnir group
authorAndrew Cohen <cohen@andy.bu.edu>
Thu, 4 Apr 2013 22:15:25 +0000 (22:15 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Thu, 4 Apr 2013 22:15:25 +0000 (22:15 +0000)
lisp/gnus/ChangeLog
lisp/gnus/gnus-msg.el
lisp/gnus/nnir.el

index 59be8293bb332f3ac8fbf89d37f32433977a4798..ca78e7c99b440ed1ec9c6a34b5b4b232cf9be460 100644 (file)
@@ -1,3 +1,10 @@
+2013-04-04  Andrew Cohen  <cohen@bu.edu>
+
+       * nnir.el (gnus-nnir-group-p): New function.
+       (nnir-possibly-change-group): Use it.
+
+       * gnus-msg.el (gnus-setup-message): Use it.
+
 2013-04-04  Katsumi Yamaoka  <yamaoka@jpl.org>
 
        * mml.el (mml-minibuffer-read-description): Use `default' insted of
index 7503afdab36c97fd302b0598603961a51544f617..36135556c738c37fdfeab4d167182bc2af8e0460 100644 (file)
@@ -417,6 +417,7 @@ Thank you for your help in stamping out bugs.
 
 (autoload 'nnir-article-number "nnir" nil nil 'macro)
 (autoload 'nnir-article-group "nnir" nil nil 'macro)
+(autoload 'gnus-nnir-group-p "nnir")
 
 
 (defvar gnus-article-reply nil)
@@ -430,17 +431,15 @@ Thank you for your help in stamping out bugs.
     `(let ((,winconf (current-window-configuration))
           (,winconf-name gnus-current-window-configuration)
           (,buffer (buffer-name (current-buffer)))
-          (,article (or  (when (and
-                                (string-match "^nnir:" gnus-newsgroup-name)
-                                gnus-article-reply)
-                           (nnir-article-number gnus-article-reply))
-                          gnus-article-reply))
-          (,yanked gnus-article-yanked-articles)
-          (,group (or (when (and
-                             (string-match "^nnir:" gnus-newsgroup-name)
+          (,article (if (and (gnus-nnir-group-p gnus-newsgroup-name)
                              gnus-article-reply)
-                        (nnir-article-group gnus-article-reply))
-                      gnus-newsgroup-name))
+                        (nnir-article-number gnus-article-reply)
+                      gnus-article-reply))
+          (,yanked gnus-article-yanked-articles)
+          (,group (if (and (gnus-nnir-group-p gnus-newsgroup-name)
+                           gnus-article-reply)
+                      (nnir-article-group gnus-article-reply)
+                    gnus-newsgroup-name))
           (message-header-setup-hook
            (copy-sequence message-header-setup-hook))
           (mbl mml-buffer-list)
index e7d004a8b2c31b88de4aaa40d29843c26b4e9e8f..b96f0c1cb789a9621cc31002688943aa35c149f3 100644 (file)
@@ -1707,6 +1707,12 @@ actually)."
 
 ;;; Util Code:
 
+(defun gnus-nnir-group-p (group)
+  "Say whether GROUP is nnir or not."
+  (if (gnus-group-prefixed-p group)
+      (eq 'nnir (car (gnus-find-method-for-group group)))
+    (and group (string-match "^nnir" group))))
+
 (defun nnir-read-parms (nnir-search-engine)
   "Reads additional search parameters according to `nnir-engines'."
   (let ((parmspec (caddr (assoc nnir-search-engine nnir-engines))))
@@ -1754,7 +1760,7 @@ environment unless `not-global' is non-nil."
 
 (defun nnir-possibly-change-group (group &optional server)
   (or (not server) (nnir-server-opened server) (nnir-open-server server))
-  (when (and group (string-match "\\`nnir" group))
+  (when (gnus-nnir-group-p group)
     (setq nnir-artlist (gnus-group-get-parameter
                        (gnus-group-prefixed-name
                         (gnus-group-short-name group) '(nnir "nnir"))