oj 3.9.1 → 3.16.11

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 (171) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +1452 -0
  3. data/README.md +21 -6
  4. data/RELEASE_NOTES.md +61 -0
  5. data/ext/oj/buf.h +50 -68
  6. data/ext/oj/cache.c +329 -0
  7. data/ext/oj/cache.h +22 -0
  8. data/ext/oj/cache8.c +60 -62
  9. data/ext/oj/cache8.h +9 -36
  10. data/ext/oj/circarray.c +38 -42
  11. data/ext/oj/circarray.h +12 -13
  12. data/ext/oj/code.c +158 -179
  13. data/ext/oj/code.h +20 -22
  14. data/ext/oj/compat.c +145 -205
  15. data/ext/oj/custom.c +740 -880
  16. data/ext/oj/debug.c +126 -0
  17. data/ext/oj/dump.c +1145 -844
  18. data/ext/oj/dump.h +71 -57
  19. data/ext/oj/dump_compat.c +575 -655
  20. data/ext/oj/dump_leaf.c +96 -186
  21. data/ext/oj/dump_object.c +533 -660
  22. data/ext/oj/dump_strict.c +306 -340
  23. data/ext/oj/encode.h +4 -33
  24. data/ext/oj/encoder.c +43 -0
  25. data/ext/oj/err.c +28 -28
  26. data/ext/oj/err.h +39 -42
  27. data/ext/oj/extconf.rb +28 -7
  28. data/ext/oj/fast.c +1052 -1113
  29. data/ext/oj/intern.c +313 -0
  30. data/ext/oj/intern.h +22 -0
  31. data/ext/oj/mem.c +318 -0
  32. data/ext/oj/mem.h +53 -0
  33. data/ext/oj/mimic_json.c +471 -430
  34. data/ext/oj/object.c +532 -580
  35. data/ext/oj/odd.c +156 -142
  36. data/ext/oj/odd.h +25 -26
  37. data/ext/oj/oj.c +1346 -961
  38. data/ext/oj/oj.h +307 -290
  39. data/ext/oj/parse.c +954 -858
  40. data/ext/oj/parse.h +74 -72
  41. data/ext/oj/parser.c +1600 -0
  42. data/ext/oj/parser.h +103 -0
  43. data/ext/oj/rails.c +819 -836
  44. data/ext/oj/rails.h +8 -11
  45. data/ext/oj/reader.c +136 -147
  46. data/ext/oj/reader.h +69 -83
  47. data/ext/oj/resolve.c +41 -63
  48. data/ext/oj/resolve.h +4 -6
  49. data/ext/oj/rxclass.c +69 -72
  50. data/ext/oj/rxclass.h +12 -13
  51. data/ext/oj/saj.c +440 -485
  52. data/ext/oj/saj2.c +584 -0
  53. data/ext/oj/saj2.h +23 -0
  54. data/ext/oj/scp.c +79 -118
  55. data/ext/oj/simd.h +10 -0
  56. data/ext/oj/sparse.c +739 -709
  57. data/ext/oj/stream_writer.c +141 -175
  58. data/ext/oj/strict.c +103 -128
  59. data/ext/oj/string_writer.c +244 -261
  60. data/ext/oj/trace.c +34 -41
  61. data/ext/oj/trace.h +42 -15
  62. data/ext/oj/usual.c +1218 -0
  63. data/ext/oj/usual.h +69 -0
  64. data/ext/oj/util.c +107 -107
  65. data/ext/oj/util.h +4 -3
  66. data/ext/oj/val_stack.c +61 -78
  67. data/ext/oj/val_stack.h +80 -114
  68. data/ext/oj/validate.c +46 -0
  69. data/ext/oj/wab.c +316 -361
  70. data/lib/oj/active_support_helper.rb +1 -3
  71. data/lib/oj/bag.rb +8 -1
  72. data/lib/oj/easy_hash.rb +9 -9
  73. data/lib/oj/error.rb +1 -2
  74. data/lib/oj/json.rb +162 -150
  75. data/lib/oj/mimic.rb +54 -20
  76. data/lib/oj/saj.rb +20 -6
  77. data/lib/oj/schandler.rb +5 -4
  78. data/lib/oj/state.rb +12 -8
  79. data/lib/oj/version.rb +1 -2
  80. data/lib/oj.rb +2 -8
  81. data/pages/Compatibility.md +1 -1
  82. data/pages/Encoding.md +1 -1
  83. data/pages/InstallOptions.md +20 -0
  84. data/pages/JsonGem.md +15 -0
  85. data/pages/Modes.md +9 -3
  86. data/pages/Options.md +62 -12
  87. data/pages/Parser.md +309 -0
  88. data/pages/Rails.md +73 -22
  89. metadata +68 -192
  90. data/ext/oj/hash.c +0 -163
  91. data/ext/oj/hash.h +0 -46
  92. data/ext/oj/hash_test.c +0 -512
  93. data/test/_test_active.rb +0 -76
  94. data/test/_test_active_mimic.rb +0 -96
  95. data/test/_test_mimic_rails.rb +0 -126
  96. data/test/activerecord/result_test.rb +0 -27
  97. data/test/activesupport4/decoding_test.rb +0 -108
  98. data/test/activesupport4/encoding_test.rb +0 -531
  99. data/test/activesupport4/test_helper.rb +0 -41
  100. data/test/activesupport5/decoding_test.rb +0 -125
  101. data/test/activesupport5/encoding_test.rb +0 -485
  102. data/test/activesupport5/encoding_test_cases.rb +0 -90
  103. data/test/activesupport5/test_helper.rb +0 -50
  104. data/test/activesupport5/time_zone_test_helpers.rb +0 -24
  105. data/test/bar.rb +0 -25
  106. data/test/files.rb +0 -29
  107. data/test/foo.rb +0 -21
  108. data/test/helper.rb +0 -26
  109. data/test/isolated/shared.rb +0 -308
  110. data/test/isolated/test_mimic_after.rb +0 -13
  111. data/test/isolated/test_mimic_alone.rb +0 -12
  112. data/test/isolated/test_mimic_as_json.rb +0 -45
  113. data/test/isolated/test_mimic_before.rb +0 -13
  114. data/test/isolated/test_mimic_define.rb +0 -28
  115. data/test/isolated/test_mimic_rails_after.rb +0 -22
  116. data/test/isolated/test_mimic_rails_before.rb +0 -21
  117. data/test/isolated/test_mimic_redefine.rb +0 -15
  118. data/test/json_gem/json_addition_test.rb +0 -216
  119. data/test/json_gem/json_common_interface_test.rb +0 -148
  120. data/test/json_gem/json_encoding_test.rb +0 -107
  121. data/test/json_gem/json_ext_parser_test.rb +0 -20
  122. data/test/json_gem/json_fixtures_test.rb +0 -35
  123. data/test/json_gem/json_generator_test.rb +0 -383
  124. data/test/json_gem/json_generic_object_test.rb +0 -90
  125. data/test/json_gem/json_parser_test.rb +0 -470
  126. data/test/json_gem/json_string_matching_test.rb +0 -42
  127. data/test/json_gem/test_helper.rb +0 -18
  128. data/test/perf.rb +0 -107
  129. data/test/perf_compat.rb +0 -130
  130. data/test/perf_fast.rb +0 -164
  131. data/test/perf_file.rb +0 -64
  132. data/test/perf_object.rb +0 -138
  133. data/test/perf_saj.rb +0 -109
  134. data/test/perf_scp.rb +0 -151
  135. data/test/perf_simple.rb +0 -287
  136. data/test/perf_strict.rb +0 -145
  137. data/test/perf_wab.rb +0 -131
  138. data/test/sample/change.rb +0 -14
  139. data/test/sample/dir.rb +0 -19
  140. data/test/sample/doc.rb +0 -36
  141. data/test/sample/file.rb +0 -48
  142. data/test/sample/group.rb +0 -16
  143. data/test/sample/hasprops.rb +0 -16
  144. data/test/sample/layer.rb +0 -12
  145. data/test/sample/line.rb +0 -20
  146. data/test/sample/oval.rb +0 -10
  147. data/test/sample/rect.rb +0 -10
  148. data/test/sample/shape.rb +0 -35
  149. data/test/sample/text.rb +0 -20
  150. data/test/sample.rb +0 -54
  151. data/test/sample_json.rb +0 -37
  152. data/test/test_compat.rb +0 -509
  153. data/test/test_custom.rb +0 -503
  154. data/test/test_debian.rb +0 -53
  155. data/test/test_fast.rb +0 -470
  156. data/test/test_file.rb +0 -239
  157. data/test/test_gc.rb +0 -49
  158. data/test/test_hash.rb +0 -29
  159. data/test/test_integer_range.rb +0 -73
  160. data/test/test_null.rb +0 -376
  161. data/test/test_object.rb +0 -1018
  162. data/test/test_saj.rb +0 -186
  163. data/test/test_scp.rb +0 -433
  164. data/test/test_strict.rb +0 -410
  165. data/test/test_various.rb +0 -741
  166. data/test/test_wab.rb +0 -307
  167. data/test/test_writer.rb +0 -380
  168. data/test/tests.rb +0 -24
  169. data/test/tests_mimic.rb +0 -14
  170. data/test/tests_mimic_addition.rb +0 -7
  171. data/test/zoo.rb +0 -13
