]> git.eshelyaron.com Git - emacs.git/commitdiff
gnus-sum.el (gnus-articles-to-read): Revert back to old behaviour if we're selecting...
authorLars Magne Ingebrigtsen <larsi@gnus.org>
Tue, 15 Mar 2011 22:57:48 +0000 (22:57 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Tue, 15 Mar 2011 22:57:48 +0000 (22:57 +0000)
lisp/gnus/ChangeLog
lisp/gnus/gnus-sum.el

index 1b4cd186951c9c49d330b42952014f849c2bd017..27fdc563db961fabe506ba883370f52e3de4736e 100644 (file)
@@ -1,5 +1,8 @@
 2011-03-15  Lars Magne Ingebrigtsen  <larsi@gnus.org>
 
+       * gnus-sum.el (gnus-articles-to-read): Revert back to old behaviour if
+       we're selecting a group with unread articles.
+
        * nnimap.el (nnimap-open-connection-1): Allow `network-only', too.
 
        * gssapi.el: New file separated out from imap.el to provide a general
index 0fa1d5979c7ad62bd7c8c83f72b8f7b908ee7e30..385460378b1897816122e57b4a6acb5cc3da1d67 100644 (file)
@@ -5798,7 +5798,8 @@ If SELECT-ARTICLES, only select those articles from GROUP."
 
 (defun gnus-articles-to-read (group &optional read-all)
   "Find out what articles the user wants to read."
-  (let* ((articles
+  (let* ((only-read-p t)
+        (articles
          ;; Select all articles if `read-all' is non-nil, or if there
          ;; are no unread articles.
          (if (or read-all
@@ -5822,6 +5823,7 @@ If SELECT-ARTICLES, only select those articles from GROUP."
                 (gnus-uncompress-range (gnus-active group)))
               (gnus-cache-articles-in-group group))
            ;; Select only the "normal" subset of articles.
+           (setq only-read-p nil)
            (gnus-sorted-nunion
             (gnus-sorted-union gnus-newsgroup-dormant gnus-newsgroup-marked)
             gnus-newsgroup-unreads)))
@@ -5845,18 +5847,25 @@ If SELECT-ARTICLES, only select those articles from GROUP."
                  (let* ((cursor-in-echo-area nil)
                         (initial (gnus-parameter-large-newsgroup-initial
                                   gnus-newsgroup-name))
+                        (default (if only-read-p
+                                     (or initial gnus-large-newsgroup)
+                                   number))
                         (input
                          (read-string
-                          (format
-                           "How many articles from %s (available %d, default %d): "
-                           (gnus-group-decoded-name
-                            (gnus-group-real-name gnus-newsgroup-name))
-                           number
-                           (or initial gnus-large-newsgroup))
+                          (if only-read-p
+                              (format
+                             "How many articles from %s (available %d, default %d): "
+                             (gnus-group-decoded-name
+                              (gnus-group-real-name gnus-newsgroup-name))
+                             number default)
+                            (format
+                               "How many articles from %s (%d available): "
+                               (gnus-group-decoded-name
+                                (gnus-group-real-name gnus-newsgroup-name))
+                               default))
                           nil
                           nil
-                          (number-to-string
-                           (or initial gnus-large-newsgroup)))))
+                          (number-to-string default))))
                    (if (string-match "^[ \t]*$" input) number input)))
                 ((and (> scored marked) (< scored number)
                       (> (- scored number) 20))