# HG changeset patch # User Glenn Morris # Date 1254535648 0 # Node ID 7f82f9367cd14fabb2fa488fc26fd2b50e417deb # Parent 175a7f7ac06946ea7fd4c1f4fefed35b0043777f (rmail-generate-viewer-buffer): Be more careful about reusing existing buffers, in case we happen to visit two files with the same basename. (Bug#4593) diff -r 175a7f7ac069 -r 7f82f9367cd1 lisp/ChangeLog --- a/lisp/ChangeLog Fri Oct 02 19:53:53 2009 +0000 +++ b/lisp/ChangeLog Sat Oct 03 02:07:28 2009 +0000 @@ -1,3 +1,9 @@ +2009-10-03 Glenn Morris + + * mail/rmail.el (rmail-generate-viewer-buffer): Be more careful about + reusing existing buffers, in case we happen to visit two files with the + same basename. (Bug#4593) + 2009-10-02 Eli Zaretskii * makefile.w32-in (update-subdirs-CMD): Add cedet to diff -r 175a7f7ac069 -r 7f82f9367cd1 lisp/mail/rmail.el --- a/lisp/mail/rmail.el Fri Oct 02 19:53:53 2009 +0000 +++ b/lisp/mail/rmail.el Sat Oct 03 02:07:28 2009 +0000 @@ -1294,11 +1294,15 @@ (defun rmail-generate-viewer-buffer () "Return a reusable buffer suitable for viewing messages. Create the buffer if necessary." - (let* ((suffix (file-name-nondirectory (or buffer-file-name (buffer-name)))) - (name (format " *message-viewer %s*" suffix)) - (buf (get-buffer name))) - (or buf - (generate-new-buffer name)))) + ;; We want to reuse any existing view buffer, so as not to create an + ;; endless number of them. But we must avoid clashes if we visit + ;; two different rmail files with the same basename (Bug#4593). + (if (and (local-variable-p 'rmail-view-buffer) + (buffer-live-p rmail-view-buffer)) + rmail-view-buffer + (generate-new-buffer + (format " *message-viewer %s*" + (file-name-nondirectory (or buffer-file-name (buffer-name))))))) (defun rmail-swap-buffers () "Swap text between current buffer and `rmail-view-buffer'. @@ -1367,6 +1371,9 @@ (set-buffer-multibyte nil) (with-current-buffer (setq rmail-view-buffer (rmail-generate-viewer-buffer)) (setq buffer-undo-list t) + ;; Note that this does not erase the buffer. Should it? + ;; It depends on how this is called. If somehow called with the + ;; rmail buffers swapped, it would erase the message collection. (set (make-local-variable 'rmail-overlay-list) nil) (set-buffer-multibyte t) ;; Force C-x C-s write Unix EOLs.