oj 3.11.0 → 3.16.5

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 (173) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +1421 -0
  3. data/README.md +20 -5
  4. data/RELEASE_NOTES.md +61 -0
  5. data/ext/oj/buf.h +48 -38
  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 +8 -7
  10. data/ext/oj/circarray.c +35 -35
  11. data/ext/oj/circarray.h +11 -9
  12. data/ext/oj/code.c +156 -174
  13. data/ext/oj/code.h +19 -18
  14. data/ext/oj/compat.c +140 -197
  15. data/ext/oj/custom.c +737 -879
  16. data/ext/oj/debug.c +126 -0
  17. data/ext/oj/dump.c +830 -835
  18. data/ext/oj/dump.h +65 -53
  19. data/ext/oj/dump_compat.c +566 -642
  20. data/ext/oj/dump_leaf.c +95 -182
  21. data/ext/oj/dump_object.c +518 -659
  22. data/ext/oj/dump_strict.c +301 -334
  23. data/ext/oj/encode.h +3 -4
  24. data/ext/oj/encoder.c +43 -0
  25. data/ext/oj/err.c +27 -24
  26. data/ext/oj/err.h +38 -13
  27. data/ext/oj/extconf.rb +23 -7
  28. data/ext/oj/fast.c +1043 -1073
  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 +449 -423
  34. data/ext/oj/object.c +530 -576
  35. data/ext/oj/odd.c +155 -138
  36. data/ext/oj/odd.h +24 -22
  37. data/ext/oj/oj.c +1331 -993
  38. data/ext/oj/oj.h +306 -292
  39. data/ext/oj/parse.c +934 -938
  40. data/ext/oj/parse.h +73 -70
  41. data/ext/oj/parser.c +1600 -0
  42. data/ext/oj/parser.h +101 -0
  43. data/ext/oj/rails.c +795 -845
  44. data/ext/oj/rails.h +7 -7
  45. data/ext/oj/reader.c +132 -140
  46. data/ext/oj/reader.h +67 -78
  47. data/ext/oj/resolve.c +40 -59
  48. data/ext/oj/resolve.h +3 -2
  49. data/ext/oj/rxclass.c +67 -67
  50. data/ext/oj/rxclass.h +11 -9
  51. data/ext/oj/saj.c +441 -480
  52. data/ext/oj/saj2.c +584 -0
  53. data/ext/oj/saj2.h +23 -0
  54. data/ext/oj/scp.c +78 -111
  55. data/ext/oj/sparse.c +726 -730
  56. data/ext/oj/stream_writer.c +146 -165
  57. data/ext/oj/strict.c +103 -123
  58. data/ext/oj/string_writer.c +241 -253
  59. data/ext/oj/trace.c +29 -33
  60. data/ext/oj/trace.h +41 -11
  61. data/ext/oj/usual.c +1218 -0
  62. data/ext/oj/usual.h +69 -0
  63. data/ext/oj/util.c +103 -103
  64. data/ext/oj/util.h +3 -2
  65. data/ext/oj/val_stack.c +60 -49
  66. data/ext/oj/val_stack.h +79 -85
  67. data/ext/oj/validate.c +46 -0
  68. data/ext/oj/wab.c +307 -350
  69. data/lib/oj/active_support_helper.rb +1 -3
  70. data/lib/oj/bag.rb +8 -1
  71. data/lib/oj/easy_hash.rb +9 -9
  72. data/lib/oj/error.rb +1 -2
  73. data/lib/oj/json.rb +162 -150
  74. data/lib/oj/mimic.rb +9 -19
  75. data/lib/oj/saj.rb +20 -6
  76. data/lib/oj/schandler.rb +5 -4
  77. data/lib/oj/state.rb +12 -8
  78. data/lib/oj/version.rb +1 -2
  79. data/lib/oj.rb +2 -0
  80. data/pages/Compatibility.md +1 -1
  81. data/pages/InstallOptions.md +20 -0
  82. data/pages/JsonGem.md +15 -0
  83. data/pages/Modes.md +8 -3
  84. data/pages/Options.md +43 -5
  85. data/pages/Parser.md +309 -0
  86. data/pages/Rails.md +14 -2
  87. data/test/_test_active.rb +8 -9
  88. data/test/_test_active_mimic.rb +7 -8
  89. data/test/_test_mimic_rails.rb +17 -20
  90. data/test/activerecord/result_test.rb +12 -8
  91. data/test/activesupport6/encoding_test.rb +63 -28
  92. data/test/{activesupport5 → activesupport7}/abstract_unit.rb +16 -12
  93. data/test/{activesupport5 → activesupport7}/decoding_test.rb +2 -10
  94. data/test/{activesupport5 → activesupport7}/encoding_test.rb +86 -50
  95. data/test/{activesupport5 → activesupport7}/encoding_test_cases.rb +6 -0
  96. data/test/{activesupport5 → activesupport7}/time_zone_test_helpers.rb +8 -0
  97. data/test/files.rb +15 -15
  98. data/test/foo.rb +17 -43
  99. data/test/helper.rb +16 -3
  100. data/test/isolated/shared.rb +3 -2
  101. data/test/json_gem/json_addition_test.rb +2 -2
  102. data/test/json_gem/json_common_interface_test.rb +8 -6
  103. data/test/json_gem/json_encoding_test.rb +0 -0
  104. data/test/json_gem/json_ext_parser_test.rb +1 -0
  105. data/test/json_gem/json_fixtures_test.rb +3 -2
  106. data/test/json_gem/json_generator_test.rb +71 -41
  107. data/test/json_gem/json_generic_object_test.rb +11 -11
  108. data/test/json_gem/json_parser_test.rb +54 -47
  109. data/test/json_gem/json_string_matching_test.rb +9 -9
  110. data/test/json_gem/test_helper.rb +12 -0
  111. data/test/mem.rb +34 -0
  112. data/test/perf.rb +22 -27
  113. data/test/perf_compat.rb +31 -33
  114. data/test/perf_dump.rb +50 -0
  115. data/test/perf_fast.rb +80 -82
  116. data/test/perf_file.rb +27 -29
  117. data/test/perf_object.rb +65 -69
  118. data/test/perf_once.rb +59 -0
  119. data/test/perf_parser.rb +183 -0
  120. data/test/perf_saj.rb +46 -54
  121. data/test/perf_scp.rb +58 -69
  122. data/test/perf_simple.rb +41 -39
  123. data/test/perf_strict.rb +74 -82
  124. data/test/perf_wab.rb +67 -69
  125. data/test/prec.rb +5 -5
  126. data/test/sample/change.rb +0 -1
  127. data/test/sample/dir.rb +0 -1
  128. data/test/sample/doc.rb +0 -1
  129. data/test/sample/file.rb +0 -1
  130. data/test/sample/group.rb +0 -1
  131. data/test/sample/hasprops.rb +0 -1
  132. data/test/sample/layer.rb +0 -1
  133. data/test/sample/rect.rb +0 -1
  134. data/test/sample/shape.rb +0 -1
  135. data/test/sample/text.rb +0 -1
  136. data/test/sample.rb +16 -16
  137. data/test/sample_json.rb +8 -8
  138. data/test/test_compat.rb +97 -45
  139. data/test/test_custom.rb +73 -51
  140. data/test/test_debian.rb +7 -10
  141. data/test/test_fast.rb +135 -79
  142. data/test/test_file.rb +41 -30
  143. data/test/test_gc.rb +16 -5
  144. data/test/test_generate.rb +21 -0
  145. data/test/test_hash.rb +15 -5
  146. data/test/test_integer_range.rb +9 -9
  147. data/test/test_null.rb +20 -20
  148. data/test/test_object.rb +99 -96
  149. data/test/test_parser.rb +11 -0
  150. data/test/test_parser_debug.rb +27 -0
  151. data/test/test_parser_saj.rb +337 -0
  152. data/test/test_parser_usual.rb +251 -0
  153. data/test/test_rails.rb +2 -2
  154. data/test/test_saj.rb +10 -8
  155. data/test/test_scp.rb +38 -40
  156. data/test/test_strict.rb +40 -32
  157. data/test/test_various.rb +165 -84
  158. data/test/test_wab.rb +48 -44
  159. data/test/test_writer.rb +47 -47
  160. data/test/tests.rb +13 -5
  161. data/test/tests_mimic.rb +12 -3
  162. data/test/tests_mimic_addition.rb +12 -3
  163. metadata +75 -127
  164. data/ext/oj/hash.c +0 -135
  165. data/ext/oj/hash.h +0 -18
  166. data/ext/oj/hash_test.c +0 -484
  167. data/test/activesupport4/decoding_test.rb +0 -108
  168. data/test/activesupport4/encoding_test.rb +0 -531
  169. data/test/activesupport4/test_helper.rb +0 -41
  170. data/test/activesupport5/test_helper.rb +0 -72
  171. data/test/bar.rb +0 -35
  172. data/test/baz.rb +0 -16
  173. data/test/zoo.rb +0 -13
