oj 3.13.11 → 3.15.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.
Files changed (158) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +74 -0
  3. data/README.md +4 -2
  4. data/ext/oj/buf.h +11 -6
  5. data/ext/oj/cache.c +25 -24
  6. data/ext/oj/cache8.c +10 -9
  7. data/ext/oj/circarray.c +8 -6
  8. data/ext/oj/circarray.h +2 -2
  9. data/ext/oj/code.c +17 -24
  10. data/ext/oj/code.h +2 -2
  11. data/ext/oj/compat.c +17 -44
  12. data/ext/oj/custom.c +70 -141
  13. data/ext/oj/debug.c +3 -9
  14. data/ext/oj/dump.c +128 -118
  15. data/ext/oj/dump.h +12 -8
  16. data/ext/oj/dump_compat.c +564 -641
  17. data/ext/oj/dump_leaf.c +17 -63
  18. data/ext/oj/dump_object.c +70 -199
  19. data/ext/oj/dump_strict.c +22 -46
  20. data/ext/oj/encoder.c +1 -1
  21. data/ext/oj/err.c +2 -13
  22. data/ext/oj/err.h +9 -12
  23. data/ext/oj/extconf.rb +14 -5
  24. data/ext/oj/fast.c +75 -103
  25. data/ext/oj/intern.c +52 -50
  26. data/ext/oj/intern.h +4 -8
  27. data/ext/oj/mem.c +318 -0
  28. data/ext/oj/mem.h +53 -0
  29. data/ext/oj/mimic_json.c +75 -47
  30. data/ext/oj/object.c +49 -66
  31. data/ext/oj/odd.c +89 -67
  32. data/ext/oj/odd.h +15 -15
  33. data/ext/oj/oj.c +140 -99
  34. data/ext/oj/oj.h +80 -51
  35. data/ext/oj/parse.c +162 -184
  36. data/ext/oj/parse.h +7 -10
  37. data/ext/oj/parser.c +89 -34
  38. data/ext/oj/parser.h +18 -7
  39. data/ext/oj/rails.c +82 -146
  40. data/ext/oj/rails.h +1 -1
  41. data/ext/oj/reader.c +11 -12
  42. data/ext/oj/reader.h +4 -2
  43. data/ext/oj/resolve.c +3 -4
  44. data/ext/oj/rxclass.c +6 -5
  45. data/ext/oj/rxclass.h +1 -1
  46. data/ext/oj/saj.c +20 -31
  47. data/ext/oj/saj2.c +329 -93
  48. data/ext/oj/saj2.h +23 -0
  49. data/ext/oj/scp.c +3 -14
  50. data/ext/oj/sparse.c +26 -70
  51. data/ext/oj/stream_writer.c +12 -22
  52. data/ext/oj/strict.c +20 -52
  53. data/ext/oj/string_writer.c +21 -21
  54. data/ext/oj/trace.h +31 -4
  55. data/ext/oj/usual.c +105 -150
  56. data/ext/oj/usual.h +68 -0
  57. data/ext/oj/util.h +1 -1
  58. data/ext/oj/val_stack.c +1 -1
  59. data/ext/oj/val_stack.h +8 -7
  60. data/ext/oj/validate.c +21 -26
  61. data/ext/oj/wab.c +31 -68
  62. data/lib/oj/active_support_helper.rb +0 -1
  63. data/lib/oj/bag.rb +7 -1
  64. data/lib/oj/easy_hash.rb +4 -5
  65. data/lib/oj/error.rb +0 -1
  66. data/lib/oj/json.rb +4 -2
  67. data/lib/oj/mimic.rb +4 -2
  68. data/lib/oj/saj.rb +20 -6
  69. data/lib/oj/state.rb +9 -6
  70. data/lib/oj/version.rb +1 -2
  71. data/lib/oj.rb +2 -0
  72. data/pages/Compatibility.md +1 -1
  73. data/pages/InstallOptions.md +20 -0
  74. data/pages/Options.md +10 -0
  75. data/test/_test_active.rb +8 -9
  76. data/test/_test_active_mimic.rb +7 -8
  77. data/test/_test_mimic_rails.rb +17 -20
  78. data/test/activerecord/result_test.rb +5 -6
  79. data/test/{activesupport5 → activesupport7}/abstract_unit.rb +16 -12
  80. data/test/{activesupport5 → activesupport7}/decoding_test.rb +2 -10
  81. data/test/{activesupport5 → activesupport7}/encoding_test.rb +20 -34
  82. data/test/{activesupport5 → activesupport7}/encoding_test_cases.rb +6 -0
  83. data/test/{activesupport5 → activesupport7}/time_zone_test_helpers.rb +8 -0
  84. data/test/files.rb +15 -15
  85. data/test/foo.rb +9 -71
  86. data/test/helper.rb +11 -8
  87. data/test/isolated/shared.rb +3 -2
  88. data/test/json_gem/json_addition_test.rb +2 -2
  89. data/test/json_gem/json_common_interface_test.rb +4 -4
  90. data/test/json_gem/json_encoding_test.rb +0 -0
  91. data/test/json_gem/json_ext_parser_test.rb +1 -0
  92. data/test/json_gem/json_fixtures_test.rb +3 -2
  93. data/test/json_gem/json_generator_test.rb +48 -36
  94. data/test/json_gem/json_generic_object_test.rb +11 -11
  95. data/test/json_gem/json_parser_test.rb +54 -47
  96. data/test/json_gem/json_string_matching_test.rb +9 -9
  97. data/test/json_gem/test_helper.rb +7 -3
  98. data/test/mem.rb +13 -12
  99. data/test/perf.rb +21 -26
  100. data/test/perf_compat.rb +31 -33
  101. data/test/perf_dump.rb +50 -0
  102. data/test/perf_fast.rb +80 -82
  103. data/test/perf_file.rb +27 -29
  104. data/test/perf_object.rb +65 -69
  105. data/test/perf_once.rb +12 -11
  106. data/test/perf_parser.rb +42 -48
  107. data/test/perf_saj.rb +46 -54
  108. data/test/perf_scp.rb +57 -69
  109. data/test/perf_simple.rb +41 -39
  110. data/test/perf_strict.rb +68 -70
  111. data/test/perf_wab.rb +67 -69
  112. data/test/prec.rb +3 -3
  113. data/test/sample/change.rb +0 -1
  114. data/test/sample/dir.rb +0 -1
  115. data/test/sample/doc.rb +0 -1
  116. data/test/sample/file.rb +0 -1
  117. data/test/sample/group.rb +0 -1
  118. data/test/sample/hasprops.rb +0 -1
  119. data/test/sample/layer.rb +0 -1
  120. data/test/sample/rect.rb +0 -1
  121. data/test/sample/shape.rb +0 -1
  122. data/test/sample/text.rb +0 -1
  123. data/test/sample.rb +16 -16
  124. data/test/sample_json.rb +8 -8
  125. data/test/test_compat.rb +76 -42
  126. data/test/test_custom.rb +72 -51
  127. data/test/test_debian.rb +7 -10
  128. data/test/test_fast.rb +86 -90
  129. data/test/test_file.rb +41 -30
  130. data/test/test_gc.rb +16 -5
  131. data/test/test_generate.rb +5 -5
  132. data/test/test_hash.rb +4 -4
  133. data/test/test_integer_range.rb +9 -9
  134. data/test/test_null.rb +20 -20
  135. data/test/test_object.rb +85 -96
  136. data/test/test_parser.rb +6 -22
  137. data/test/test_parser_debug.rb +27 -0
  138. data/test/test_parser_saj.rb +115 -23
  139. data/test/test_parser_usual.rb +6 -6
  140. data/test/test_rails.rb +2 -2
  141. data/test/test_saj.rb +10 -8
  142. data/test/test_scp.rb +37 -39
  143. data/test/test_strict.rb +30 -32
  144. data/test/test_various.rb +147 -99
  145. data/test/test_wab.rb +48 -44
  146. data/test/test_writer.rb +47 -47
  147. data/test/tests.rb +13 -4
  148. data/test/tests_mimic.rb +12 -3
  149. data/test/tests_mimic_addition.rb +12 -3
  150. metadata +33 -144
  151. data/test/activesupport4/decoding_test.rb +0 -108
  152. data/test/activesupport4/encoding_test.rb +0 -531
  153. data/test/activesupport4/test_helper.rb +0 -41
  154. data/test/activesupport5/test_helper.rb +0 -72
  155. data/test/bar.rb +0 -16
  156. data/test/baz.rb +0 -16
  157. data/test/bug.rb +0 -16
  158. data/test/zoo.rb +0 -13
