From: Dmitry Gutov <dgutov@yandex.ru>
To: Leo Liu <sdl.web@gmail.com>, 23750@debbugs.gnu.org
Cc: Stefan Monnier <monnier@IRO.UMontreal.CA>
Subject: bug#23750: 25.0.95; bug in url-retrieve or json.el
Date: Mon, 13 Jun 2016 18:02:13 +0300 [thread overview]
Message-ID: <eb49b559-c2cd-16fb-fd3e-5eb133054b5d@yandex.ru> (raw)
In-Reply-To: <m137oj5eoi.fsf@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 531 bytes --]
On 06/12/2016 05:22 AM, Leo Liu wrote:
> ¹ https://github.com/ternjs/tern/issues/719
Investigation shows that the problem occurs when url-http-data is
multibyte and (length url-http-data) differs from (length
(string-as-unibyte url-http-data)), because we send a wrong value in
Content-length.
Changing url-http-create-request like this will make the problem more
obvious for anyone else that hits it, patch attached.
Stefan, did you have a particular situation in mind where this might be
bad, when you wrote the FIXME?
[-- Attachment #2: url-http-unibyte.diff --]
[-- Type: text/x-patch, Size: 1077 bytes --]
diff --git a/lisp/url/url-http.el b/lisp/url/url-http.el
index 5832e92..f7ec640 100644
--- a/lisp/url/url-http.el
+++ b/lisp/url/url-http.el
@@ -278,14 +278,10 @@ url-http-create-request
;; We used to concat directly, but if one of the strings happens
;; to being multibyte (even if it only contains pure ASCII) then
;; every string gets converted with `string-MAKE-multibyte' which
- ;; turns the 127-255 codes into things like latin-1 accented chars
- ;; (it would work right if it used `string-TO-multibyte' instead).
+ ;; turns the 127-255 codes into things like latin-1 accented chars.
;; So to avoid the problem we force every string to be unibyte.
(mapconcat
- ;; FIXME: Instead of `string-AS-unibyte' we'd want
- ;; `string-to-unibyte', so as to properly signal an error if one
- ;; of the strings contains a multibyte char.
- 'string-as-unibyte
+ 'string-to-unibyte
(delq nil
(list
;; The request
next prev parent reply other threads:[~2016-06-13 15:02 UTC|newest]
Thread overview: 125+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-12 2:22 bug#23750: 25.0.95; bug in url-retrieve or json.el Leo Liu
2016-06-13 15:02 ` Dmitry Gutov [this message]
2016-06-13 17:55 ` Stefan Monnier
2016-06-13 19:26 ` Dmitry Gutov
2016-06-14 0:30 ` Stefan Monnier
2016-06-19 18:14 ` Dmitry Gutov
2016-06-19 18:25 ` Eli Zaretskii
2016-06-19 18:30 ` John Wiegley
2016-06-19 18:45 ` Dmitry Gutov
2016-06-19 19:56 ` John Wiegley
2016-06-19 20:05 ` Dmitry Gutov
2016-06-19 21:07 ` John Wiegley
2016-06-20 1:28 ` Glenn Morris
2016-06-20 4:22 ` John Wiegley
2016-06-20 12:39 ` Lars Ingebrigtsen
2016-07-01 20:49 ` John Wiegley
2016-06-20 14:42 ` Eli Zaretskii
2016-06-23 17:14 ` Glenn Morris
2016-06-20 1:26 ` Glenn Morris
2016-06-20 2:58 ` Dmitry Gutov
2016-06-19 18:36 ` Dmitry Gutov
2016-06-20 0:15 ` Leo Liu
2016-06-20 14:39 ` Eli Zaretskii
2016-06-20 2:40 ` Eli Zaretskii
2016-06-20 2:51 ` Dmitry Gutov
2016-06-20 14:38 ` Eli Zaretskii
2016-06-20 14:54 ` Dmitry Gutov
2016-06-20 15:03 ` Eli Zaretskii
2016-06-20 17:16 ` Dmitry Gutov
2016-06-20 20:17 ` Eli Zaretskii
2016-06-20 20:27 ` Dmitry Gutov
2016-06-21 2:30 ` Eli Zaretskii
2016-06-21 13:51 ` Dmitry Gutov
2016-06-21 15:18 ` Eli Zaretskii
2016-06-22 1:08 ` John Wiegley
2016-06-22 2:36 ` Eli Zaretskii
2016-06-22 18:21 ` Dmitry Gutov
-- strict thread matches above, loose matches on Subject: below --
2016-11-29 8:22 Kentaro NAKAZAWA
2016-11-29 9:54 ` Andreas Schwab
2016-11-29 10:06 ` Kentaro NAKAZAWA
2016-11-29 10:08 ` Dmitry Gutov
2016-11-29 10:23 ` Kentaro NAKAZAWA
2016-11-29 10:34 ` Lars Ingebrigtsen
2016-11-29 10:38 ` Kentaro NAKAZAWA
2016-11-29 10:42 ` Lars Ingebrigtsen
2016-11-29 10:48 ` Kentaro NAKAZAWA
2016-11-29 10:49 ` Dmitry Gutov
2016-11-29 10:50 ` Dmitry Gutov
2016-11-29 10:55 ` Kentaro NAKAZAWA
2016-11-29 10:59 ` Dmitry Gutov
2016-11-29 11:03 ` Kentaro NAKAZAWA
2016-11-29 11:05 ` Dmitry Gutov
2016-11-29 11:12 ` Kentaro NAKAZAWA
2016-11-29 17:23 ` Eli Zaretskii
2016-11-29 23:09 ` Philipp Stephani
2016-11-29 23:18 ` Philipp Stephani
2016-11-30 15:11 ` Eli Zaretskii
2016-11-30 15:20 ` Lars Ingebrigtsen
2016-11-30 15:43 ` Eli Zaretskii
2016-11-30 15:46 ` Lars Ingebrigtsen
2016-11-30 0:16 ` Dmitry Gutov
2016-11-30 15:13 ` Eli Zaretskii
2016-11-30 15:17 ` Dmitry Gutov
2016-11-30 15:32 ` Stefan Monnier
2016-11-30 15:42 ` Eli Zaretskii
2016-11-30 15:45 ` Dmitry Gutov
2016-11-30 15:48 ` Lars Ingebrigtsen
2016-11-30 16:25 ` Eli Zaretskii
2016-11-30 16:27 ` Lars Ingebrigtsen
2016-11-30 16:42 ` Eli Zaretskii
2016-11-30 18:25 ` Philipp Stephani
2016-11-30 18:48 ` Eli Zaretskii
2016-12-28 18:18 ` Philipp Stephani
2016-12-28 18:34 ` Eli Zaretskii
2016-12-28 18:45 ` Philipp Stephani
2016-12-28 18:55 ` Eli Zaretskii
2016-12-28 19:03 ` Andreas Schwab
2016-11-30 18:23 ` Philipp Stephani
2016-11-30 18:44 ` Eli Zaretskii
2016-12-28 18:09 ` Philipp Stephani
2016-12-28 18:27 ` Eli Zaretskii
2016-12-28 18:35 ` Philipp Stephani
2016-12-28 18:45 ` Eli Zaretskii
2016-12-28 18:22 ` Philipp Stephani
2016-12-28 18:57 ` Lars Ingebrigtsen
2016-12-30 0:07 ` Richard Stallman
2016-12-30 14:15 ` Lars Ingebrigtsen
2016-12-30 16:59 ` Eli Zaretskii
2017-01-21 15:39 ` Lars Ingebrigtsen
2017-01-21 15:56 ` Eli Zaretskii
2017-01-21 16:30 ` Lars Ingebrigtsen
2017-01-21 22:58 ` Stefan Monnier
2017-01-24 20:04 ` Lars Ingebrigtsen
2017-01-28 9:52 ` Elias Mårtenson
2017-01-28 14:16 ` Lars Ingebrigtsen
2016-12-30 21:38 ` Richard Stallman
2016-11-30 16:23 ` Eli Zaretskii
2016-12-01 0:30 ` Dmitry Gutov
2016-12-01 17:17 ` Eli Zaretskii
2016-12-02 13:18 ` Dmitry Gutov
2016-12-02 14:24 ` Eli Zaretskii
2016-12-02 14:35 ` Dmitry Gutov
2016-12-02 15:20 ` Eli Zaretskii
2016-12-02 14:53 ` Yuri Khan
2016-12-02 15:45 ` Eli Zaretskii
2016-12-02 15:51 ` Lars Ingebrigtsen
2016-12-02 15:58 ` Eli Zaretskii
2016-12-02 15:29 ` Lars Ingebrigtsen
2016-12-02 15:32 ` Dmitry Gutov
2016-12-02 15:48 ` Lars Ingebrigtsen
2016-12-02 15:56 ` Dmitry Gutov
2016-12-02 16:02 ` Lars Ingebrigtsen
2016-12-02 16:06 ` Dmitry Gutov
2016-12-02 16:31 ` Lars Ingebrigtsen
2016-12-02 23:13 ` Dmitry Gutov
2016-12-03 0:37 ` Lars Ingebrigtsen
2016-12-03 1:27 ` Dmitry Gutov
2016-12-03 8:12 ` Eli Zaretskii
2016-12-03 10:01 ` Lars Ingebrigtsen
2016-12-03 16:00 ` Stefan Monnier
2016-12-03 20:01 ` Lars Ingebrigtsen
2016-12-03 20:57 ` Andreas Schwab
2016-12-28 18:25 ` Philipp Stephani
2016-11-30 15:06 ` Eli Zaretskii
2016-11-30 15:31 ` Stefan Monnier
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=eb49b559-c2cd-16fb-fd3e-5eb133054b5d@yandex.ru \
--to=dgutov@yandex.ru \
--cc=23750@debbugs.gnu.org \
--cc=monnier@IRO.UMontreal.CA \
--cc=sdl.web@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.