data/ext/oj/cache8.c CHANGED
@@ -1,107 +1,105 @@
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.
3
+
4
+ #include "cache8.h"
1
5
 
2
- #include <stdlib.h>
3
6
  #include <errno.h>
7
+ #include <stdarg.h>
4
8
  #include <stdio.h>
9
+ #include <stdlib.h>
5
10
  #include <string.h>
6
- #include <stdarg.h>
7
11
 
12
+ #include "mem.h"
8
13
  #include "ruby.h"
9
- #include "cache8.h"
10
14
 
11
- #define BITS 4
12
- #define MASK 0x000000000000000FULL
13
- #define SLOT_CNT 16
14
- #define DEPTH 16
15
+ #define BITS 4
16
+ #define MASK 0x000000000000000FULL
17
+ #define SLOT_CNT 16
18
+ #define DEPTH 16
15
19
 
16
20
  typedef union {
17
- struct _cache8 *child;
18
- slot_t value;
21
+ struct _cache8 *child;
22
+ slot_t value;
19
23
  } Bucket;
20
24
 
21
25
  struct _cache8 {
22
- Bucket buckets[SLOT_CNT];
26
+ Bucket buckets[SLOT_CNT];
23
27
  };
24
28
 
25
- static void cache8_delete(Cache8 cache, int depth);
26
- static void slot_print(Cache8 cache, sid_t key, unsigned int depth);
29
+ static void cache8_delete(Cache8 cache, int depth);
30
+ static void slot_print(Cache8 cache, sid_t key, unsigned int depth);
27
31
 