data/ext/oj/oj.h CHANGED
@@ -39,6 +39,16 @@ enum st_retval { ST_CONTINUE = 0, ST_STOP = 1, ST_DELETE = 2, ST_CHECK };
39
39
  #define NINF_VAL "-3.0e14159265358979323846"
40
40
  #define NAN_VAL "3.3e14159265358979323846"
41
41
 
42
+ #if __STDC_VERSION__ >= 199901L
43
+ // To avoid using ruby_snprintf with C99.
44
+ #undef snprintf
45
+ #include <stdio.h>
46
+ #endif
47
+
48
+ // To avoid using ruby_nonempty_memcpy().
49
+ #undef memcpy
50
+ #include <string.h>
51
+
42
52
  typedef enum { Yes = 'y', No = 'n', NotSet = 0 } YesNo;
43
53
 
44
54
  typedef enum {
@@ -56,6 +66,7 @@ typedef enum { UnixTime = 'u', UnixZTime = 'z', XmlTime = 'x', RubyTime = 'r' }
56
66
  typedef enum {
57
67
  NLEsc = 'n',
58
68
  JSONEsc = 'j',
69
+ SlashEsc = 's',
59
70
  XSSEsc = 'x',
60
71
  ASCIIEsc = 'a',
61
72
  JXEsc = 'g', // json gem
@@ -113,41 +124,42 @@ typedef struct _dumpOpts {
113
124
  uint8_t array_size;
114
125
  char nan_dump; // NanDump
115
126
  bool omit_nil;
127
+ bool omit_null_byte;
116
128
  int max_depth;
117
- } * DumpOpts;
129
+ } *DumpOpts;
118
130
 
119
131
  typedef struct _options {
120
- int indent; // indention for dump, default 2
121
- char circular; // YesNo
122
- char auto_define; // YesNo
123
- char sym_key; // YesNo
124
- char escape_mode; // Escape_Mode
125
- char mode; // Mode
126
- char class_cache; // YesNo
127
- char time_format; // TimeFormat
128
- char bigdec_as_num; // YesNo
129
- char bigdec_load; // BigLoad
130
- char compat_bigdec; // boolean (0 or 1)
131
- char to_hash; // YesNo
132
- char to_json; // YesNo
133
- char as_json; // YesNo
134
- char raw_json; // YesNo
135
- char nilnil; // YesNo
136
- char empty_string; // YesNo
137
- char allow_gc; // allow GC during parse
138
- char quirks_mode; // allow single JSON values instead of documents
139
- char allow_invalid; // YesNo - allow invalid unicode
140
- char create_ok; // YesNo allow create_id
141
- char allow_nan; // YEsyNo for parsing only
142
- char trace; // YesNo
143
- char safe; // YesNo
144
- char sec_prec_set; // boolean (0 or 1)
145
- char ignore_under; // YesNo - ignore attrs starting with _ if true in object and custom modes
146
- char cache_keys; // YesNo
147
- char cache_str; // string short than or equal to this are cache
132
+ int indent; // indention for dump, default 2
133
+ char circular; // YesNo
134
+ char auto_define; // YesNo
135
+ char sym_key; // YesNo
136
+ char escape_mode; // Escape_Mode
137
+ char mode; // Mode
138
+ char class_cache; // YesNo
139
+ char time_format; // TimeFormat
140
+ char bigdec_as_num; // YesNo
141
+ char bigdec_load; // BigLoad
142
+ char compat_bigdec; // boolean (0 or 1)
143
+ char to_hash; // YesNo
144
+ char to_json; // YesNo
145
+ char as_json; // YesNo
146
+ char raw_json; // YesNo
147
+ char nilnil; // YesNo
148
+ char empty_string; // YesNo
149
+ char allow_gc; // allow GC during parse
150
+ char quirks_mode; // allow single JSON values instead of documents
151
+ char allow_invalid; // YesNo - allow invalid unicode
152
+ char create_ok; // YesNo allow create_id
153
+ char allow_nan; // YEsyNo for parsing only
154
+ char trace; // YesNo
155
+ char safe; // YesNo
156
+ char sec_prec_set; // boolean (0 or 1)
157
+ char ignore_under; // YesNo - ignore attrs starting with _ if true in object and custom modes
158
+ char cache_keys; // YesNo
159
+ char cache_str; // string short than or equal to this are cache
148
160
  int64_t int_range_min; // dump numbers below as string
149
161
  int64_t int_range_max; // dump numbers above as string
150
- const char * create_id; // 0 or string
162
+ const char *create_id; // 0 or string
151
163
  size_t create_id_len; // length of create_id
152
164
  int sec_prec; // second precision when dumping time
153
165
  char float_prec; // float precision, linked to float_fmt
@@ -156,8 +168,8 @@ typedef struct _options {
156
168
  VALUE array_class; // class to use in place of Array on load
157
169
  struct _dumpOpts dump_opts;
158
170
  struct _rxClass str_rx;
159
- VALUE * ignore; // Qnil terminated array of classes or NULL
160
- } * Options;
171
+ VALUE *ignore; // Qnil terminated array of classes or NULL
172
+ } *Options;
161
173
 
162
174
  struct _out;
163
175
  typedef void (*DumpFunc)(VALUE obj, int depth, struct _out *out, bool as_ok);
@@ -167,18 +179,19 @@ typedef struct _rOpt {
167
179
  VALUE clas;
168
180
  bool on;
169
181
  DumpFunc dump;
170
- } * ROpt;
182
+ } *ROpt;
171
183
 
