diff options
| author | Leo Liu <sdl.web@gmail.com> | 2014-06-26 12:00:56 +0800 | 
|---|---|---|
| committer | Leo Liu <sdl.web@gmail.com> | 2014-06-26 12:00:56 +0800 | 
| commit | 1d8bea62832ea227d154995d2d52bd2093d4d722 (patch) | |
| tree | 42fb1c174359cc10e83760726927a569f86ac606 | |
| parent | d2301b5d805d603547b36d96e3a09e6d8124a6d7 (diff) | |
| download | emacs-1d8bea62832ea227d154995d2d52bd2093d4d722.tar.gz | |
* lisp/url/url-handlers.el (url-http-parse-response): Remove unused autoload.
(url-insert-file-contents): Condition on url-http-response-status
for the HTTP/S specific part. 
* lisp/url/url-http.el (url-http-end-of-headers): Remove duplicate defvar.
Fixes: debbugs:17549
| -rw-r--r-- | lisp/url/ChangeLog | 8 | ||||
| -rw-r--r-- | lisp/url/url-handlers.el | 16 | ||||
| -rw-r--r-- | lisp/url/url-http.el | 1 | 
3 files changed, 18 insertions, 7 deletions
| diff --git a/lisp/url/ChangeLog b/lisp/url/ChangeLog index 408f659681f..4880bfea30b 100644 --- a/lisp/url/ChangeLog +++ b/lisp/url/ChangeLog @@ -1,3 +1,11 @@ +2014-06-26  Leo Liu  <sdl.web@gmail.com> + +	* url-http.el (url-http-end-of-headers): Remove duplicate defvar. + +	* url-handlers.el (url-http-parse-response): Remove unused autoload. +	(url-insert-file-contents): Condition on url-http-response-status +	for the HTTP/S specific part.  (Bug#17549) +  2014-05-09  Michael Albinus  <michael.albinus@gmx.de>  	* url-handlers.el (url-file-handler-load-in-progress): New defvar. diff --git a/lisp/url/url-handlers.el b/lisp/url/url-handlers.el index b0f01123bbb..5a274c12e31 100644 --- a/lisp/url/url-handlers.el +++ b/lisp/url/url-handlers.el @@ -33,7 +33,6 @@  (autoload 'url-expand-file-name "url-expand" "Convert url to a fully specified url, and canonicalize it.")  (autoload 'mm-dissect-buffer "mm-decode" "Dissect the current buffer and return a list of MIME handles.")  (autoload 'url-scheme-get-property "url-methods" "Get property of a URL SCHEME.") -(autoload 'url-http-parse-response "url-http" "Parse just the response code.")  ;; Always used after mm-dissect-buffer and defined in the same file.  (declare-function mm-save-part-to-file "mm-decode" (handle file)) @@ -298,17 +297,21 @@ They count bytes from the beginning of the body."        (insert data))      (list (length data) charset))) +(defconst url-http-codes) +  ;;;###autoload  (defun url-insert-file-contents (url &optional visit beg end replace)    (let ((buffer (url-retrieve-synchronously url)))      (unless buffer (signal 'file-error (list url "No Data")))      (with-current-buffer buffer -      (let ((response (url-http-parse-response))) -        (if (and (>= response 200) (< response 300)) -            (goto-char (point-min)) -          (let ((desc (buffer-substring-no-properties (1+ (point)) -                                                      (line-end-position)))) +      ;; XXX: This is HTTP/S specific and should be moved to url-http +      ;; instead.  See http://debbugs.gnu.org/17549. +      (when (bound-and-true-p url-http-response-status) +        (unless (and (>= url-http-response-status 200) +                     (< url-http-response-status 300)) +          (let ((desc (nth 2 (assq url-http-response-status url-http-codes))))              (kill-buffer buffer) +            ;; Signal file-error per http://debbugs.gnu.org/16733.              (signal 'file-error (list url desc))))))      (if visit (setq buffer-file-name url))      (save-excursion @@ -323,6 +326,7 @@ They count bytes from the beginning of the body."            ;; usual heuristic/rules that we apply to files.            (decode-coding-inserted-region start (point) url visit beg end replace))          (list url (car size-and-charset)))))) +  (put 'insert-file-contents 'url-file-handlers 'url-insert-file-contents)  (defun url-file-name-completion (url directory &optional predicate) diff --git a/lisp/url/url-http.el b/lisp/url/url-http.el index ac2e1403d03..dcb86689ca9 100644 --- a/lisp/url/url-http.el +++ b/lisp/url/url-http.el @@ -47,7 +47,6 @@  (defvar url-http-response-version)  (defvar url-http-target-url)  (defvar url-http-transfer-encoding) -(defvar url-http-end-of-headers)  (defvar url-show-status)  (require 'url-gw) | 
