diff options
| author | Glenn Morris <rgm@gnu.org> | 2013-09-16 17:28:11 -0400 | 
|---|---|---|
| committer | Glenn Morris <rgm@gnu.org> | 2013-09-16 17:28:11 -0400 | 
| commit | a19f6c6396b17d3c9cc54076b7965855ad6851e9 (patch) | |
| tree | f33dbd14a1f7665f372617c1eee6d715eb4d3830 /lisp | |
| parent | 0c2a2b57fe7b740b56cac4aed7b848fb87c2c00f (diff) | |
| download | emacs-a19f6c6396b17d3c9cc54076b7965855ad6851e9.tar.gz | |
* lisp/url/url-misc.el (url-data): Avoid match-data mix-up with base64 case.
Use Content-Transfer-Encoding rather than Content-Encoding.
Fixes: debbugs:15285
Diffstat (limited to 'lisp')
| -rw-r--r-- | lisp/url/ChangeLog | 5 | ||||
| -rw-r--r-- | lisp/url/url-misc.el | 11 | 
2 files changed, 10 insertions, 6 deletions
| diff --git a/lisp/url/ChangeLog b/lisp/url/ChangeLog index 3f48b8ff431..817130c5184 100644 --- a/lisp/url/ChangeLog +++ b/lisp/url/ChangeLog @@ -1,3 +1,8 @@ +2013-09-16  Glenn Morris  <rgm@gnu.org> + +	* url-misc.el (url-data): Avoid match-data mix-up with base64 case. +	Use Content-Transfer-Encoding rather than Content-Encoding. (Bug#15285) +  2013-09-13  Glenn Morris  <rgm@gnu.org>  	* url-http.el (url-handle-content-transfer-encoding): diff --git a/lisp/url/url-misc.el b/lisp/url/url-misc.el index c8e9b591790..ecc602940f3 100644 --- a/lisp/url/url-misc.el +++ b/lisp/url/url-misc.el @@ -1,7 +1,6 @@  ;;; url-misc.el --- Misc Uniform Resource Locator retrieval code -;; Copyright (C) 1996-1999, 2002, 2004-2013 Free Software Foundation, -;; Inc. +;; Copyright (C) 1996-1999, 2002, 2004-2013 Free Software Foundation, Inc.  ;; Keywords: comm, data, processes @@ -89,19 +88,19 @@      (save-excursion        (if (not (string-match "\\([^,]*\\)?," desc))  	  (error "Malformed data URL: %s" desc) -	(setq mediatype (match-string 1 desc)) +	(setq mediatype (match-string 1 desc) +	      data (url-unhex-string (substring desc (match-end 0))))  	(if (and mediatype (string-match ";base64\\'" mediatype))  	    (setq mediatype (substring mediatype 0 (match-beginning 0))  		  encoding "base64"))  	(if (or (null mediatype)  		(eq ?\; (aref mediatype 0))) -	  (setq mediatype (concat "text/plain" mediatype))) -	(setq data (url-unhex-string (substring desc (match-end 0))))) +	  (setq mediatype (concat "text/plain" mediatype))))        (set-buffer (generate-new-buffer " *url-data*"))        (mm-disable-multibyte)        (insert (format "Content-Length: %d\n" (length data))  	      "Content-Type: " mediatype "\n" -	      "Content-Encoding: " encoding "\n" +	      "Content-Transfer-Encoding: " encoding "\n"  	      "\n")        (if data (insert data))        (current-buffer)))) | 