172
184
  typedef struct _rOptTable {
173
185
  int len;
174
186
  int alen;
175
187
  ROpt table;
176
- } * ROptTable;
188
+ } *ROptTable;
177
189
 
178
190
  typedef struct _out {
179
- char * buf;
180
- char * end;
181
- char * cur;
191
+ char stack_buffer[4096];
192
+ char *buf;
193
+ char *end;
194
+ char *cur;
182
195
  Cache8 circ_cache;
183
196
  slot_t circ_cnt;
184
197
  int indent;
@@ -187,21 +200,22 @@ typedef struct _out {
187
200
  uint32_t hash_cnt;
188
201
  bool allocated;
189
202
  bool omit_nil;
203
+ bool omit_null_byte;
190
204
  int argc;
191
- VALUE * argv;
205
+ VALUE *argv;
192
206
  DumpCaller caller; // used for the mimic json only
193
207
  ROptTable ropts;
194
- } * Out;
208
+ } *Out;
195
209
 
196
210
  typedef struct _strWriter {
197
211
  struct _out out;
198
212
  struct _options opts;
199
213
  int depth;
200
- char * types; // DumpType
201
- char * types_end;
214
+ char *types; // DumpType
215
+ char *types_end;
202
216
  int keyWritten;
203
217
 
204
- } * StrWriter;
218
+ } *StrWriter;
205
219
 
