From: Lars Magne Ingebrigtsen Date: Tue, 16 Nov 2010 00:04:25 +0000 (+0000) Subject: Allow gnus-html to register image displayer callbacks. X-Git-Tag: emacs-pretest-24.0.90~104^2~275^2~438^2~45^2~227 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=0073e0313a029f5bba231a147f0d4f1bb029dd43;p=emacs.git Allow gnus-html to register image displayer callbacks. gnus-html.el (gnus-html-wash-images): Register a displayer. gnus-util.el (gnus-find-text-property-region): Return markers. --- diff --git a/lisp/gnus/ChangeLog b/lisp/gnus/ChangeLog index e1265e7cc43..ddaa2266530 100644 --- a/lisp/gnus/ChangeLog +++ b/lisp/gnus/ChangeLog @@ -1,5 +1,9 @@ 2010-11-15 Lars Magne Ingebrigtsen + * gnus-html.el (gnus-html-wash-images): Register a displayer. + + * gnus-util.el (gnus-find-text-property-region): Return markers. + * shr.el (shr-tag-img): Put a displayer in the text property. * gnus-util.el (gnus-find-text-property-region): New utility function. diff --git a/lisp/gnus/gnus-html.el b/lisp/gnus/gnus-html.el index 8274e20c8c1..dc2400c0246 100644 --- a/lisp/gnus/gnus-html.el +++ b/lisp/gnus/gnus-html.el @@ -189,19 +189,26 @@ CHARS is a regexp-like character alternative (e.g., \"[)$]\")." (let* ((handle (mm-get-content-id (setq url (match-string 1 url)))) (image (when handle - (gnus-create-image (mm-with-part handle (buffer-string)) - nil t)))) + (gnus-create-image + (mm-with-part handle (buffer-string)) + nil t)))) (when image (let ((string (buffer-substring start end))) (delete-region start end) - (gnus-put-image (gnus-rescale-image image (gnus-html-maximum-image-size)) + (gnus-put-image (gnus-rescale-image + image (gnus-html-maximum-image-size)) (gnus-string-or string "*") 'cid) (gnus-add-image 'cid image)))) ;; Normal, external URL. - (let ((alt-text (when (string-match "\\(alt\\|title\\)=\"\\([^\"]+\\)" - parameters) - (xml-substitute-special (match-string 2 parameters))))) + (let ((alt-text + (when (string-match "\\(alt\\|title\\)=\"\\([^\"]+\\)" + parameters) + (xml-substitute-special (match-string 2 parameters))))) (gnus-put-text-property start end 'image-url url) + (gnus-put-text-property + start end 'image-displayer + (lambda (url start end) + (gnus-html-display-image url start end))) (if (gnus-html-image-url-blocked-p url (if (buffer-live-p gnus-summary-buffer) diff --git a/lisp/gnus/gnus-util.el b/lisp/gnus/gnus-util.el index 4e4aab43ba2..9deedbeb010 100644 --- a/lisp/gnus/gnus-util.el +++ b/lisp/gnus/gnus-util.el @@ -288,7 +288,10 @@ Uses `gnus-extract-address-components'." (if (not end) (setq start nil) (when value - (push (list start end value) regions)) + (push (list (set-marker (make-marker) start) + (set-marker (make-marker) end) + value) + regions)) (setq start (next-single-property-change start prop)))) (nreverse regions)))