diff options
author | Bram Moolenaar <Bram@vim.org> | 2017-01-11 21:50:08 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2017-01-11 21:50:08 +0100 |
commit | ee142add229cbcd58bc76d59f23e02517df14379 (patch) | |
tree | 5b6252210596b5a331e00ab4a89ea5017fc07a37 /src/json.c | |
parent | e32abbe42c921c5e521420417abe5bc301e540b3 (diff) | |
download | vim-git-ee142add229cbcd58bc76d59f23e02517df14379.tar.gz |
patch 8.0.0171: JS style JSON does not support single quotesv8.0.0171
Problem: JS style JSON does not support single quotes.
Solution: Allow for single quotes. (Yasuhiro Matsumoto, closes #1371)
Diffstat (limited to 'src/json.c')
-rw-r--r-- | src/json.c | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/src/json.c b/src/json.c index 2cc3a2a39..faaeab35c 100644 --- a/src/json.c +++ b/src/json.c @@ -378,7 +378,7 @@ json_skip_white(js_read_T *reader) } static int -json_decode_string(js_read_T *reader, typval_T *res) +json_decode_string(js_read_T *reader, typval_T *res, int quote) { garray_T ga; int len; @@ -389,8 +389,8 @@ json_decode_string(js_read_T *reader, typval_T *res) if (res != NULL) ga_init2(&ga, 1, 200); - p = reader->js_buf + reader->js_used + 1; /* skip over " */ - while (*p != '"') + p = reader->js_buf + reader->js_used + 1; /* skip over " or ' */ + while (*p != quote) { /* The JSON is always expected to be utf-8, thus use utf functions * here. The string is converted below if needed. */ @@ -504,7 +504,7 @@ json_decode_string(js_read_T *reader, typval_T *res) } reader->js_used = (int)(p - reader->js_buf); - if (*p == '"') + if (*p == quote) { ++reader->js_used; if (res != NULL) @@ -620,7 +620,8 @@ json_decode_item(js_read_T *reader, typval_T *res, int options) if (top_item != NULL && top_item->jd_type == JSON_OBJECT_KEY && (options & JSON_JS) - && reader->js_buf[reader->js_used] != '"') + && reader->js_buf[reader->js_used] != '"' + && reader->js_buf[reader->js_used] != '\'') { char_u *key; @@ -690,7 +691,17 @@ json_decode_item(js_read_T *reader, typval_T *res, int options) continue; case '"': /* string */ - retval = json_decode_string(reader, cur_item); + retval = json_decode_string(reader, cur_item, *p); + break; + + case '\'': + if (options & JSON_JS) + retval = json_decode_string(reader, cur_item, *p); + else + { + EMSG(_(e_invarg)); + retval = FAIL; + } break; case ',': /* comma: empty item */ |