shr.el (shr-encode-url-chars): New function.

This commit is contained in:
Katsumi Yamaoka 2010-10-05 00:44:05 +00:00
parent 71e691a59f
commit ca1bd56c49
2 changed files with 26 additions and 1 deletions

View file

@ -1,3 +1,9 @@
2010-10-05 Katsumi Yamaoka <yamaoka@jpl.org>
* shr.el (shr-encode-url-chars): New function, that's an alias to
browse-url-url-encode-chars or a copy of it.
(shr-tag-img): Use it.
2010-10-04 Lars Magne Ingebrigtsen <larsi@gnus.org>
* shr.el (shr-tag-blockquote): Ensure paragraph after quote, too.

View file

@ -191,6 +191,25 @@ redirects somewhere else."
(copy-region-as-kill (point-min) (point-max))
(message "Copied %s" url))))))
(eval-and-compile
(defalias 'shr-encode-url-chars
;; Neither Emacs 22 nor XEmacs provides this function.
(if (fboundp 'browse-url-url-encode-chars)
'browse-url-url-encode-chars
(lambda (text chars)
"URL-encode the chars in TEXT that match CHARS.
CHARS is a regexp-like character alternative (e.g., \"[)$]\")."
(let ((encoded-text (copy-sequence text))
(s 0))
(while (setq s (string-match chars encoded-text s))
(setq encoded-text
(replace-match (format "%%%x"
(string-to-char
(match-string 0 encoded-text)))
t t encoded-text)
s (1+ s)))
encoded-text)))))
(defun shr-tag-img (cont)
(when (and (> (current-column) 0)
(not (eq shr-state 'image)))
@ -204,7 +223,7 @@ redirects somewhere else."
((and shr-blocked-images
(string-match shr-blocked-images url))
(insert alt))
((url-is-cached (browse-url-url-encode-chars url "[&)$ ]"))
((url-is-cached (shr-encode-url-chars url "[&)$ ]"))
(shr-put-image (shr-get-image-data url) (point) alt))
(t
(insert alt)