data/ext/oj/val_stack.h CHANGED
@@ -1,185 +1,151 @@
1
- /* val_stack.h
2
- * Copyright (c) 2011, Peter Ohler
3
- * All rights reserved.
4
- *
5
- * Redistribution and use in source and binary forms, with or without
6
- * modification, are permitted provided that the following conditions are met:
7
- *
8
- * - Redistributions of source code must retain the above copyright notice, this
9
- * list of conditions and the following disclaimer.
10
- *
11
- * - Redistributions in binary form must reproduce the above copyright notice,
12
- * this list of conditions and the following disclaimer in the documentation
13
- * and/or other materials provided with the distribution.
14
- *
15
- * - Neither the name of Peter Ohler nor the names of its contributors may be
16
- * used to endorse or promote products derived from this software without
17
- * specific prior written permission.
18
- *
19
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22
- * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
23
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
25
- * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
26
- * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
27
- * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
- */
1
+ // Copyright (c) 2011 Peter Ohler. All rights reserved.
2
+ // Licensed under the MIT License. See LICENSE file in the project root for license details.
30
3
 
31
4
  #ifndef OJ_VAL_STACK_H
32
5
  #define OJ_VAL_STACK_H
33
6
 
34
- #include "ruby.h"
35
- #include "odd.h"
36
7
  #include <stdint.h>