206
220
  typedef struct _streamWriter {
207
221
  struct _strWriter sw;
@@ -209,7 +223,7 @@ typedef struct _streamWriter {
209
223
  VALUE stream;
210
224
  int fd;
211
225
  int flush_limit; // indicator of when to flush
212
- } * StreamWriter;
226
+ } *StreamWriter;
213
227
 
214
228
  enum { NO_VAL = 0x00, STR_VAL = 0x01, COL_VAL = 0x02, RUBY_VAL = 0x03 };
215
229
 
@@ -220,14 +234,14 @@ typedef struct _leaf {
220
234
  size_t index; // array index, 0 is not set
221
235
  };
222
236
  union {
223
- char * str; // pointer to location in json string or allocated
237
+ char *str; // pointer to location in json string or allocated
224
238
  struct _leaf *elements; // array and hash elements
225
239
  VALUE value;
226
240
  };
227
241
  uint8_t rtype;
228
242
  uint8_t parent_type;
229
243
  uint8_t value_type;
230
- } * Leaf;
244
+ } *Leaf;
231
245
 
232
246
  extern VALUE oj_saj_parse(int argc, VALUE *argv, VALUE self);
233
247
  extern VALUE oj_sc_parse(int argc, VALUE *argv, VALUE self);
@@ -249,8 +263,7 @@ extern bool oj_hash_has_key(VALUE hash, VALUE key);
249
263
  extern void oj_parse_options(VALUE ropts, Options copts);
250
264
 
251
265
  extern void oj_dump_obj_to_json(VALUE obj, Options copts, Out out);
