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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +74 -0
- data/README.md +4 -2
- data/ext/oj/buf.h +11 -6
- data/ext/oj/cache.c +25 -24
- data/ext/oj/cache8.c +10 -9
- data/ext/oj/circarray.c +8 -6
- data/ext/oj/circarray.h +2 -2
- data/ext/oj/code.c +17 -24
- data/ext/oj/code.h +2 -2
- data/ext/oj/compat.c +17 -44
- data/ext/oj/custom.c +70 -141
- data/ext/oj/debug.c +3 -9
- data/ext/oj/dump.c +128 -118
- data/ext/oj/dump.h +12 -8
- data/ext/oj/dump_compat.c +564 -641
- data/ext/oj/dump_leaf.c +17 -63
- data/ext/oj/dump_object.c +70 -199
- data/ext/oj/dump_strict.c +22 -46
- data/ext/oj/encoder.c +1 -1
- data/ext/oj/err.c +2 -13
- data/ext/oj/err.h +9 -12
- data/ext/oj/extconf.rb +14 -5
- data/ext/oj/fast.c +75 -103
- data/ext/oj/intern.c +52 -50
- data/ext/oj/intern.h +4 -8
- data/ext/oj/mem.c +318 -0
- data/ext/oj/mem.h +53 -0
- data/ext/oj/mimic_json.c +75 -47
- data/ext/oj/object.c +49 -66
- data/ext/oj/odd.c +89 -67
- data/ext/oj/odd.h +15 -15
- data/ext/oj/oj.c +140 -99
- data/ext/oj/oj.h +80 -51
- data/ext/oj/parse.c +162 -184
- data/ext/oj/parse.h +7 -10
- data/ext/oj/parser.c +89 -34
- data/ext/oj/parser.h +18 -7
- data/ext/oj/rails.c +82 -146
- data/ext/oj/rails.h +1 -1
- data/ext/oj/reader.c +11 -12
- data/ext/oj/reader.h +4 -2
- data/ext/oj/resolve.c +3 -4
- data/ext/oj/rxclass.c +6 -5
- data/ext/oj/rxclass.h +1 -1
- data/ext/oj/saj.c +20 -31
- data/ext/oj/saj2.c +329 -93
- data/ext/oj/saj2.h +23 -0
- data/ext/oj/scp.c +3 -14
- data/ext/oj/sparse.c +26 -70
- data/ext/oj/stream_writer.c +12 -22
- data/ext/oj/strict.c +20 -52
- data/ext/oj/string_writer.c +21 -21
- data/ext/oj/trace.h +31 -4
- data/ext/oj/usual.c +105 -150
- data/ext/oj/usual.h +68 -0
- data/ext/oj/util.h +1 -1
- data/ext/oj/val_stack.c +1 -1
- data/ext/oj/val_stack.h +8 -7
- data/ext/oj/validate.c +21 -26
- data/ext/oj/wab.c +31 -68
- data/lib/oj/active_support_helper.rb +0 -1
- data/lib/oj/bag.rb +7 -1
- data/lib/oj/easy_hash.rb +4 -5
- data/lib/oj/error.rb +0 -1
- data/lib/oj/json.rb +4 -2
- data/lib/oj/mimic.rb +4 -2
- data/lib/oj/saj.rb +20 -6
- data/lib/oj/state.rb +9 -6
- data/lib/oj/version.rb +1 -2
- data/lib/oj.rb +2 -0
- data/pages/Compatibility.md +1 -1
- data/pages/InstallOptions.md +20 -0
- data/pages/Options.md +10 -0
- data/test/_test_active.rb +8 -9
- data/test/_test_active_mimic.rb +7 -8
- data/test/_test_mimic_rails.rb +17 -20
- data/test/activerecord/result_test.rb +5 -6
- data/test/{activesupport5 → activesupport7}/abstract_unit.rb +16 -12
- data/test/{activesupport5 → activesupport7}/decoding_test.rb +2 -10
- data/test/{activesupport5 → activesupport7}/encoding_test.rb +20 -34
- data/test/{activesupport5 → activesupport7}/encoding_test_cases.rb +6 -0
- data/test/{activesupport5 → activesupport7}/time_zone_test_helpers.rb +8 -0
- data/test/files.rb +15 -15
- data/test/foo.rb +9 -71
- data/test/helper.rb +11 -8
- data/test/isolated/shared.rb +3 -2
- data/test/json_gem/json_addition_test.rb +2 -2
- data/test/json_gem/json_common_interface_test.rb +4 -4
- data/test/json_gem/json_encoding_test.rb +0 -0
- data/test/json_gem/json_ext_parser_test.rb +1 -0
- data/test/json_gem/json_fixtures_test.rb +3 -2
- data/test/json_gem/json_generator_test.rb +48 -36
- data/test/json_gem/json_generic_object_test.rb +11 -11
- data/test/json_gem/json_parser_test.rb +54 -47
- data/test/json_gem/json_string_matching_test.rb +9 -9
- data/test/json_gem/test_helper.rb +7 -3
- data/test/mem.rb +13 -12
- data/test/perf.rb +21 -26
- data/test/perf_compat.rb +31 -33
- data/test/perf_dump.rb +50 -0
- data/test/perf_fast.rb +80 -82
- data/test/perf_file.rb +27 -29
- data/test/perf_object.rb +65 -69
- data/test/perf_once.rb +12 -11
- data/test/perf_parser.rb +42 -48
- data/test/perf_saj.rb +46 -54
- data/test/perf_scp.rb +57 -69
- data/test/perf_simple.rb +41 -39
- data/test/perf_strict.rb +68 -70
- data/test/perf_wab.rb +67 -69
- data/test/prec.rb +3 -3
- data/test/sample/change.rb +0 -1
- data/test/sample/dir.rb +0 -1
- data/test/sample/doc.rb +0 -1
- data/test/sample/file.rb +0 -1
- data/test/sample/group.rb +0 -1
- data/test/sample/hasprops.rb +0 -1
- data/test/sample/layer.rb +0 -1
- data/test/sample/rect.rb +0 -1
- data/test/sample/shape.rb +0 -1
- data/test/sample/text.rb +0 -1
- data/test/sample.rb +16 -16
- data/test/sample_json.rb +8 -8
- data/test/test_compat.rb +76 -42
- data/test/test_custom.rb +72 -51
- data/test/test_debian.rb +7 -10
- data/test/test_fast.rb +86 -90
- data/test/test_file.rb +41 -30
- data/test/test_gc.rb +16 -5
- data/test/test_generate.rb +5 -5
- data/test/test_hash.rb +4 -4
- data/test/test_integer_range.rb +9 -9
- data/test/test_null.rb +20 -20
- data/test/test_object.rb +85 -96
- data/test/test_parser.rb +6 -22
- data/test/test_parser_debug.rb +27 -0
- data/test/test_parser_saj.rb +115 -23
- data/test/test_parser_usual.rb +6 -6
- data/test/test_rails.rb +2 -2
- data/test/test_saj.rb +10 -8
- data/test/test_scp.rb +37 -39
- data/test/test_strict.rb +30 -32
- data/test/test_various.rb +147 -99
- data/test/test_wab.rb +48 -44
- data/test/test_writer.rb +47 -47
- data/test/tests.rb +13 -4
- data/test/tests_mimic.rb +12 -3
- data/test/tests_mimic_addition.rb +12 -3
- metadata +33 -144
- data/test/activesupport4/decoding_test.rb +0 -108
- data/test/activesupport4/encoding_test.rb +0 -531
- data/test/activesupport4/test_helper.rb +0 -41
- data/test/activesupport5/test_helper.rb +0 -72
- data/test/bar.rb +0 -16
- data/test/baz.rb +0 -16
- data/test/bug.rb +0 -16
- 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
|
-
} *
|
129
|
+
} *DumpOpts;
|
118
130
|
|
119
131
|
typedef struct _options {
|
120
|
-
int
|
121
|
-
char
|
122
|
-
char
|
123
|
-
char
|
124
|
-
char
|
125
|
-
char
|
126
|
-
char
|
127
|
-
char
|
128
|
-
char
|
129
|
-
char
|
130
|
-
char
|
131
|
-
char
|
132
|
-
char
|
133
|
-
char
|
134
|
-
char
|
135
|
-
char
|
136
|
-
char
|
137
|
-
char
|
138
|
-
char
|
139
|
-
char
|
140
|
-
char
|
141
|
-
char
|
142
|
-
char
|
143
|
-
char
|
144
|
-
char
|
145
|
-
char
|
146
|
-
char
|
147
|
-
char
|
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
|
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
|
160
|
-
} *
|
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
|
-
} *
|
182
|
+
} *ROpt;
|
171
183
|
|
172
184
|
typedef struct _rOptTable {
|
173
185
|
int len;
|
174
186
|
int alen;
|
175
187
|
ROpt table;
|
176
|
-
} *
|
188
|
+
} *ROptTable;
|
177
189
|
|
178
190
|
typedef struct _out {
|
179
|
-
char
|
180
|
-
char
|
181
|
-
char
|
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
|
205
|
+
VALUE *argv;
|
192
206
|
DumpCaller caller; // used for the mimic json only
|
193
207
|
ROptTable ropts;
|
194
|
-
} *
|
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
|
201
|
-
char
|
214
|
+
char *types; // DumpType
|
215
|
+
char *types_end;
|
202
216
|
int keyWritten;
|
203
217
|
|
204
|
-
} *
|
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
|
-
} *
|
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
|
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
|
-
} *
|
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
|
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
|