28
- void
29
- oj_cache8_new(Cache8 *cache) {
30
- Bucket *b;
31
- int i;
32
-
33
- *cache = ALLOC(struct _cache8);
32
+ void oj_cache8_new(Cache8 *cache) {
33
+ Bucket *b;
34
+ int i;
35
+
36
+ *cache = OJ_R_ALLOC(struct _cache8);
34
37
  for (i = SLOT_CNT, b = (*cache)->buckets; 0 < i; i--, b++) {
35
- b->value = 0;
38
+ b->value = 0;
36
39
  }
37
40
  }
38
41
 
39
- void
40
- oj_cache8_delete(Cache8 cache) {
42
+ void oj_cache8_delete(Cache8 cache) {
41
43
  cache8_delete(cache, 0);
42
44
  }
43
45
 
44
- static void
45
- cache8_delete(Cache8 cache, int depth) {
46
- Bucket *b;
47
- unsigned int i;
46
+ static void cache8_delete(Cache8 cache, int depth) {
47
+ Bucket *b;
48
+ unsigned int i;
48
49
 
49
50
  for (i = 0, b = cache->buckets; i < SLOT_CNT; i++, b++) {
50
- if (0 != b->child) {
51
- if (DEPTH - 1 != depth) {
52
- cache8_delete(b->child, depth + 1);
53
- }
54
- }
51
+ if (0 != b->child) {
52
+ if (DEPTH - 1 != depth) {
53
+ cache8_delete(b->child, depth + 1);
54
+ }
55
+ }
55
56
  }
56
- xfree(cache);
57
+ OJ_R_FREE(cache);
57
58
  }
58
59
 
59
- slot_t
60
- oj_cache8_get(Cache8 cache, sid_t key, slot_t **slot) {
61
- Bucket *b;
62
- int i;
63
- sid_t k8 = (sid_t)key;
64
- sid_t k;
65
-
60
+ slot_t oj_cache8_get(Cache8 cache, sid_t key, slot_t **slot) {
61
+ Bucket *b;
62
+ int i;
63
+ sid_t k8 = (sid_t)key;
64
+ sid_t k;
65
+
66
66
  for (i = 64 - BITS; 0 < i; i -= BITS) {
67
- k = (k8 >> i) & MASK;
68
- b = cache->buckets + k;
69
- if (0 == b->child) {
70
- oj_cache8_new(&b->child);
71
- }
72
- cache = b->child;
67
+ k = (k8 >> i) & MASK;
68
+ b = cache->buckets + k;
69
+ if (0 == b->child) {
70
+ oj_cache8_new(&b->child);
71
+ }
72
+ cache = b->child;
73
73
  }
74
74
  *slot = &(cache->buckets + (k8 & MASK))->value;
75
75
 
76
76
  return **slot;
77
77
  }
78
78
 
79
- void
80
- oj_cache8_print(Cache8 cache) {
79
+ void oj_cache8_print(Cache8 cache) {
81
80
  /*printf("-------------------------------------------\n"); */
82
81
  slot_print(cache, 0, 0);
83
82
  }
84
83
 
85
- static void
86
- slot_print(Cache8 c, sid_t key, unsigned int depth) {
87
- Bucket *b;
88
- unsigned int i;
89
- sid_t k8 = (sid_t)key;
90
- sid_t k;
84
+ static void slot_print(Cache8 c, sid_t key, unsigned int depth) {
85
+ Bucket *b;
86
+ unsigned int i;
87
+ sid_t k8 = (sid_t)key;
88
+ sid_t k;
91
89
 
92
90
  for (i = 0, b = c->buckets; i < SLOT_CNT; i++, b++) {
93
- if (0 != b->child) {
94
- k = (k8 << BITS) | i;
95
- /*printf("*** key: 0x%016llx depth: %u i: %u\n", k, depth, i); */
96
- if (DEPTH - 1 == depth) {
91
+ if (0 != b->child) {
92
+ k = (k8 << BITS) | i;
93
+ /*printf("*** key: 0x%016llx depth: %u i: %u\n", k, depth, i); */
94
+ if (DEPTH - 1 == depth) {
97
95
  #if IS_WINDOWS
98
- printf("0x%016lx: %4lu\n", (long unsigned int)k, (long unsigned int)b->value);
96
+ printf("0x%016lx: %4lu\n", (long unsigned int)k, (long unsigned int)b->value);
99
97
  #else
100
- printf("0x%016llx: %4llu\n", (long long unsigned int)k, (long long unsigned int)b->value);
98
+ printf("0x%016llx: %4llu\n", (long long unsigned int)k, (long long unsigned int)b->value);
101
99
  #endif
102
- } else {
103
- slot_print(b->child, k, depth + 1);
104
- }
105
- }
100
+ } else {
101
+ slot_print(b->child, k, depth + 1);
102
+ }
103
+ }
106
104
  }
107
105
  }
data/ext/oj/cache8.h CHANGED
@@ -1,4 +1,5 @@
1
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.
2
3
 
3
4
  #ifndef OJ_CACHE8_H
4
5
  #define OJ_CACHE8_H
@@ -6,15 +7,15 @@
6
7
  #include "ruby.h"
7
8
  #include "stdint.h"
8
9
 
9
- typedef struct _cache8 *Cache8;
10
- typedef uint64_t slot_t;
11
- typedef uint64_t sid_t;
10
+ typedef struct _cache8 *Cache8;
11
+ typedef uint64_t slot_t;
12
+ typedef uint64_t sid_t;
12
13
 
13
- extern void oj_cache8_new(Cache8 *cache);
14
- extern void oj_cache8_delete(Cache8 cache);
14
+ extern void oj_cache8_new(Cache8 *cache);
15
+ extern void oj_cache8_delete(Cache8 cache);
15
16
 
16
- extern slot_t oj_cache8_get(Cache8 cache, sid_t key, slot_t **slot);
17
+ extern slot_t oj_cache8_get(Cache8 cache, sid_t key, slot_t **slot);
17
18
 
18
- extern void oj_cache8_print(Cache8 cache);
19
+ extern void oj_cache8_print(Cache8 cache);
19
20
 
20
21
  #endif /* OJ_CACHE8_H */
data/ext/oj/circarray.c CHANGED
@@ -1,64 +1,64 @@
1
1
  // Copyright (c) 2012 Peter Ohler. All rights reserved.
2
+ // Licensed under the MIT License. See LICENSE file in the project root for license details.
2
3
 
3
4
  #include "circarray.h"
4
5
 
5
- CircArray
6
- oj_circ_array_new() {
7
- CircArray ca;
6
+ #include "mem.h"
8
7
 
9
- if (0 == (ca = ALLOC(struct _circArray))) {
10
- rb_raise(rb_eNoMemError, "not enough memory\n");
8
+ CircArray oj_circ_array_new(void) {
9
+ CircArray ca;
10
+
11
+ if (0 == (ca = OJ_R_ALLOC(struct _circArray))) {
12
+ rb_raise(rb_eNoMemError, "not enough memory\n");
11
13
  }
12
14
  ca->objs = ca->obj_array;
13
15
  ca->size = sizeof(ca->obj_array) / sizeof(VALUE);
14
- ca->cnt = 0;
16
+ ca->cnt = 0;
15
17
 
16
18
  return ca;
17
19
  }
18
20
 
19
- void
20
- oj_circ_array_free(CircArray ca) {
21
+ void oj_circ_array_free(CircArray ca) {
21
22
  if (ca->objs != ca->obj_array) {
22
- xfree(ca->objs);
23
+ OJ_R_FREE(ca->objs);
23
24
  }
24
- xfree(ca);
25
+ OJ_R_FREE(ca);
25
26
  }
26
27
 
27
- void
28
- oj_circ_array_set(CircArray ca, VALUE obj, unsigned long id) {
28
+ void oj_circ_array_set(CircArray ca, VALUE obj, unsigned long id) {
29
29
  if (0 < id && 0 != ca) {
30
- unsigned long i;
30
+ unsigned long i;
31
31
 
32
- if (ca->size < id) {
33
- unsigned long cnt = id + 512;
32
+ if (ca->size < id) {
33
+ unsigned long cnt = id + 512;
34
34
 
35
- if (ca->objs == ca->obj_array) {
36
- if (0 == (ca->objs = ALLOC_N(VALUE, cnt))) {
37
- rb_raise(rb_eNoMemError, "not enough memory\n");
38
- }
39
- memcpy(ca->objs, ca->obj_array, sizeof(VALUE) * ca->cnt);
40
- } else {
41
- REALLOC_N(ca->objs, VALUE, cnt);
42
- }
43
- ca->size = cnt;
44
- }
45
- id--;
46
- for (i = ca->cnt; i < id; i++) {
47
- ca->objs[i] = Qnil;
48
- }
49
- ca->objs[id] = obj;
50
- if (ca->cnt <= id) {
51
- ca->cnt = id + 1;
52
- }
35
+ if (ca->objs == ca->obj_array) {
36
+ if (0 == (ca->objs = OJ_R_ALLOC_N(VALUE, cnt))) {
37
+ rb_raise(rb_eNoMemError, "not enough memory\n");
38
+ }
39
+ memcpy(ca->objs, ca->obj_array, sizeof(VALUE) * ca->cnt);
40
+ } else {
41
+ OJ_R_REALLOC_N(ca->objs, VALUE, cnt);
42
+ }
43
+ ca->size = cnt;
44
+ }
45
+ id--;
46
+ for (i = ca->cnt; i < id; i++) {
47
+ ca->objs[i] = Qnil;
48
+ }
49
+ ca->objs[id] = obj;
50
+ if (ca->cnt <= id) {
51
+ ca->cnt = id + 1;
52
+ }
53
53
  }
54
54
  }
55
55
 
56
56
  VALUE
57
57
  oj_circ_array_get(CircArray ca, unsigned long id) {
58
- VALUE obj = Qnil;
58
+ VALUE obj = Qnil;
59
59
 
60
60
  if (id <= ca->cnt && 0 != ca) {
61
- obj = ca->objs[id - 1];
61
+ obj = ca->objs[id - 1];
62
62
  }
63
63
  return obj;
64
64
  }
data/ext/oj/circarray.h CHANGED
@@ -1,4 +1,6 @@
1
1
  // Copyright (c) 2012 Peter Ohler. All rights reserved.
2
+ // Licensed under the MIT License. See LICENSE file in the project root for
3
+ // license details.
2
4
 
3
5
  #ifndef OJ_CIRCARRAY_H
4
6
  #define OJ_CIRCARRAY_H
@@ -6,15 +8,15 @@
6
8
  #include "ruby.h"
7
9
 
8
10
  typedef struct _circArray {
9
- VALUE obj_array[1024];
10
- VALUE *objs;
11
- unsigned long size; // allocated size or initial array size
12
- unsigned long cnt;
13
- } *CircArray;
11
+ VALUE obj_array[1024];
12
+ VALUE* objs;
13
+ unsigned long size; // allocated size or initial array size
14
+ unsigned long cnt;
15
+ }* CircArray;
14
16
 
15
- extern CircArray oj_circ_array_new(void);
16
- extern void oj_circ_array_free(CircArray ca);
17
- extern void oj_circ_array_set(CircArray ca, VALUE obj, unsigned long id);
18
- extern VALUE oj_circ_array_get(CircArray ca, unsigned long id);
17
+ extern CircArray oj_circ_array_new(void);
18
+ extern void oj_circ_array_free(CircArray ca);
19
+ extern void oj_circ_array_set(CircArray ca, VALUE obj, unsigned long id);
20
+ extern VALUE oj_circ_array_get(CircArray ca, unsigned long id);
19
21
 
20
22
  #endif /* OJ_CIRCARRAY_H */