json 2.7.4 → 2.8.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGES.md +25 -0
- data/README.md +8 -77
- data/ext/json/ext/fbuffer/fbuffer.h +85 -47
- data/ext/json/ext/generator/generator.c +367 -216
- data/ext/json/ext/parser/extconf.rb +5 -27
- data/ext/json/ext/parser/parser.c +1536 -474
- data/ext/json/ext/parser/parser.rl +717 -243
- data/json.gemspec +4 -1
- data/lib/json/add/bigdecimal.rb +1 -1
- data/lib/json/common.rb +200 -54
- data/lib/json/ext/generator/state.rb +1 -31
- data/lib/json/ext.rb +2 -4
- data/lib/json/{pure → truffle_ruby}/generator.rb +165 -124
- data/lib/json/version.rb +1 -1
- data/lib/json.rb +15 -20
- metadata +4 -8
- data/ext/json/ext/generator/generator.h +0 -129
- data/ext/json/ext/parser/parser.h +0 -60
- data/lib/json/pure/parser.rb +0 -331
- data/lib/json/pure.rb +0 -16
@@ -1,101 +1,105 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
module JSON
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
3
|
+
module TruffleRuby
|
4
|
+
module Generator
|
5
|
+
MAP = {
|
6
|
+
"\x0" => '\u0000',
|
7
|
+
"\x1" => '\u0001',
|
8
|
+
"\x2" => '\u0002',
|
9
|
+
"\x3" => '\u0003',
|
10
|
+
"\x4" => '\u0004',
|
11
|
+
"\x5" => '\u0005',
|
12
|
+
"\x6" => '\u0006',
|
13
|
+
"\x7" => '\u0007',
|
14
|
+
"\b" => '\b',
|
15
|
+
"\t" => '\t',
|
16
|
+
"\n" => '\n',
|
17
|
+
"\xb" => '\u000b',
|
18
|
+
"\f" => '\f',
|
19
|
+
"\r" => '\r',
|
20
|
+
"\xe" => '\u000e',
|
21
|
+
"\xf" => '\u000f',
|
22
|
+
"\x10" => '\u0010',
|
23
|
+
"\x11" => '\u0011',
|
24
|
+
"\x12" => '\u0012',
|
25
|
+
"\x13" => '\u0013',
|
26
|
+
"\x14" => '\u0014',
|
27
|
+
"\x15" => '\u0015',
|
28
|
+
"\x16" => '\u0016',
|
29
|
+
"\x17" => '\u0017',
|
30
|
+
"\x18" => '\u0018',
|
31
|
+
"\x19" => '\u0019',
|
32
|
+
"\x1a" => '\u001a',
|
33
|
+
"\x1b" => '\u001b',
|
34
|
+
"\x1c" => '\u001c',
|
35
|
+
"\x1d" => '\u001d',
|
36
|
+
"\x1e" => '\u001e',
|
37
|
+
"\x1f" => '\u001f',
|
38
|
+
'"' => '\"',
|
39
|
+
'\\' => '\\\\',
|
40
|
+
}.freeze # :nodoc:
|
41
|
+
|
42
|
+
ESCAPE_PATTERN = /[\/"\\\x0-\x1f]/n # :nodoc:
|
43
|
+
|
44
|
+
SCRIPT_SAFE_MAP = MAP.merge(
|
45
|
+
'/' => '\\/',
|
46
|
+
"\u2028".b => '\u2028',
|
47
|
+
"\u2029".b => '\u2029',
|
48
|
+
).freeze
|
49
|
+
|
50
|
+
SCRIPT_SAFE_ESCAPE_PATTERN = Regexp.union(ESCAPE_PATTERN, "\u2028".b, "\u2029".b)
|
51
|
+
|
52
|
+
# Convert a UTF8 encoded Ruby string _string_ to a JSON string, encoded with
|
53
|
+
# UTF16 big endian characters as \u????, and return it.
|
54
|
+
def utf8_to_json(string, script_safe = false) # :nodoc:
|
55
|
+
string = string.b
|
56
|
+
if script_safe
|
57
|
+
string.gsub!(SCRIPT_SAFE_ESCAPE_PATTERN) { SCRIPT_SAFE_MAP[$&] || $& }
|
58
|
+
else
|
59
|
+
string.gsub!(ESCAPE_PATTERN) { MAP[$&] || $& }
|
60
|
+
end
|
61
|
+
string.force_encoding(::Encoding::UTF_8)
|
62
|
+
string
|
63
|
+
end
|
62
64
|
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
65
|
+
def utf8_to_json_ascii(string, script_safe = false) # :nodoc:
|
66
|
+
string = string.b
|
67
|
+
map = script_safe ? SCRIPT_SAFE_MAP : MAP
|
68
|
+
string.gsub!(/[\/"\\\x0-\x1f]/n) { map[$&] || $& }
|
69
|
+
string.gsub!(/(
|
70
|
+
(?:
|
71
|
+
[\xc2-\xdf][\x80-\xbf] |
|
72
|
+
[\xe0-\xef][\x80-\xbf]{2} |
|
73
|
+
[\xf0-\xf4][\x80-\xbf]{3}
|
74
|
+
)+ |
|
75
|
+
[\x80-\xc1\xf5-\xff] # invalid
|
76
|
+
)/nx) { |c|
|
77
|
+
c.size == 1 and raise GeneratorError, "invalid utf8 byte: '#{c}'"
|
78
|
+
s = c.encode(::Encoding::UTF_16BE, ::Encoding::UTF_8).unpack('H*')[0]
|
79
|
+
s.force_encoding(::Encoding::BINARY)
|
80
|
+
s.gsub!(/.{4}/n, '\\\\u\&')
|
81
|
+
s.force_encoding(::Encoding::UTF_8)
|
82
|
+
}
|
83
|
+
string.force_encoding(::Encoding::UTF_8)
|
84
|
+
string
|
85
|
+
rescue => e
|
86
|
+
raise GeneratorError.wrap(e)
|
87
|
+
end
|
86
88
|
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
89
|
+
def valid_utf8?(string)
|
90
|
+
encoding = string.encoding
|
91
|
+
(encoding == Encoding::UTF_8 || encoding == Encoding::ASCII) &&
|
92
|
+
string.valid_encoding?
|
93
|
+
end
|
94
|
+
module_function :utf8_to_json, :utf8_to_json_ascii, :valid_utf8?
|
93
95
|
|
94
|
-
module Pure
|
95
|
-
module Generator
|
96
96
|
# This class is used to create State instances, that are use to hold data
|
97
97
|
# while generating a JSON text from a Ruby data structure.
|
98
98
|
class State
|
99
|
+
def self.generate(obj, opts = nil)
|
100
|
+
new(opts).generate(obj)
|
101
|
+
end
|
102
|
+
|
99
103
|
# Creates a State object from _opts_, which ought to be Hash to create
|
100
104
|
# a new State instance configured by _opts_, something else to create
|
101
105
|
# an unconfigured instance. If _opts_ is a State object, it is just
|
@@ -130,7 +134,7 @@ module JSON
|
|
130
134
|
# * *allow_nan*: true if NaN, Infinity, and -Infinity should be
|
131
135
|
# generated, otherwise an exception is thrown, if these values are
|
132
136
|
# encountered. This options defaults to false.
|
133
|
-
def initialize(opts =
|
137
|
+
def initialize(opts = nil)
|
134
138
|
@indent = ''
|
135
139
|
@space = ''
|
136
140
|
@space_before = ''
|
@@ -138,10 +142,12 @@ module JSON
|
|
138
142
|
@array_nl = ''
|
139
143
|
@allow_nan = false
|
140
144
|
@ascii_only = false
|
141
|
-
@
|
142
|
-
@strict = false
|
145
|
+
@depth = 0
|
143
146
|
@buffer_initial_length = 1024
|
144
|
-
|
147
|
+
@script_safe = false
|
148
|
+
@strict = false
|
149
|
+
@max_nesting = 100
|
150
|
+
configure(opts) if opts
|
145
151
|
end
|
146
152
|
|
147
153
|
# This string is used to indent levels in the JSON text.
|
@@ -239,13 +245,13 @@ module JSON
|
|
239
245
|
end
|
240
246
|
|
241
247
|
# NOTE: If adding new instance variables here, check whether #generate should check them for #generate_json
|
242
|
-
@indent = opts[:indent] if opts.key?(:indent)
|
243
|
-
@space = opts[:space] if opts.key?(:space)
|
244
|
-
@space_before = opts[:space_before] if opts.key?(:space_before)
|
245
|
-
@object_nl = opts[:object_nl] if opts.key?(:object_nl)
|
246
|
-
@array_nl = opts[:array_nl] if opts.key?(:array_nl)
|
247
|
-
@allow_nan = !!opts[:allow_nan]
|
248
|
-
@ascii_only = opts[:ascii_only]
|
248
|
+
@indent = opts[:indent] || '' if opts.key?(:indent)
|
249
|
+
@space = opts[:space] || '' if opts.key?(:space)
|
250
|
+
@space_before = opts[:space_before] || '' if opts.key?(:space_before)
|
251
|
+
@object_nl = opts[:object_nl] || '' if opts.key?(:object_nl)
|
252
|
+
@array_nl = opts[:array_nl] || '' if opts.key?(:array_nl)
|
253
|
+
@allow_nan = !!opts[:allow_nan] if opts.key?(:allow_nan)
|
254
|
+
@ascii_only = opts[:ascii_only] if opts.key?(:ascii_only)
|
249
255
|
@depth = opts[:depth] || 0
|
250
256
|
@buffer_initial_length ||= opts[:buffer_initial_length]
|
251
257
|
|
@@ -294,7 +300,7 @@ module JSON
|
|
294
300
|
else
|
295
301
|
result = obj.to_json(self)
|
296
302
|
end
|
297
|
-
JSON.valid_utf8?(result) or raise GeneratorError,
|
303
|
+
JSON::TruffleRuby::Generator.valid_utf8?(result) or raise GeneratorError,
|
298
304
|
"source sequence #{result.inspect} is illegal/malformed utf-8"
|
299
305
|
result
|
300
306
|
end
|
@@ -307,7 +313,16 @@ module JSON
|
|
307
313
|
first = true
|
308
314
|
obj.each_pair do |k,v|
|
309
315
|
buf << ',' unless first
|
310
|
-
|
316
|
+
|
317
|
+
key_str = k.to_s
|
318
|
+
if key_str.class == String
|
319
|
+
fast_serialize_string(key_str, buf)
|
320
|
+
elsif key_str.is_a?(String)
|
321
|
+
generate_json(key_str, buf)
|
322
|
+
else
|
323
|
+
raise TypeError, "#{k.class}#to_s returns an instance of #{key_str.class}, expected a String"
|
324
|
+
end
|
325
|
+
|
311
326
|
buf << ':'
|
312
327
|
generate_json(v, buf)
|
313
328
|
first = false
|
@@ -323,7 +338,11 @@ module JSON
|
|
323
338
|
end
|
324
339
|
buf << ']'
|
325
340
|
when String
|
326
|
-
|
341
|
+
if obj.class == String
|
342
|
+
fast_serialize_string(obj, buf)
|
343
|
+
else
|
344
|
+
buf << obj.to_json(self)
|
345
|
+
end
|
327
346
|
when Integer
|
328
347
|
buf << obj.to_s
|
329
348
|
else
|
@@ -333,24 +352,23 @@ module JSON
|
|
333
352
|
end
|
334
353
|
|
335
354
|
# Assumes !@ascii_only, !@script_safe
|
336
|
-
|
337
|
-
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
buf << string.gsub(/["\\\x0-\x1f]/n, MAP)
|
344
|
-
else
|
345
|
-
buf << string
|
355
|
+
private def fast_serialize_string(string, buf) # :nodoc:
|
356
|
+
buf << '"'
|
357
|
+
unless string.encoding == ::Encoding::UTF_8
|
358
|
+
begin
|
359
|
+
string = string.encode(::Encoding::UTF_8)
|
360
|
+
rescue Encoding::UndefinedConversionError => error
|
361
|
+
raise GeneratorError, error.message
|
346
362
|
end
|
347
|
-
buf << '"'
|
348
363
|
end
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
buf << string.
|
364
|
+
raise GeneratorError, "source sequence is illegal/malformed utf-8" unless string.valid_encoding?
|
365
|
+
|
366
|
+
if /["\\\x0-\x1f]/n.match?(string)
|
367
|
+
buf << string.gsub(/["\\\x0-\x1f]/n, MAP)
|
368
|
+
else
|
369
|
+
buf << string
|
353
370
|
end
|
371
|
+
buf << '"'
|
354
372
|
end
|
355
373
|
|
356
374
|
# Return the value returned by method +name+.
|
@@ -406,15 +424,29 @@ module JSON
|
|
406
424
|
end
|
407
425
|
|
408
426
|
def json_transform(state)
|
427
|
+
depth = state.depth += 1
|
428
|
+
|
429
|
+
if empty?
|
430
|
+
state.depth -= 1
|
431
|
+
return '{}'
|
432
|
+
end
|
433
|
+
|
409
434
|
delim = ",#{state.object_nl}"
|
410
435
|
result = +"{#{state.object_nl}"
|
411
|
-
depth = state.depth += 1
|
412
436
|
first = true
|
413
437
|
indent = !state.object_nl.empty?
|
414
438
|
each { |key, value|
|
415
439
|
result << delim unless first
|
416
440
|
result << state.indent * depth if indent
|
417
|
-
|
441
|
+
|
442
|
+
key_str = key.to_s
|
443
|
+
if key_str.is_a?(String)
|
444
|
+
key_json = key_str.to_json(state)
|
445
|
+
else
|
446
|
+
raise TypeError, "#{key.class}#to_s returns an instance of #{key_str.class}, expected a String"
|
447
|
+
end
|
448
|
+
|
449
|
+
result = +"#{result}#{key_json}#{state.space_before}:#{state.space}"
|
418
450
|
if state.strict? && !(false == value || true == value || nil == value || String === value || Array === value || Hash === value || Integer === value || Float === value)
|
419
451
|
raise GeneratorError, "#{value.class} not allowed in JSON"
|
420
452
|
elsif value.respond_to?(:to_json)
|
@@ -448,6 +480,13 @@ module JSON
|
|
448
480
|
private
|
449
481
|
|
450
482
|
def json_transform(state)
|
483
|
+
depth = state.depth += 1
|
484
|
+
|
485
|
+
if empty?
|
486
|
+
state.depth -= 1
|
487
|
+
return '[]'
|
488
|
+
end
|
489
|
+
|
451
490
|
result = '['.dup
|
452
491
|
if state.array_nl.empty?
|
453
492
|
delim = ","
|
@@ -455,7 +494,7 @@ module JSON
|
|
455
494
|
result << state.array_nl
|
456
495
|
delim = ",#{state.array_nl}"
|
457
496
|
end
|
458
|
-
|
497
|
+
|
459
498
|
first = true
|
460
499
|
indent = !state.array_nl.empty?
|
461
500
|
each { |value|
|
@@ -520,10 +559,12 @@ module JSON
|
|
520
559
|
string = encode(::Encoding::UTF_8)
|
521
560
|
end
|
522
561
|
if state.ascii_only?
|
523
|
-
%("#{JSON.utf8_to_json_ascii(string, state.script_safe)}")
|
562
|
+
%("#{JSON::TruffleRuby::Generator.utf8_to_json_ascii(string, state.script_safe)}")
|
524
563
|
else
|
525
|
-
%("#{JSON.utf8_to_json(string, state.script_safe)}")
|
564
|
+
%("#{JSON::TruffleRuby::Generator.utf8_to_json(string, state.script_safe)}")
|
526
565
|
end
|
566
|
+
rescue Encoding::UndefinedConversionError => error
|
567
|
+
raise ::JSON::GeneratorError, error.message
|
527
568
|
end
|
528
569
|
|
529
570
|
# Module that holds the extending methods if, the String module is
|
data/lib/json/version.rb
CHANGED
data/lib/json.rb
CHANGED
@@ -378,13 +378,13 @@ require 'json/common'
|
|
378
378
|
# json1 = JSON.generate(ruby)
|
379
379
|
# ruby1 = JSON.parse(json1, create_additions: true)
|
380
380
|
# # Make a nice display.
|
381
|
-
# display =
|
382
|
-
#
|
383
|
-
#
|
384
|
-
#
|
385
|
-
#
|
386
|
-
#
|
387
|
-
#
|
381
|
+
# display = <<~EOT
|
382
|
+
# Generated JSON:
|
383
|
+
# Without addition: #{json0} (#{json0.class})
|
384
|
+
# With addition: #{json1} (#{json1.class})
|
385
|
+
# Parsed JSON:
|
386
|
+
# Without addition: #{ruby0.inspect} (#{ruby0.class})
|
387
|
+
# With addition: #{ruby1.inspect} (#{ruby1.class})
|
388
388
|
# EOT
|
389
389
|
# puts display
|
390
390
|
#
|
@@ -562,13 +562,13 @@ require 'json/common'
|
|
562
562
|
# json1 = JSON.generate(foo1)
|
563
563
|
# obj1 = JSON.parse(json1, create_additions: true)
|
564
564
|
# # Make a nice display.
|
565
|
-
# display =
|
566
|
-
#
|
567
|
-
#
|
568
|
-
#
|
569
|
-
#
|
570
|
-
#
|
571
|
-
#
|
565
|
+
# display = <<~EOT
|
566
|
+
# Generated JSON:
|
567
|
+
# Without custom addition: #{json0} (#{json0.class})
|
568
|
+
# With custom addition: #{json1} (#{json1.class})
|
569
|
+
# Parsed JSON:
|
570
|
+
# Without custom addition: #{obj0.inspect} (#{obj0.class})
|
571
|
+
# With custom addition: #{obj1.inspect} (#{obj1.class})
|
572
572
|
# EOT
|
573
573
|
# puts display
|
574
574
|
#
|
@@ -583,10 +583,5 @@ require 'json/common'
|
|
583
583
|
#
|
584
584
|
module JSON
|
585
585
|
require 'json/version'
|
586
|
-
|
587
|
-
begin
|
588
|
-
require 'json/ext'
|
589
|
-
rescue LoadError
|
590
|
-
require 'json/pure'
|
591
|
-
end
|
586
|
+
require 'json/ext'
|
592
587
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: json
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 2.8.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Florian Frank
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-11-06 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: This is a JSON implementation as a Ruby extension in C.
|
14
14
|
email: flori@ping.de
|
@@ -27,10 +27,8 @@ files:
|
|
27
27
|
- ext/json/ext/fbuffer/fbuffer.h
|
28
28
|
- ext/json/ext/generator/extconf.rb
|
29
29
|
- ext/json/ext/generator/generator.c
|
30
|
-
- ext/json/ext/generator/generator.h
|
31
30
|
- ext/json/ext/parser/extconf.rb
|
32
31
|
- ext/json/ext/parser/parser.c
|
33
|
-
- ext/json/ext/parser/parser.h
|
34
32
|
- ext/json/ext/parser/parser.rl
|
35
33
|
- json.gemspec
|
36
34
|
- lib/json.rb
|
@@ -52,9 +50,7 @@ files:
|
|
52
50
|
- lib/json/ext.rb
|
53
51
|
- lib/json/ext/generator/state.rb
|
54
52
|
- lib/json/generic_object.rb
|
55
|
-
- lib/json/
|
56
|
-
- lib/json/pure/generator.rb
|
57
|
-
- lib/json/pure/parser.rb
|
53
|
+
- lib/json/truffle_ruby/generator.rb
|
58
54
|
- lib/json/version.rb
|
59
55
|
homepage: https://ruby.github.io/json
|
60
56
|
licenses:
|
@@ -78,7 +74,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
78
74
|
requirements:
|
79
75
|
- - ">="
|
80
76
|
- !ruby/object:Gem::Version
|
81
|
-
version: '2.
|
77
|
+
version: '2.7'
|
82
78
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
83
79
|
requirements:
|
84
80
|
- - ">="
|
@@ -1,129 +0,0 @@
|
|
1
|
-
#ifndef _GENERATOR_H_
|
2
|
-
#define _GENERATOR_H_
|
3
|
-
|
4
|
-
#include <math.h>
|
5
|
-
#include <ctype.h>
|
6
|
-
|
7
|
-
#include "ruby.h"
|
8
|
-
|
9
|
-
/* This is the fallback definition from Ruby 3.4 */
|
10
|
-
#ifndef RBIMPL_STDBOOL_H
|
11
|
-
#if defined(__cplusplus)
|
12
|
-
# if defined(HAVE_STDBOOL_H) && (__cplusplus >= 201103L)
|
13
|
-
# include <cstdbool>
|
14
|
-
# endif
|
15
|
-
#elif defined(HAVE_STDBOOL_H)
|
16
|
-
# include <stdbool.h>
|
17
|
-
#elif !defined(HAVE__BOOL)
|
18
|
-
typedef unsigned char _Bool;
|
19
|
-
# define bool _Bool
|
20
|
-
# define true ((_Bool)+1)
|
21
|
-
# define false ((_Bool)+0)
|
22
|
-
# define __bool_true_false_are_defined
|
23
|
-
#endif
|
24
|
-
#endif
|
25
|
-
|
26
|
-
static char *fstrndup(const char *ptr, unsigned long len);
|
27
|
-
|
28
|
-
/* ruby api and some helpers */
|
29
|
-
|
30
|
-
typedef struct JSON_Generator_StateStruct {
|
31
|
-
char *indent;
|
32
|
-
long indent_len;
|
33
|
-
char *space;
|
34
|
-
long space_len;
|
35
|
-
char *space_before;
|
36
|
-
long space_before_len;
|
37
|
-
char *object_nl;
|
38
|
-
long object_nl_len;
|
39
|
-
char *array_nl;
|
40
|
-
long array_nl_len;
|
41
|
-
long max_nesting;
|
42
|
-
char allow_nan;
|
43
|
-
char ascii_only;
|
44
|
-
char script_safe;
|
45
|
-
char strict;
|
46
|
-
long depth;
|
47
|
-
long buffer_initial_length;
|
48
|
-
} JSON_Generator_State;
|
49
|
-
|
50
|
-
#define GET_STATE_TO(self, state) \
|
51
|
-
TypedData_Get_Struct(self, JSON_Generator_State, &JSON_Generator_State_type, state)
|
52
|
-
|
53
|
-
#define GET_STATE(self) \
|
54
|
-
JSON_Generator_State *state; \
|
55
|
-
GET_STATE_TO(self, state)
|
56
|
-
|
57
|
-
#define GENERATE_JSON(type) \
|
58
|
-
FBuffer *buffer; \
|
59
|
-
VALUE Vstate; \
|
60
|
-
JSON_Generator_State *state; \
|
61
|
-
\
|
62
|
-
rb_scan_args(argc, argv, "01", &Vstate); \
|
63
|
-
Vstate = cState_from_state_s(cState, Vstate); \
|
64
|
-
TypedData_Get_Struct(Vstate, JSON_Generator_State, &JSON_Generator_State_type, state); \
|
65
|
-
buffer = cState_prepare_buffer(Vstate); \
|
66
|
-
generate_json_##type(buffer, Vstate, state, self); \
|
67
|
-
return fbuffer_to_s(buffer)
|
68
|
-
|
69
|
-
static VALUE mHash_to_json(int argc, VALUE *argv, VALUE self);
|
70
|
-
static VALUE mArray_to_json(int argc, VALUE *argv, VALUE self);
|
71
|
-
#ifdef RUBY_INTEGER_UNIFICATION
|
72
|
-
static VALUE mInteger_to_json(int argc, VALUE *argv, VALUE self);
|
73
|
-
#else
|
74
|
-
static VALUE mFixnum_to_json(int argc, VALUE *argv, VALUE self);
|
75
|
-
static VALUE mBignum_to_json(int argc, VALUE *argv, VALUE self);
|
76
|
-
#endif
|
77
|
-
static VALUE mFloat_to_json(int argc, VALUE *argv, VALUE self);
|
78
|
-
static VALUE mString_included_s(VALUE self, VALUE modul);
|
79
|
-
static VALUE mString_to_json(int argc, VALUE *argv, VALUE self);
|
80
|
-
static VALUE mString_to_json_raw_object(VALUE self);
|
81
|
-
static VALUE mString_to_json_raw(int argc, VALUE *argv, VALUE self);
|
82
|
-
static VALUE mString_Extend_json_create(VALUE self, VALUE o);
|
83
|
-
static VALUE mTrueClass_to_json(int argc, VALUE *argv, VALUE self);
|
84
|
-
static VALUE mFalseClass_to_json(int argc, VALUE *argv, VALUE self);
|
85
|
-
static VALUE mNilClass_to_json(int argc, VALUE *argv, VALUE self);
|
86
|
-
static VALUE mObject_to_json(int argc, VALUE *argv, VALUE self);
|
87
|
-
static void State_free(void *state);
|
88
|
-
static VALUE cState_s_allocate(VALUE klass);
|
89
|
-
static void generate_json(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
90
|
-
static void generate_json_object(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
91
|
-
static void generate_json_array(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
92
|
-
static void generate_json_string(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
93
|
-
static void generate_json_null(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
94
|
-
static void generate_json_false(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
95
|
-
static void generate_json_true(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
96
|
-
#ifdef RUBY_INTEGER_UNIFICATION
|
97
|
-
static void generate_json_integer(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
98
|
-
#endif
|
99
|
-
static void generate_json_fixnum(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
100
|
-
static void generate_json_bignum(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
101
|
-
static void generate_json_float(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *state, VALUE obj);
|
102
|
-
static VALUE cState_partial_generate(VALUE self, VALUE obj);
|
103
|
-
static VALUE cState_generate(VALUE self, VALUE obj);
|
104
|
-
static VALUE cState_from_state_s(VALUE self, VALUE opts);
|
105
|
-
static VALUE cState_indent(VALUE self);
|
106
|
-
static VALUE cState_indent_set(VALUE self, VALUE indent);
|
107
|
-
static VALUE cState_space(VALUE self);
|
108
|
-
static VALUE cState_space_set(VALUE self, VALUE space);
|
109
|
-
static VALUE cState_space_before(VALUE self);
|
110
|
-
static VALUE cState_space_before_set(VALUE self, VALUE space_before);
|
111
|
-
static VALUE cState_object_nl(VALUE self);
|
112
|
-
static VALUE cState_object_nl_set(VALUE self, VALUE object_nl);
|
113
|
-
static VALUE cState_array_nl(VALUE self);
|
114
|
-
static VALUE cState_array_nl_set(VALUE self, VALUE array_nl);
|
115
|
-
static VALUE cState_max_nesting(VALUE self);
|
116
|
-
static VALUE cState_max_nesting_set(VALUE self, VALUE depth);
|
117
|
-
static VALUE cState_allow_nan_p(VALUE self);
|
118
|
-
static VALUE cState_ascii_only_p(VALUE self);
|
119
|
-
static VALUE cState_depth(VALUE self);
|
120
|
-
static VALUE cState_depth_set(VALUE self, VALUE depth);
|
121
|
-
static VALUE cState_script_safe(VALUE self);
|
122
|
-
static VALUE cState_script_safe_set(VALUE self, VALUE depth);
|
123
|
-
static VALUE cState_strict(VALUE self);
|
124
|
-
static VALUE cState_strict_set(VALUE self, VALUE strict);
|
125
|
-
static FBuffer *cState_prepare_buffer(VALUE self);
|
126
|
-
|
127
|
-
static const rb_data_type_t JSON_Generator_State_type;
|
128
|
-
|
129
|
-
#endif
|