From: Lars Magne Ingebrigtsen Date: Thu, 2 Sep 2010 00:03:57 +0000 (+0000) Subject: gnus.el, gnus-html.el: Use the deleted text as the image alt text. X-Git-Tag: emacs-pretest-24.0.90~104^2~275^2~438^2~48^2~155 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=075843d346ec303963e065a8fe61a98a4210dc16;p=emacs.git gnus.el, gnus-html.el: Use the deleted text as the image alt text. --- diff --git a/lisp/gnus/ChangeLog b/lisp/gnus/ChangeLog index 711e7194d39..b85a4ce1c93 100644 --- a/lisp/gnus/ChangeLog +++ b/lisp/gnus/ChangeLog @@ -1,3 +1,11 @@ +2010-09-01 Lars Magne Ingebrigtsen + + * gnus-html.el (gnus-html-put-image): Use the deleted text as the image + alt text. + + * gnus.el (gnus-string-or): Fix the syntax to not use eval or + overshadow variable bindings. + 2010-09-01 Teodor Zlatanov * gnus-html.el (gnus-html-wash-tags) diff --git a/lisp/gnus/gnus-html.el b/lisp/gnus/gnus-html.el index a89a3f57ff1..b6b4c507825 100644 --- a/lisp/gnus/gnus-html.el +++ b/lisp/gnus/gnus-html.el @@ -132,17 +132,19 @@ fit these criteria." (setq image (gnus-create-image (buffer-string) nil t)))) (when image - (delete-region start end) - (gnus-put-image image))) + (let ((string (buffer-substring start end))) + (delete-region start end) + (gnus-put-image image (gnus-string-or string "*"))))) ;; Normal, external URL. (when (or (null gnus-blocked-images) (not (string-match gnus-blocked-images url))) (let ((file (gnus-html-image-id url))) (if (file-exists-p file) ;; It's already cached, so just insert it. - (when (gnus-html-put-image file (point)) + (let ((string (buffer-substring start end))) ;; Delete the ALT text. - (delete-region start end)) + (delete-region start end) + (gnus-html-put-image file (point) string)) ;; We don't have it, so schedule it for fetching ;; asynchronously. (push (list url @@ -209,13 +211,14 @@ fit these criteria." ;; article before the image arrived. (not (= (marker-position (cadr spec)) (point-min)))) (with-current-buffer buffer - (let ((inhibit-read-only t)) - (when (gnus-html-put-image file (cadr spec)) - (delete-region (1+ (cadr spec)) (caddr spec)))))) + (let ((inhibit-read-only t) + (string (buffer-substring (cadr spec) (caddr spec)))) + (delete-region (cadr spec) (caddr spec)) + (gnus-html-put-image file (cadr spec) string)))) (when images (gnus-html-schedule-image-fetching buffer images))))) -(defun gnus-html-put-image (file point) +(defun gnus-html-put-image (file point string) (when (display-graphic-p) (let ((image (ignore-errors (gnus-create-image file)))) @@ -229,11 +232,14 @@ fit these criteria." (= (car (image-size image t)) 30) (= (cdr (image-size image t)) 30)))) (progn - (gnus-put-image (gnus-html-rescale-image image)) + (gnus-put-image (gnus-html-rescale-image image) + (gnus-string-or string "*")) t) + (insert string) (when (fboundp 'find-image) (gnus-put-image (find-image - '((:type xpm :file "lock-broken.xpm"))))) + '((:type xpm :file "lock-broken.xpm"))) + (gnus-string-or string "*"))) nil))))) (defun gnus-html-rescale-image (image) diff --git a/lisp/gnus/gnus.el b/lisp/gnus/gnus.el index b3752506c8f..25c1bc44296 100644 --- a/lisp/gnus/gnus.el +++ b/lisp/gnus/gnus.el @@ -3289,12 +3289,12 @@ with a `subscribed' parameter." (defmacro gnus-string-or (&rest strings) "Return the first element of STRINGS that is a non-blank string. STRINGS will be evaluated in normal `or' order." - `(gnus-string-or-1 ',strings)) + `(gnus-string-or-1 (list ,@strings))) (defun gnus-string-or-1 (strings) (let (string) (while strings - (setq string (eval (pop strings))) + (setq string (pop strings)) (if (string-match "^[ \t]*$" string) (setq string nil) (setq strings nil)))