From: Lars Ingebrigtsen Date: Sat, 18 Feb 2012 22:28:00 +0000 (+0000) Subject: shr.el (shr-image-fetched): Be more defensive about killing the correct buffer X-Git-Tag: emacs-pretest-24.0.94~115 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=0e2cebe57e75c570c7fcac25890ce995fbc7c598;p=emacs.git shr.el (shr-image-fetched): Be more defensive about killing the correct buffer --- diff --git a/lisp/gnus/ChangeLog b/lisp/gnus/ChangeLog index 61f6ff9a3d3..d2f2b1b4660 100644 --- a/lisp/gnus/ChangeLog +++ b/lisp/gnus/ChangeLog @@ -1,3 +1,8 @@ +2012-02-18 Lars Ingebrigtsen + + * shr.el (shr-image-fetched): Make sure we really kill the right + buffer. + 2012-02-16 Leo Liu * gnus-start.el (gnus-1): Avoid duplicate entries. diff --git a/lisp/gnus/shr.el b/lisp/gnus/shr.el index f3d75032926..dd0f1599c36 100644 --- a/lisp/gnus/shr.el +++ b/lisp/gnus/shr.el @@ -524,20 +524,21 @@ the URL of the image to the kill buffer instead." directory))))) (defun shr-image-fetched (status buffer start end) - (when (and (buffer-name buffer) - (not (plist-get status :error))) - (url-store-in-cache (current-buffer)) - (when (or (search-forward "\n\n" nil t) - (search-forward "\r\n\r\n" nil t)) - (let ((data (buffer-substring (point) (point-max)))) - (with-current-buffer buffer - (save-excursion - (let ((alt (buffer-substring start end)) - (inhibit-read-only t)) - (delete-region start end) - (goto-char start) - (funcall shr-put-image-function data alt))))))) - (kill-buffer (current-buffer))) + (let ((image-buffer (current-buffer))) + (when (and (buffer-name buffer) + (not (plist-get status :error))) + (url-store-in-cache image-buffer) + (when (or (search-forward "\n\n" nil t) + (search-forward "\r\n\r\n" nil t)) + (let ((data (buffer-substring (point) (point-max)))) + (with-current-buffer buffer + (save-excursion + (let ((alt (buffer-substring start end)) + (inhibit-read-only t)) + (delete-region start end) + (goto-char start) + (funcall shr-put-image-function data alt))))))) + (kill-buffer image-buffer))) (defun shr-put-image (data alt) "Put image DATA with a string ALT. Return image."