json 2.1.0 → 2.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/CHANGES.md +63 -5
- data/LICENSE +56 -0
- data/README.md +56 -23
- data/VERSION +1 -1
- data/ext/json/ext/generator/generator.c +223 -58
- data/ext/json/ext/generator/generator.h +5 -2
- data/ext/json/ext/parser/extconf.rb +26 -0
- data/ext/json/ext/parser/parser.c +2973 -1744
- data/ext/json/ext/parser/parser.h +6 -1
- data/ext/json/ext/parser/parser.rl +130 -22
- data/ext/json/extconf.rb +1 -0
- data/json.gemspec +0 -0
- data/lib/json/add/bigdecimal.rb +2 -2
- data/lib/json/add/complex.rb +2 -3
- data/lib/json/add/ostruct.rb +1 -1
- data/lib/json/add/rational.rb +2 -3
- data/lib/json/add/regexp.rb +2 -2
- data/lib/json/add/set.rb +29 -0
- data/lib/json/common.rb +372 -125
- data/lib/json/pure/generator.rb +31 -10
- data/lib/json/pure/parser.rb +32 -6
- data/lib/json/version.rb +1 -1
- data/lib/json.rb +549 -29
- metadata +19 -113
- data/.gitignore +0 -17
- data/.travis.yml +0 -19
- data/Gemfile +0 -16
- data/README-json-jruby.md +0 -33
- data/Rakefile +0 -408
- data/data/example.json +0 -1
- data/data/index.html +0 -38
- data/data/prototype.js +0 -4184
- data/diagrams/.keep +0 -0
- data/install.rb +0 -23
- data/java/src/json/ext/ByteListTranscoder.java +0 -166
- data/java/src/json/ext/Generator.java +0 -443
- data/java/src/json/ext/GeneratorMethods.java +0 -231
- data/java/src/json/ext/GeneratorService.java +0 -42
- data/java/src/json/ext/GeneratorState.java +0 -490
- data/java/src/json/ext/OptionsReader.java +0 -113
- data/java/src/json/ext/Parser.java +0 -2362
- data/java/src/json/ext/Parser.rl +0 -893
- data/java/src/json/ext/ParserService.java +0 -34
- data/java/src/json/ext/RuntimeInfo.java +0 -116
- data/java/src/json/ext/StringDecoder.java +0 -166
- data/java/src/json/ext/StringEncoder.java +0 -111
- data/java/src/json/ext/Utils.java +0 -88
- data/json-java.gemspec +0 -38
- data/json_pure.gemspec +0 -38
- data/lib/json/ext/.keep +0 -0
- data/references/rfc7159.txt +0 -899
- data/tests/fixtures/fail10.json +0 -1
- data/tests/fixtures/fail11.json +0 -1
- data/tests/fixtures/fail12.json +0 -1
- data/tests/fixtures/fail13.json +0 -1
- data/tests/fixtures/fail14.json +0 -1
- data/tests/fixtures/fail18.json +0 -1
- data/tests/fixtures/fail19.json +0 -1
- data/tests/fixtures/fail2.json +0 -1
- data/tests/fixtures/fail20.json +0 -1
- data/tests/fixtures/fail21.json +0 -1
- data/tests/fixtures/fail22.json +0 -1
- data/tests/fixtures/fail23.json +0 -1
- data/tests/fixtures/fail24.json +0 -1
- data/tests/fixtures/fail25.json +0 -1
- data/tests/fixtures/fail27.json +0 -2
- data/tests/fixtures/fail28.json +0 -2
- data/tests/fixtures/fail3.json +0 -1
- data/tests/fixtures/fail4.json +0 -1
- data/tests/fixtures/fail5.json +0 -1
- data/tests/fixtures/fail6.json +0 -1
- data/tests/fixtures/fail7.json +0 -1
- data/tests/fixtures/fail8.json +0 -1
- data/tests/fixtures/fail9.json +0 -1
- data/tests/fixtures/obsolete_fail1.json +0 -1
- data/tests/fixtures/pass1.json +0 -56
- data/tests/fixtures/pass15.json +0 -1
- data/tests/fixtures/pass16.json +0 -1
- data/tests/fixtures/pass17.json +0 -1
- data/tests/fixtures/pass2.json +0 -1
- data/tests/fixtures/pass26.json +0 -1
- data/tests/fixtures/pass3.json +0 -6
- data/tests/json_addition_test.rb +0 -193
- data/tests/json_common_interface_test.rb +0 -126
- data/tests/json_encoding_test.rb +0 -107
- data/tests/json_ext_parser_test.rb +0 -15
- data/tests/json_fixtures_test.rb +0 -32
- data/tests/json_generator_test.rb +0 -377
- data/tests/json_generic_object_test.rb +0 -82
- data/tests/json_parser_test.rb +0 -471
- data/tests/json_string_matching_test.rb +0 -38
- data/tests/test_helper.rb +0 -21
- data/tools/diff.sh +0 -18
- data/tools/fuzz.rb +0 -131
- data/tools/server.rb +0 -62
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: dcc1346522e82980a0a5891f93738a33d0d367b0013e22440a85282b6d56721e
|
4
|
+
data.tar.gz: a7d4a06c398e9a550664e29096f85eaab0f7007bac945e69d3b869b24df2017b
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 91235d83102ee7de2a1263a6b4d351fa61a3fa9440a31dc00cd391995721e333e609ab569f93ec9b2ad9e6b68a721d96a18af8e515d77d11c81d7626b82ab0f3
|
7
|
+
data.tar.gz: f2dcfe70be72b2df3567ee35bc3f4ecbf170ed6022362bc31cab151609ec3e3a0ef7aa339e81c0816987b25c7132fa222e1a51bc19af8cf4bf8143d66d5ed157
|
data/CHANGES.md
CHANGED
@@ -1,5 +1,63 @@
|
|
1
1
|
# Changes
|
2
2
|
|
3
|
+
## 2020-12-22 (2.5.1)
|
4
|
+
|
5
|
+
* Restore the compatibility for constants of JSON class.
|
6
|
+
|
7
|
+
## 2020-12-22 (2.5.0)
|
8
|
+
|
9
|
+
* Ready to Ractor-safe at Ruby 3.0.
|
10
|
+
|
11
|
+
## 2020-12-17 (2.4.1)
|
12
|
+
|
13
|
+
* Restore version.rb with 2.4.1
|
14
|
+
|
15
|
+
## 2020-12-15 (2.4.0)
|
16
|
+
|
17
|
+
* Implement a freeze: parser option #447
|
18
|
+
* Fix an issue with generate_pretty and empty objects in the Ruby and Java implementations #449
|
19
|
+
* Fix JSON.load_file doc #448
|
20
|
+
* Fix pure parser with unclosed arrays / objects #425
|
21
|
+
* bundle the LICENSE file in the gem #444
|
22
|
+
* Add an option to escape forward slash character #405
|
23
|
+
* RDoc for JSON #439 #446 #442 #434 #433 #430
|
24
|
+
|
25
|
+
## 2020-06-30 (2.3.1)
|
26
|
+
|
27
|
+
* Spelling and grammar fixes for comments. Pull request #191 by Josh
|
28
|
+
Kline.
|
29
|
+
* Enhance generic JSON and #generate docs. Pull request #347 by Victor
|
30
|
+
Shepelev.
|
31
|
+
* Add :nodoc: for GeneratorMethods. Pull request #349 by Victor Shepelev.
|
32
|
+
* Baseline changes to help (JRuby) development. Pull request #371 by Karol
|
33
|
+
Bucek.
|
34
|
+
* Add metadata for rubygems.org. Pull request #379 by Alexandre ZANNI.
|
35
|
+
* Remove invalid JSON.generate description from JSON module rdoc. Pull
|
36
|
+
request #384 by Jeremy Evans.
|
37
|
+
* Test with TruffleRuby in CI. Pull request #402 by Benoit Daloze.
|
38
|
+
* Rdoc enhancements. Pull request #413 by Burdette Lamar.
|
39
|
+
* Fixtures/ are not being tested... Pull request #416 by Marc-André
|
40
|
+
Lafortune.
|
41
|
+
* Use frozen string for hash key. Pull request #420 by Marc-André
|
42
|
+
Lafortune.
|
43
|
+
* Added :call-seq: to RDoc for some methods. Pull request #422 by Burdette
|
44
|
+
Lamar.
|
45
|
+
* Small typo fix. Pull request #423 by Marc-André Lafortune.
|
46
|
+
|
47
|
+
## 2019-12-11 (2.3.0)
|
48
|
+
* Fix default of `create_additions` to always be `false` for `JSON(user_input)`
|
49
|
+
and `JSON.parse(user_input, nil)`.
|
50
|
+
Note that `JSON.load` remains with default `true` and is meant for internal
|
51
|
+
serialization of trusted data. [CVE-2020-10663]
|
52
|
+
* Fix passing args all #to_json in json/add/*.
|
53
|
+
* Fix encoding issues
|
54
|
+
* Fix issues of keyword vs positional parameter
|
55
|
+
* Fix JSON::Parser against bigdecimal updates
|
56
|
+
* Bug fixes to JRuby port
|
57
|
+
|
58
|
+
## 2019-02-21 (2.2.0)
|
59
|
+
* Adds support for 2.6 BigDecimal and ruby standard library Set datetype.
|
60
|
+
|
3
61
|
## 2017-04-18 (2.1.0)
|
4
62
|
* Allow passing of `decimal_class` option to specify a class as which to parse
|
5
63
|
JSON float numbers.
|
@@ -25,7 +83,7 @@
|
|
25
83
|
|
26
84
|
## 2015-09-11 (2.0.0)
|
27
85
|
* Now complies to newest JSON RFC 7159.
|
28
|
-
* Implements
|
86
|
+
* Implements compatibility to ruby 2.4 integer unification.
|
29
87
|
* Drops support for old rubies whose life has ended, that is rubies < 2.0.
|
30
88
|
Also see https://www.ruby-lang.org/en/news/2014/07/01/eol-for-1-8-7-and-1-9-2/
|
31
89
|
* There were still some mentions of dual GPL licensing in the source, but JSON
|
@@ -66,9 +124,9 @@
|
|
66
124
|
## 2013-02-04 (1.7.7)
|
67
125
|
* Security fix for JSON create_additions default value and
|
68
126
|
`JSON::GenericObject`. It should not be possible to create additions unless
|
69
|
-
|
127
|
+
explicitly requested by setting the create_additions argument to true or
|
70
128
|
using the JSON.load/dump interface. If `JSON::GenericObject` is supposed to
|
71
|
-
be automatically deserialised, this has to be
|
129
|
+
be automatically deserialised, this has to be explicitly enabled by
|
72
130
|
setting
|
73
131
|
JSON::GenericObject.json_creatable = true
|
74
132
|
as well.
|
@@ -214,7 +272,7 @@
|
|
214
272
|
## 2010-04-23 (1.4.0)
|
215
273
|
* Major speed improvements and building with simplified
|
216
274
|
directory/file-structure.
|
217
|
-
* Extension should at least be
|
275
|
+
* Extension should at least be compatible with MRI, YARV and Rubinius.
|
218
276
|
|
219
277
|
## 2010-04-07 (1.2.4)
|
220
278
|
* Triger const_missing callback to make Rails' dynamic class loading work.
|
@@ -232,7 +290,7 @@
|
|
232
290
|
strings in object names/keys.
|
233
291
|
|
234
292
|
## 2009-10-01 (1.2.0)
|
235
|
-
* `fast_generate` now raises an
|
293
|
+
* `fast_generate` now raises an exception for nan and infinite floats.
|
236
294
|
* On Ruby 1.8 json supports parsing of UTF-8, UTF-16BE, UTF-16LE, UTF-32BE,
|
237
295
|
and UTF-32LE JSON documents now. Under Ruby 1.9 the M17n conversion
|
238
296
|
functions are used to convert from all supported encodings. ASCII-8BIT
|
data/LICENSE
ADDED
@@ -0,0 +1,56 @@
|
|
1
|
+
Ruby is copyrighted free software by Yukihiro Matsumoto <matz@netlab.jp>.
|
2
|
+
You can redistribute it and/or modify it under either the terms of the
|
3
|
+
2-clause BSDL (see the file BSDL), or the conditions below:
|
4
|
+
|
5
|
+
1. You may make and give away verbatim copies of the source form of the
|
6
|
+
software without restriction, provided that you duplicate all of the
|
7
|
+
original copyright notices and associated disclaimers.
|
8
|
+
|
9
|
+
2. You may modify your copy of the software in any way, provided that
|
10
|
+
you do at least ONE of the following:
|
11
|
+
|
12
|
+
a) place your modifications in the Public Domain or otherwise
|
13
|
+
make them Freely Available, such as by posting said
|
14
|
+
modifications to Usenet or an equivalent medium, or by allowing
|
15
|
+
the author to include your modifications in the software.
|
16
|
+
|
17
|
+
b) use the modified software only within your corporation or
|
18
|
+
organization.
|
19
|
+
|
20
|
+
c) give non-standard binaries non-standard names, with
|
21
|
+
instructions on where to get the original software distribution.
|
22
|
+
|
23
|
+
d) make other distribution arrangements with the author.
|
24
|
+
|
25
|
+
3. You may distribute the software in object code or binary form,
|
26
|
+
provided that you do at least ONE of the following:
|
27
|
+
|
28
|
+
a) distribute the binaries and library files of the software,
|
29
|
+
together with instructions (in the manual page or equivalent)
|
30
|
+
on where to get the original distribution.
|
31
|
+
|
32
|
+
b) accompany the distribution with the machine-readable source of
|
33
|
+
the software.
|
34
|
+
|
35
|
+
c) give non-standard binaries non-standard names, with
|
36
|
+
instructions on where to get the original software distribution.
|
37
|
+
|
38
|
+
d) make other distribution arrangements with the author.
|
39
|
+
|
40
|
+
4. You may modify and include the part of the software into any other
|
41
|
+
software (possibly commercial). But some files in the distribution
|
42
|
+
are not written by the author, so that they are not under these terms.
|
43
|
+
|
44
|
+
For the list of those files and their copying conditions, see the
|
45
|
+
file LEGAL.
|
46
|
+
|
47
|
+
5. The scripts and library files supplied as input to or produced as
|
48
|
+
output from the software do not automatically fall under the
|
49
|
+
copyright of the software, but belong to whomever generated them,
|
50
|
+
and may be sold commercially, and may be aggregated with this
|
51
|
+
software.
|
52
|
+
|
53
|
+
6. THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR
|
54
|
+
IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
|
55
|
+
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
56
|
+
PURPOSE.
|
data/README.md
CHANGED
@@ -1,5 +1,6 @@
|
|
1
|
-
# JSON implementation for Ruby
|
2
|
-
|
1
|
+
# JSON implementation for Ruby
|
2
|
+
|
3
|
+
[](https://github.com/flori/json/actions/workflows/ci.yml)
|
3
4
|
|
4
5
|
## Description
|
5
6
|
|
@@ -150,6 +151,18 @@ require 'json/add/rails'
|
|
150
151
|
Both of the additions attempt to require `'json'` (like above) first, if it has
|
151
152
|
not been required yet.
|
152
153
|
|
154
|
+
## Serializing exceptions
|
155
|
+
|
156
|
+
The JSON module doesn't extend `Exception` by default. If you convert an `Exception`
|
157
|
+
object to JSON, it will by default only include the exception message.
|
158
|
+
|
159
|
+
To include the full details, you must either load the `json/add/core` mentioned
|
160
|
+
above, or specifically load the exception addition:
|
161
|
+
|
162
|
+
```ruby
|
163
|
+
require 'json/add/exception'
|
164
|
+
```
|
165
|
+
|
153
166
|
## More Examples
|
154
167
|
|
155
168
|
To create a JSON document from a ruby data structure, you can call
|
@@ -179,14 +192,14 @@ should return a JSON object (a hash converted to JSON with `#to_json`) like
|
|
179
192
|
this (don't forget the `*a` for all the arguments):
|
180
193
|
|
181
194
|
```ruby
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
195
|
+
class Range
|
196
|
+
def to_json(*a)
|
197
|
+
{
|
198
|
+
'json_class' => self.class.name, # = 'Range'
|
199
|
+
'data' => [ first, last, exclude_end? ]
|
200
|
+
}.to_json(*a)
|
201
|
+
end
|
202
|
+
end
|
190
203
|
```
|
191
204
|
|
192
205
|
The hash key `json_class` is the class, that will be asked to deserialise the
|
@@ -194,26 +207,30 @@ JSON representation later. In this case it's `Range`, but any namespace of
|
|
194
207
|
the form `A::B` or `::A::B` will do. All other keys are arbitrary and can be
|
195
208
|
used to store the necessary data to configure the object to be deserialised.
|
196
209
|
|
197
|
-
If
|
210
|
+
If the key `json_class` is found in a JSON object, the JSON parser checks
|
198
211
|
if the given class responds to the `json_create` class method. If so, it is
|
199
212
|
called with the JSON object converted to a Ruby hash. So a range can
|
200
213
|
be deserialised by implementing `Range.json_create` like this:
|
201
214
|
|
202
215
|
```ruby
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
216
|
+
class Range
|
217
|
+
def self.json_create(o)
|
218
|
+
new(*o['data'])
|
219
|
+
end
|
220
|
+
end
|
208
221
|
```
|
209
222
|
|
210
223
|
Now it possible to serialise/deserialise ranges as well:
|
211
224
|
|
212
225
|
```ruby
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
226
|
+
json = JSON.generate [1, 2, {"a"=>3.141}, false, true, nil, 4..10]
|
227
|
+
# => "[1,2,{\"a\":3.141},false,true,null,{\"json_class\":\"Range\",\"data\":[4,10,false]}]"
|
228
|
+
JSON.parse json
|
229
|
+
# => [1, 2, {"a"=>3.141}, false, true, nil, 4..10]
|
230
|
+
json = JSON.generate [1, 2, {"a"=>3.141}, false, true, nil, 4..10]
|
231
|
+
# => "[1,2,{\"a\":3.141},false,true,null,{\"json_class\":\"Range\",\"data\":[4,10,false]}]"
|
232
|
+
JSON.parse json, :create_additions => true
|
233
|
+
# => [1, 2, {"a"=>3.141}, false, true, nil, 4..10]
|
217
234
|
```
|
218
235
|
|
219
236
|
`JSON.generate` always creates the shortest possible string representation of a
|
@@ -250,7 +267,7 @@ the `pp` library's `pp` methods.
|
|
250
267
|
|
251
268
|
The script `tools/server.rb` contains a small example if you want to test, how
|
252
269
|
receiving a JSON object from a webrick server in your browser with the
|
253
|
-
|
270
|
+
JavaScript prototype library http://www.prototypejs.org works.
|
254
271
|
|
255
272
|
## Speed Comparisons
|
256
273
|
|
@@ -277,7 +294,7 @@ extension:
|
|
277
294
|
```
|
278
295
|
|
279
296
|
In the table above 1 is `JSON::Ext::Parser`, 2 is `YAML.load` with YAML
|
280
|
-
|
297
|
+
compatible JSON document, 3 is is `JSON::Pure::Parser`, and 4 is
|
281
298
|
`ActiveSupport::JSON.decode`. The ActiveSupport JSON-decoder converts the
|
282
299
|
input first to YAML and then uses the YAML-parser, the conversion seems to
|
283
300
|
slow it down so much that it is only as fast as the `JSON::Pure::Parser`!
|
@@ -373,6 +390,22 @@ Here are the median comparisons for completeness' sake:
|
|
373
390
|
secs/call
|
374
391
|
```
|
375
392
|
|
393
|
+
## Development
|
394
|
+
|
395
|
+
### Release
|
396
|
+
|
397
|
+
Update the json.gemspec and json-java.gemspec.
|
398
|
+
|
399
|
+
```
|
400
|
+
rbenv shell 2.6.5
|
401
|
+
rake build
|
402
|
+
gem push pkg/json-2.3.0.gem
|
403
|
+
|
404
|
+
rbenv shell jruby-9.2.9.0
|
405
|
+
rake build
|
406
|
+
gem push pkg/json-2.3.0-java.gem
|
407
|
+
```
|
408
|
+
|
376
409
|
## Author
|
377
410
|
|
378
411
|
Florian Frank <mailto:flori@ping.de>
|
@@ -389,4 +422,4 @@ The latest version of this library can be downloaded at
|
|
389
422
|
|
390
423
|
Online Documentation should be located at
|
391
424
|
|
392
|
-
*
|
425
|
+
* https://www.rubydoc.info/gems/json
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
2.
|
1
|
+
2.6.0
|