8
+
9
+ #include "mem.h"
10
+ #include "odd.h"
11
+ #include "ruby.h"
37
12
  #ifdef HAVE_PTHREAD_MUTEX_INIT
38
13
  #include <pthread.h>
39
14
  #endif
40
15
 
41
- #define STACK_INC 64
16
+ #define STACK_INC 64
42
17
 
43
18
  typedef enum {
44
- NEXT_NONE = 0,
45
- NEXT_ARRAY_NEW = 'a',
46
- NEXT_ARRAY_ELEMENT = 'e',
47
- NEXT_ARRAY_COMMA = ',',
48
- NEXT_HASH_NEW = 'h',
49
- NEXT_HASH_KEY = 'k',
50
- NEXT_HASH_COLON = ':',
51
- NEXT_HASH_VALUE = 'v',
52
- NEXT_HASH_COMMA = 'n',
19
+ NEXT_NONE = 0,
20
+ NEXT_ARRAY_NEW = 'a',
21
+ NEXT_ARRAY_ELEMENT = 'e',
22
+ NEXT_ARRAY_COMMA = ',',
23
+ NEXT_HASH_NEW = 'h',
24
+ NEXT_HASH_KEY = 'k',
25
+ NEXT_HASH_COLON = ':',
26
+ NEXT_HASH_VALUE = 'v',
27
+ NEXT_HASH_COMMA = 'n',
53
28
  } ValNext;
54
29
 
55
30
  typedef struct _val {
56
- volatile VALUE val;
57
- const char *key;
58
- char karray[32];
59
- volatile VALUE key_val;
60
- const char *classname;
61
- VALUE clas;
62
- OddArgs odd_args;
63
- uint16_t klen;
64
- uint16_t clen;
65
- char next; // ValNext
66
- char k1; // first original character in the key
67
- char kalloc;
31
+ volatile VALUE val;
32
+ const char *key;
33
+ char karray[32];
34
+ volatile VALUE key_val;
35
+ const char *classname;
36
+ VALUE clas;
37
+ OddArgs odd_args;
38
+ uint16_t klen;
39
+ uint16_t clen;
40
+ char next; // ValNext
41
+ char k1; // first original character in the key
42
+ char kalloc;
68
43
  } *Val;