252
- extern void
253
- oj_dump_obj_to_json_using_params(VALUE obj, Options copts, Out out, int argc, VALUE *argv);
266
+ extern void oj_dump_obj_to_json_using_params(VALUE obj, Options copts, Out out, int argc, VALUE *argv);
254
267
  extern void oj_write_obj_to_file(VALUE obj, const char *path, Options copts);
255
268
  extern void oj_write_obj_to_stream(VALUE obj, VALUE stream, Options copts);
256
269
  extern void oj_dump_leaf_to_json(Leaf leaf, Options copts, Out out);
@@ -265,8 +278,8 @@ extern void oj_str_writer_pop(StrWriter sw);
265
278
  extern void oj_str_writer_pop_all(StrWriter sw);
266
279
 
267
280
  extern void oj_init_doc(void);
268
- extern void oj_string_writer_init();
269
- extern void oj_stream_writer_init();
281
+ extern void oj_string_writer_init(void);
282
+ extern void oj_stream_writer_init(void);
270
283
  extern void oj_str_writer_init(StrWriter sw, int buf_size);
271
284
  extern VALUE oj_define_mimic_json(int argc, VALUE *argv, VALUE self);
272
285
  extern VALUE oj_mimic_generate(int argc, VALUE *argv, VALUE self);
@@ -281,7 +294,8 @@ extern VALUE oj_rails_encode(int argc, VALUE *argv, VALUE self);
281
294
 
282
295
  extern VALUE Oj;
283
296
  extern struct _options oj_default_options;
284
- extern rb_encoding * oj_utf8_encoding;
297
+ extern rb_encoding *oj_utf8_encoding;
298
+ extern int oj_utf8_encoding_index;
285
299
 
286
300
  extern VALUE oj_bag_class;
287
301
  extern VALUE oj_bigdecimal_class;
@@ -304,11 +318,14 @@ extern VALUE oj_ascii_only_sym;
304
318
  extern VALUE oj_create_additions_sym;
305
319
  extern VALUE oj_decimal_class_sym;
306
320
  extern VALUE oj_hash_class_sym;
321
+ extern VALUE oj_in_sym;
307
322
  extern VALUE oj_indent_sym;
323
+ extern VALUE oj_nanosecond_sym;
308
324
  extern VALUE oj_max_nesting_sym;
309
325
  extern VALUE oj_object_class_sym;
310
326
  extern VALUE oj_object_nl_sym;
311
327
  extern VALUE oj_quirks_mode_sym;
328
+ extern VALUE oj_skip_null_byte_sym;
312
329
  extern VALUE oj_space_before_sym;
313
330
  extern VALUE oj_space_sym;
314
331
  extern VALUE oj_symbolize_names_sym;
@@ -321,6 +338,7 @@ extern ID oj_array_append_id;
321
338
  extern ID oj_array_end_id;
322
339
  extern ID oj_array_start_id;
323
340
  extern ID oj_as_json_id;
341
+ extern ID oj_at_id;
324
342
  extern ID oj_begin_id;
325
343
  extern ID oj_bigdecimal_id;
326
344
  extern ID oj_end_id;
@@ -334,7 +352,6 @@ extern ID oj_hash_key_id;
334
352
  extern ID oj_hash_set_id;
335
353
  extern ID oj_hash_start_id;
336
354
  extern ID oj_iconv_id;
337
- extern ID oj_instance_variables_id;
338
355
  extern ID oj_json_create_id;
339
356
  extern ID oj_length_id;
340
357
  extern ID oj_new_id;
@@ -364,6 +381,18 @@ extern bool oj_use_hash_alt;
364
381
  extern bool oj_use_array_alt;
365
382
  extern bool string_writer_optimized;
366
383
 
384
+ static inline VALUE oj_safe_string_convert(VALUE obj) {
385
+ VALUE rstr = rb_funcall(obj, oj_to_s_id, 0);
386
+ StringValue(rstr);
387
+ return rstr;
388
+ }
389
+
390
+ #define APPEND_CHARS(buffer, chars, size) \
391
+ { \
392
+ memcpy(buffer, chars, size); \
393
+ buffer += size; \
394
+ }
395
+
367
396
  #ifdef HAVE_PTHREAD_MUTEX_INIT
368
397
  extern pthread_mutex_t oj_cache_mutex;
369
398
  #else