diff options
| author | Basil L. Contovounesios <contovob@tcd.ie> | 2019-03-24 14:12:58 +0000 | 
|---|---|---|
| committer | Eric Abrahamsen <eric@ericabrahamsen.net> | 2019-03-24 10:11:29 -0700 | 
| commit | 03e916beb0186f3707cd238650298870bf471575 (patch) | |
| tree | ff3dab09aecbde6e12fccfa57151939c5e3126df /lisp/gnus/gnus-sum.el | |
| parent | d2a9273c77182e8aa3468fbb5c71f2729639c465 (diff) | |
| download | emacs-03e916beb0186f3707cd238650298870bf471575.tar.gz | |
Fix Gnus duplicate article unsuppression
* lisp/gnus/gnus-sum.el (gnus-summary-mode-group): Declare before
first use to silence byte-compiler.
(gnus-summary-select-article): Simplify boolean expression.
(gnus-summary-move-article): Do not try to unsuppress article when
duplicate suppression is disabled. (bug#34973, bug#34974)
Diffstat (limited to 'lisp/gnus/gnus-sum.el')
| -rw-r--r-- | lisp/gnus/gnus-sum.el | 25 | 
1 files changed, 12 insertions, 13 deletions
| diff --git a/lisp/gnus/gnus-sum.el b/lisp/gnus/gnus-sum.el index 85c902a5e43..f09c0fbb58e 100644 --- a/lisp/gnus/gnus-sum.el +++ b/lisp/gnus/gnus-sum.el @@ -3053,6 +3053,11 @@ When FORCE, rebuild the tool bar."  (defvar bidi-paragraph-direction) +(defvar gnus-summary-mode-group nil +  "Variable for communication with `gnus-summary-mode'. +Allows the `gnus-newsgroup-name' local variable to be set before +the summary mode hooks are run.") +  (define-derived-mode gnus-summary-mode gnus-mode "Summary"    "Major mode for reading articles.  \\<gnus-summary-mode-map> @@ -3468,11 +3473,6 @@ display only a single character."  					       (point)  					       (current-buffer)))))) -(defvar gnus-summary-mode-group nil -  "Variable for communication with `gnus-summary-mode'. -Allows the `gnus-newsgroup-name' local variable to be set before -the summary mode hooks are run.") -  (defun gnus-summary-setup-buffer (group)    "Initialize summary buffer for GROUP.  This function does all setup work that relies on the specific @@ -7744,7 +7744,7 @@ be displayed."    (unless (derived-mode-p 'gnus-summary-mode)      (set-buffer gnus-summary-buffer))    (let ((article (or article (gnus-summary-article-number))) -	(all-headers (not (not all-headers))) ;Must be t or nil. +        (all-headers (and all-headers t)) ; Must be t or nil.  	gnus-summary-display-article-function)      (and (not pseudo)  	 (gnus-summary-article-pseudo-p article) @@ -9978,13 +9978,12 @@ ACTION can be either `move' (the default), `crosspost' or `copy'."  		 (crosspost "Crosspost" "Crossposting")))  	(copy-buf (save-excursion  		    (nnheader-set-temp-buffer " *copy article*"))) -	art-group to-method new-xref article to-groups +        art-group to-method new-xref to-groups  	articles-to-update-marks encoded)      (unless (assq action names)        (error "Unknown action %s" action))      ;; Read the newsgroup name. -    (when (and (not to-newsgroup) -	       (not select-method)) +    (unless (or to-newsgroup select-method)        (if (and gnus-move-split-methods  	       (not  		(and (memq gnus-current-article articles) @@ -10029,8 +10028,7 @@ ACTION can be either `move' (the default), `crosspost' or `copy'."  		  (or (car select-method)  		      (gnus-group-decoded-name to-newsgroup))  		  articles) -    (while articles -      (setq article (pop articles)) +    (dolist (article articles)        ;; Set any marks that may have changed in the summary buffer.        (when gnus-preserve-marks  	(gnus-summary-push-marks-to-backend article)) @@ -10039,8 +10037,9 @@ ACTION can be either `move' (the default), `crosspost' or `copy'."         (cond  	;; Move the article.  	((eq action 'move) -	 ;; Remove this article from future suppression. -	 (gnus-dup-unsuppress-article article) +         (when gnus-suppress-duplicates +           ;; Remove this article from future suppression. +           (gnus-dup-unsuppress-article article))  	 (let* ((from-method (gnus-find-method-for-group  			      gnus-newsgroup-name))  		(to-method (or select-method | 