69
44
 
70
45
  typedef struct _valStack {
71
- struct _val base[STACK_INC];
72
- Val head; // current stack
73
- Val end; // stack end
74
- Val tail; // pointer to one past last element name on stack
46
+ struct _val base[STACK_INC];
47
+ Val head; // current stack
48
+ Val end; // stack end
49
+ Val tail; // pointer to one past last element name on stack
75
50
  #ifdef HAVE_PTHREAD_MUTEX_INIT
76
- pthread_mutex_t mutex;
51
+ pthread_mutex_t mutex;
77
52
  #else
78
- VALUE mutex;
53
+ VALUE mutex;
79
54
  #endif
80
55
 
81
56
  } *ValStack;
82
57
 
83
- extern VALUE oj_stack_init(ValStack stack);
58
+ extern VALUE oj_stack_init(ValStack stack);
84
59
 
85
- inline static int
86
- stack_empty(ValStack stack) {
60
+ inline static int stack_empty(ValStack stack) {
87
61
  return (stack->head == stack->tail);
88
62
  }
89
63
 
90
- inline static void
91
- stack_cleanup(ValStack stack) {
64
+ inline static void stack_cleanup(ValStack stack) {
92
65
  if (stack->base != stack->head) {
93
- xfree(stack->head);
94
- stack->head = NULL;
66
+ OJ_R_FREE(stack->head);
67
+ stack->head = NULL;
95
68
  }
96
69
  }
97
70
 
98
- inline static void
99
- stack_push(ValStack stack, VALUE val, ValNext next) {
71
+ inline static void stack_push(ValStack stack, VALUE val, ValNext next) {
100
72
  if (stack->end <= stack->tail) {
101
- size_t len = stack->end - stack->head;
102
- size_t toff = stack->tail - stack->head;
103
- Val head = stack->head;
104
-
105
- // A realloc can trigger a GC so make sure it happens outside the lock
106
- // but lock before changing pointers.
107
- if (stack->base == stack->head) {
108
- head = ALLOC_N(struct _val, len + STACK_INC);
109
- memcpy(head, stack->base, sizeof(struct _val) * len);
110
- } else {
111
- REALLOC_N(head, struct _val, len + STACK_INC);
112
- }
73
+ size_t len = stack->end - stack->head;
74
+ size_t toff = stack->tail - stack->head;
75
+ Val head = stack->head;
76
+
77
+ // A realloc can trigger a GC so make sure it happens outside the lock
78
+ // but lock before changing pointers.
79
+ if (stack->base == stack->head) {
80
+ head = OJ_R_ALLOC_N(struct _val, len + STACK_INC);
81
+ memcpy(head, stack->base, sizeof(struct _val) * len);
82
+ } else {
83
+ OJ_R_REALLOC_N(head, struct _val, len + STACK_INC);
84
+ }
113
85
  #ifdef HAVE_PTHREAD_MUTEX_INIT
114
- pthread_mutex_lock(&stack->mutex);
86
+ pthread_mutex_lock(&stack->mutex);
115
87
  #else
116
- rb_mutex_lock(stack->mutex);
88
+ rb_mutex_lock(stack->mutex);
117
89
  #endif
118
- stack->head = head;
119
- stack->tail = stack->head + toff;
120
- stack->end = stack->head + len + STACK_INC;
90
+ stack->head = head;
91
+ stack->tail = stack->head + toff;
92
+ stack->end = stack->head + len + STACK_INC;
121
93
  #ifdef HAVE_PTHREAD_MUTEX_INIT
122
- pthread_mutex_unlock(&stack->mutex);
94
+ pthread_mutex_unlock(&stack->mutex);
123
95
  #else
124
- rb_mutex_unlock(stack->mutex);
96
+ rb_mutex_unlock(stack->mutex);
125
97
  #endif
126
98
  }
127
- stack->tail->val = val;
128
- stack->tail->next = next;
99
+ stack->tail->val = val;
100
+ stack->tail->next = next;
129
101
  stack->tail->classname = NULL;
130
- stack->tail->clas = Qundef;
131
- stack->tail->odd_args = NULL;
132
- stack->tail->key = 0;
133
- stack->tail->key_val = Qundef;
134
- stack->tail->clen = 0;
135
- stack->tail->klen = 0;
136
- stack->tail->kalloc = 0;
102
+ stack->tail->clas = Qundef;
103
+ stack->tail->odd_args = NULL;
104
+ stack->tail->key = 0;
105
+ stack->tail->key_val = Qundef;
106
+ stack->tail->clen = 0;
107
+ stack->tail->klen = 0;
108
+ stack->tail->kalloc = 0;
137
109
  stack->tail++;
138
110
  }
139
111
 
140
- inline static size_t
141
- stack_size(ValStack stack) {
112
+ inline static size_t stack_size(ValStack stack) {
142
113
  return stack->tail - stack->head;
143
114
  }
144
115
 
145
- inline static Val
146
- stack_peek(ValStack stack) {
116
+ inline static Val stack_peek(ValStack stack) {
147
117
  if (stack->head < stack->tail) {
148
- return stack->tail - 1;
118
+ return stack->tail - 1;
149
119
  }
150
120
  return 0;
151
121
  }
152
122
 
153
- inline static Val
154
- stack_peek_up(ValStack stack) {
123
+ inline static Val stack_peek_up(ValStack stack) {
155
124
  if (stack->head < stack->tail - 1) {
156
- return stack->tail - 2;
125
+ return stack->tail - 2;
157
126
  }
158
127
  return 0;
159
128
  }
160
129
 
161
- inline static Val
162
- stack_prev(ValStack stack) {
130
+ inline static Val stack_prev(ValStack stack) {
163
131
  return stack->tail;
164
132
  }
165
133
 
166
- inline static VALUE
167
- stack_head_val(ValStack stack) {
134
+ inline static VALUE stack_head_val(ValStack stack) {
168
135
  if (Qundef != stack->head->val) {
169
- return stack->head->val;
136
+ return stack->head->val;
170
137
  }
171
138
  return Qnil;
172
139
  }
173
140
 
174
- inline static Val
175
- stack_pop(ValStack stack) {
141
+ inline static Val stack_pop(ValStack stack) {
176
142
  if (stack->head < stack->tail) {
177
- stack->tail--;
178
- return stack->tail;
143
+ stack->tail--;
144
+ return stack->tail;
179
145
  }
180
146
  return 0;
181
147
  }
182
148
 
183
- extern const char* oj_stack_next_string(ValNext n);
149
+ extern const char *oj_stack_next_string(ValNext n);
184
150
 
185
151
  #endif /* OJ_VAL_STACK_H */
data/ext/oj/validate.c ADDED
@@ -0,0 +1,46 @@
1
+ // Copyright (c) 2021, Peter Ohler, All rights reserved.
2
+
3
+ #include "parser.h"
4
+
5
+ static void noop(ojParser p) {
6
+ }
7
+
8
+ static VALUE option(ojParser p, const char *key, VALUE value) {
9
+ rb_raise(rb_eArgError, "%s is not an option for the validate delegate", key);
10
+ return Qnil;
11
+ }
12
+
13
+ static VALUE result(ojParser p) {
14
+ return Qnil;
15
+ }
16
+
17
+ static void dfree(ojParser p) {
18
+ }
19
+
20
+ static void mark(ojParser p) {
21
+ }
22
+
23
+ void oj_set_parser_validator(ojParser p) {
24
+ Funcs end = p->funcs + 3;
25
+ Funcs f;
26
+ p->ctx = NULL;
27
+
28
+ for (f = p->funcs; f < end; f++) {
29
+ f->add_null = noop;
30
+ f->add_true = noop;
31
+ f->add_false = noop;
32
+ f->add_int = noop;
33
+ f->add_float = noop;
34
+ f->add_big = noop;
35
+ f->add_str = noop;
36
+ f->open_array = noop;
37
+ f->close_array = noop;
38
+ f->open_object = noop;
39
+ f->close_object = noop;
40
+ }
41
+ p->option = option;
42
+ p->result = result;
43
+ p->free = dfree;
44
+ p->mark = mark;
45
+ p->start = noop;
46
+ }