]> git.eshelyaron.com Git - emacs.git/commitdiff
(gnus-button-alist): Allow whitespace in `<URL:...'
authorRichard M. Stallman <rms@gnu.org>
Mon, 9 Dec 1996 06:37:30 +0000 (06:37 +0000)
committerRichard M. Stallman <rms@gnu.org>
Mon, 9 Dec 1996 06:37:30 +0000 (06:37 +0000)
markup (rfc1738), done last, after possible partial matches.
(gnus-button-url): Zap any whitespace from a <URL:...> match.

lisp/gnus-vis.el

index baddc09e08702355df5b685b22c7e3734309241d..0258368cce84bb423284020f35bc59b1ba7dedef 100644 (file)
     ("\\(<?\\(url: ?\\)?news:\\([^>\n\t ]*\\)>?\\)" 1 t
      gnus-button-message-id 3)
     ("\\(<URL: *\\)?mailto: *\\([^> \n\t]+\\)>?" 0 t gnus-button-reply 2)
-    ;; This is how URLs _should_ be embedded in text...
-    ("<URL: *\\([^\n\r>]*\\)>" 0 t gnus-button-url 1)
     ;; Next regexp stolen from highlight-headers.el.
     ;; Modified by Vladimir Alexiev.
-    (,gnus-button-url-regexp 0 t gnus-button-url 0))
+    (,gnus-button-url-regexp 0 t gnus-button-url 0)
+    ;; This is how URLs _should_ be embedded in text...  It should go
+    ;; last to avoid matching only a subset of the URL, depending on
+    ;; how it was broken across lines.
+    ("<URL:\\([^>]+\\)>" 0 t gnus-button-url 1))
   "Alist of regexps matching buttons in article bodies.
 
 Each entry has the form (REGEXP BUTTON FORM CALLBACK PAR...), where
@@ -1518,7 +1520,13 @@ specified by `gnus-button-alist'."
 
 (defun gnus-button-url (address)
   "Browse ADDRESS."
-  (funcall browse-url-browser-function address))
+  (funcall browse-url-browser-function
+          ;; Zap whitespace in case <URL:...> contained it.
+          ;; (Whitespace illegal in raw URL.)
+          (let ((stripped-address address))
+            (while (string-match "\\s +\\|\n+" stripped-address)
+              (setq stripped-address (replace-match "" t t stripped-address)))
+            stripped-address)))
 
 ;;; Next/prev buttons in the article buffer.