oj 3.7.4 → 3.13.21

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 (142) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +1352 -0
  3. data/README.md +29 -8
  4. data/RELEASE_NOTES.md +61 -0
  5. data/ext/oj/buf.h +53 -72
  6. data/ext/oj/cache.c +326 -0
  7. data/ext/oj/cache.h +21 -0
  8. data/ext/oj/cache8.c +61 -64
  9. data/ext/oj/cache8.h +12 -39
  10. data/ext/oj/circarray.c +37 -43
  11. data/ext/oj/circarray.h +16 -17
  12. data/ext/oj/code.c +165 -179
  13. data/ext/oj/code.h +27 -29
  14. data/ext/oj/compat.c +174 -194
  15. data/ext/oj/custom.c +809 -866
  16. data/ext/oj/debug.c +132 -0
  17. data/ext/oj/dump.c +848 -863
  18. data/ext/oj/dump.h +81 -67
  19. data/ext/oj/dump_compat.c +85 -123
  20. data/ext/oj/dump_leaf.c +100 -188
  21. data/ext/oj/dump_object.c +527 -656
  22. data/ext/oj/dump_strict.c +315 -338
  23. data/ext/oj/encode.h +7 -34
  24. data/ext/oj/encoder.c +43 -0
  25. data/ext/oj/err.c +40 -29
  26. data/ext/oj/err.h +48 -48
  27. data/ext/oj/extconf.rb +17 -4
  28. data/ext/oj/fast.c +1070 -1087
  29. data/ext/oj/intern.c +301 -0
  30. data/ext/oj/intern.h +26 -0
  31. data/ext/oj/mimic_json.c +469 -436
  32. data/ext/oj/object.c +525 -593
  33. data/ext/oj/odd.c +154 -138
  34. data/ext/oj/odd.h +37 -38
  35. data/ext/oj/oj.c +1325 -986
  36. data/ext/oj/oj.h +333 -316
  37. data/ext/oj/parse.c +1002 -846
  38. data/ext/oj/parse.h +92 -87
  39. data/ext/oj/parser.c +1557 -0
  40. data/ext/oj/parser.h +91 -0
  41. data/ext/oj/rails.c +888 -878
  42. data/ext/oj/rails.h +11 -14
  43. data/ext/oj/reader.c +141 -147
  44. data/ext/oj/reader.h +73 -89
  45. data/ext/oj/resolve.c +41 -62
  46. data/ext/oj/resolve.h +7 -9
  47. data/ext/oj/rxclass.c +71 -75
  48. data/ext/oj/rxclass.h +18 -19
  49. data/ext/oj/saj.c +443 -486
  50. data/ext/oj/saj2.c +602 -0
  51. data/ext/oj/scp.c +88 -113
  52. data/ext/oj/sparse.c +787 -709
  53. data/ext/oj/stream_writer.c +133 -159
  54. data/ext/oj/strict.c +127 -118
  55. data/ext/oj/string_writer.c +230 -249
  56. data/ext/oj/trace.c +34 -41
  57. data/ext/oj/trace.h +19 -19
  58. data/ext/oj/usual.c +1254 -0
  59. data/ext/oj/util.c +136 -0
  60. data/ext/oj/util.h +20 -0
  61. data/ext/oj/val_stack.c +59 -67
  62. data/ext/oj/val_stack.h +91 -129
  63. data/ext/oj/validate.c +46 -0
  64. data/ext/oj/wab.c +342 -353
  65. data/lib/oj/bag.rb +1 -0
  66. data/lib/oj/easy_hash.rb +5 -4
  67. data/lib/oj/error.rb +1 -1
  68. data/lib/oj/json.rb +1 -1
  69. data/lib/oj/mimic.rb +48 -14
  70. data/lib/oj/saj.rb +20 -6
  71. data/lib/oj/state.rb +8 -7
  72. data/lib/oj/version.rb +2 -2
  73. data/lib/oj.rb +0 -8
  74. data/pages/Compatibility.md +1 -1
  75. data/pages/JsonGem.md +15 -0
  76. data/pages/Modes.md +53 -46
  77. data/pages/Options.md +72 -11
  78. data/pages/Parser.md +309 -0
  79. data/pages/Rails.md +73 -22
  80. data/pages/Security.md +1 -1
  81. data/test/activerecord/result_test.rb +7 -2
  82. data/test/activesupport5/abstract_unit.rb +45 -0
  83. data/test/activesupport5/decoding_test.rb +68 -60
  84. data/test/activesupport5/encoding_test.rb +111 -96
  85. data/test/activesupport5/encoding_test_cases.rb +33 -25
  86. data/test/activesupport5/test_helper.rb +43 -21
  87. data/test/activesupport5/time_zone_test_helpers.rb +18 -3
  88. data/test/activesupport6/abstract_unit.rb +44 -0
  89. data/test/activesupport6/decoding_test.rb +133 -0
  90. data/test/activesupport6/encoding_test.rb +507 -0
  91. data/test/activesupport6/encoding_test_cases.rb +98 -0
  92. data/test/activesupport6/test_common.rb +17 -0
  93. data/test/activesupport6/test_helper.rb +163 -0
  94. data/test/activesupport6/time_zone_test_helpers.rb +39 -0
  95. data/test/activesupport7/abstract_unit.rb +49 -0
  96. data/test/activesupport7/decoding_test.rb +125 -0
  97. data/test/activesupport7/encoding_test.rb +486 -0
  98. data/test/activesupport7/encoding_test_cases.rb +104 -0
  99. data/test/activesupport7/time_zone_test_helpers.rb +47 -0
  100. data/test/bar.rb +6 -12
  101. data/test/baz.rb +16 -0
  102. data/test/bug.rb +16 -0
  103. data/test/foo.rb +69 -75
  104. data/test/helper.rb +16 -0
  105. data/test/json_gem/json_common_interface_test.rb +8 -3
  106. data/test/json_gem/json_generator_test.rb +18 -4
  107. data/test/json_gem/json_parser_test.rb +9 -0
  108. data/test/json_gem/test_helper.rb +12 -0
  109. data/test/mem.rb +33 -0
  110. data/test/perf.rb +1 -1
  111. data/test/perf_dump.rb +50 -0
  112. data/test/perf_once.rb +58 -0
  113. data/test/perf_parser.rb +189 -0
  114. data/test/perf_scp.rb +11 -10
  115. data/test/perf_strict.rb +17 -23
  116. data/test/prec.rb +23 -0
  117. data/test/sample_json.rb +1 -1
  118. data/test/test_compat.rb +46 -10
  119. data/test/test_custom.rb +147 -8
  120. data/test/test_fast.rb +62 -2
  121. data/test/test_file.rb +25 -2
  122. data/test/test_gc.rb +13 -0
  123. data/test/test_generate.rb +21 -0
  124. data/test/test_hash.rb +11 -1
  125. data/test/test_integer_range.rb +7 -2
  126. data/test/test_object.rb +85 -9
  127. data/test/test_parser.rb +27 -0
  128. data/test/test_parser_saj.rb +335 -0
  129. data/test/test_parser_usual.rb +217 -0
  130. data/test/test_rails.rb +35 -0
  131. data/test/test_saj.rb +1 -1
  132. data/test/test_scp.rb +5 -5
  133. data/test/test_strict.rb +26 -1
  134. data/test/test_various.rb +87 -65
  135. data/test/test_wab.rb +2 -0
  136. data/test/test_writer.rb +19 -2
  137. data/test/tests.rb +1 -1
  138. data/test/zoo.rb +13 -0
  139. metadata +60 -110
  140. data/ext/oj/hash.c +0 -163
  141. data/ext/oj/hash.h +0 -46
  142. data/ext/oj/hash_test.c +0 -512
data/ext/oj/cache8.c CHANGED
@@ -1,107 +1,104 @@
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
 
8
12
  #include "ruby.h"
9
- #include "cache8.h"
10
13
 
11
- #define BITS 4
12
- #define MASK 0x000000000000000FULL
13
- #define SLOT_CNT 16
14
- #define DEPTH 16
14
+ #define BITS 4
15
+ #define MASK 0x000000000000000FULL
16
+ #define SLOT_CNT 16
17
+ #define DEPTH 16
15
18
 
16
19
  typedef union {
17
- struct _Cache8 *child;
18
- slot_t value;
20
+ struct _cache8 *child;
21
+ slot_t value;
19
22
  } Bucket;
20
23
 
21
- struct _Cache8 {
22
- Bucket buckets[SLOT_CNT];
24
+ struct _cache8 {
25
+ Bucket buckets[SLOT_CNT];
23
26
  };
24
27
 
25
- static void cache8_delete(Cache8 cache, int depth);
26
- static void slot_print(Cache8 cache, sid_t key, unsigned int depth);
28
+ static void cache8_delete(Cache8 cache, int depth);
29
+ static void slot_print(Cache8 cache, sid_t key, unsigned int depth);
30
+
31
+ void oj_cache8_new(Cache8 *cache) {
32
+ Bucket *b;
33
+ int i;
27
34
 
28
- void
29
- oj_cache8_new(Cache8 *cache) {
30
- Bucket *b;
31
- int i;
32
-
33
- *cache = ALLOC(struct _Cache8);
35
+ *cache = ALLOC(struct _cache8);
34
36
  for (i = SLOT_CNT, b = (*cache)->buckets; 0 < i; i--, b++) {
35
- b->value = 0;
37
+ b->value = 0;
36
38
  }
37
39
  }
38
40
 
39
- void
40
- oj_cache8_delete(Cache8 cache) {
41
- cache8_delete(cache, 0);
42
- }
41
+ void oj_cache8_delete(Cache8 cache) { cache8_delete(cache, 0); }
43
42
 
44
- static void
45
- cache8_delete(Cache8 cache, int depth) {
46
- Bucket *b;
47
- unsigned int i;
43
+ static void cache8_delete(Cache8 cache, int depth) {
44
+ Bucket * b;
45
+ unsigned int i;
48
46
 
49
47
  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
- }
48
+ if (0 != b->child) {
49
+ if (DEPTH - 1 != depth) {
50
+ cache8_delete(b->child, depth + 1);
51
+ }
52
+ }
55
53
  }
56
54
  xfree(cache);
57
55
  }
58
56
 
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
-
57
+ slot_t oj_cache8_get(Cache8 cache, sid_t key, slot_t **slot) {
58
+ Bucket *b;
59
+ int i;
60
+ sid_t k8 = (sid_t)key;
61
+ sid_t k;
62
+
66
63
  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;
64
+ k = (k8 >> i) & MASK;
65
+ b = cache->buckets + k;
66
+ if (0 == b->child) {
67
+ oj_cache8_new(&b->child);
68
+ }
69
+ cache = b->child;
73
70
  }
74
71
  *slot = &(cache->buckets + (k8 & MASK))->value;
75
72
 
76
73
  return **slot;
77
74
  }
78
75
 
79
- void
80
- oj_cache8_print(Cache8 cache) {
76
+ void oj_cache8_print(Cache8 cache) {
81
77
  /*printf("-------------------------------------------\n"); */
82
78
  slot_print(cache, 0, 0);
83
79
  }
84
80
 
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;
81
+ static void slot_print(Cache8 c, sid_t key, unsigned int depth) {
82
+ Bucket * b;
83
+ unsigned int i;
84
+ sid_t k8 = (sid_t)key;
85
+ sid_t k;
91
86
 
92
87
  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) {
88
+ if (0 != b->child) {
89
+ k = (k8 << BITS) | i;
90
+ /*printf("*** key: 0x%016llx depth: %u i: %u\n", k, depth, i); */
91
+ if (DEPTH - 1 == depth) {
97
92
  #if IS_WINDOWS
98
- printf("0x%016lx: %4lu\n", (long unsigned int)k, (long unsigned int)b->value);
93
+ printf("0x%016lx: %4lu\n", (long unsigned int)k,
94
+ (long unsigned int)b->value);
99
95
  #else
100
- printf("0x%016llx: %4llu\n", (long long unsigned int)k, (long long unsigned int)b->value);
96
+ printf("0x%016llx: %4llu\n", (long long unsigned int)k,
97
+ (long long unsigned int)b->value);
101
98
  #endif
102
- } else {
103
- slot_print(b->child, k, depth + 1);
104
- }
105
- }
99
+ } else {
100
+ slot_print(b->child, k, depth + 1);
101
+ }
102
+ }
106
103
  }
107
104
  }
data/ext/oj/cache8.h CHANGED
@@ -1,48 +1,21 @@
1
- /* cache8.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
- #ifndef __OJ_CACHE8_H__
32
- #define __OJ_CACHE8_H__
4
+ #ifndef OJ_CACHE8_H
5
+ #define OJ_CACHE8_H
33
6
 
34
7
  #include "ruby.h"
35
8
  #include "stdint.h"
36
9
 
37
- typedef struct _Cache8 *Cache8;
38
- typedef uint64_t slot_t;
39
- typedef uint64_t sid_t;
10
+ typedef struct _cache8 *Cache8;
11
+ typedef uint64_t slot_t;
12
+ typedef uint64_t sid_t;
40
13
 
41
- extern void oj_cache8_new(Cache8 *cache);
42
- extern void oj_cache8_delete(Cache8 cache);
14
+ extern void oj_cache8_new(Cache8 *cache);
15
+ extern void oj_cache8_delete(Cache8 cache);
43
16
 
44
- 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);
45
18
 
46
- extern void oj_cache8_print(Cache8 cache);
19
+ extern void oj_cache8_print(Cache8 cache);
47
20
 
48
- #endif /* __OJ_CACHE8_H__ */
21
+ #endif /* OJ_CACHE8_H */
data/ext/oj/circarray.c CHANGED
@@ -1,68 +1,62 @@
1
- /* circarray.c
2
- * Copyright (c) 2012, Peter Ohler
3
- * All rights reserved.
4
- */
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.
5
3
 
6
4
  #include "circarray.h"
7
5
 
8
- CircArray
9
- oj_circ_array_new() {
10
- CircArray ca;
11
-
12
- if (0 == (ca = ALLOC(struct _CircArray))) {
13
- rb_raise(rb_eNoMemError, "not enough memory\n");
6
+ CircArray oj_circ_array_new(void) {
7
+ CircArray ca;
8
+
9
+ if (0 == (ca = ALLOC(struct _circArray))) {
10
+ rb_raise(rb_eNoMemError, "not enough memory\n");
14
11
  }
15
12
  ca->objs = ca->obj_array;
16
13
  ca->size = sizeof(ca->obj_array) / sizeof(VALUE);
17
- ca->cnt = 0;
18
-
14
+ ca->cnt = 0;
15
+
19
16
  return ca;
20
17
  }
21
18
 
22
- void
23
- oj_circ_array_free(CircArray ca) {
19
+ void oj_circ_array_free(CircArray ca) {
24
20
  if (ca->objs != ca->obj_array) {
25
- xfree(ca->objs);
21
+ xfree(ca->objs);
26
22
  }
27
23
  xfree(ca);
28
24
  }
29
25
 
30
- void
31
- oj_circ_array_set(CircArray ca, VALUE obj, unsigned long id) {
26
+ void oj_circ_array_set(CircArray ca, VALUE obj, unsigned long id) {
32
27
  if (0 < id && 0 != ca) {
33
- unsigned long i;
34
-
35
- if (ca->size < id) {
36
- unsigned long cnt = id + 512;
37
-
38
- if (ca->objs == ca->obj_array) {
39
- if (0 == (ca->objs = ALLOC_N(VALUE, cnt))) {
40
- rb_raise(rb_eNoMemError, "not enough memory\n");
41
- }
42
- memcpy(ca->objs, ca->obj_array, sizeof(VALUE) * ca->cnt);
43
- } else {
44
- REALLOC_N(ca->objs, VALUE, cnt);
45
- }
46
- ca->size = cnt;
47
- }
48
- id--;
49
- for (i = ca->cnt; i < id; i++) {
50
- ca->objs[i] = Qnil;
51
- }
52
- ca->objs[id] = obj;
53
- if (ca->cnt <= id) {
54
- ca->cnt = id + 1;
55
- }
28
+ unsigned long i;
29
+
30
+ if (ca->size < id) {
31
+ unsigned long cnt = id + 512;
32
+
33
+ if (ca->objs == ca->obj_array) {
34
+ if (0 == (ca->objs = ALLOC_N(VALUE, cnt))) {
35
+ rb_raise(rb_eNoMemError, "not enough memory\n");
36
+ }
37
+ memcpy(ca->objs, ca->obj_array, sizeof(VALUE) * ca->cnt);
38
+ } else {
39
+ REALLOC_N(ca->objs, VALUE, cnt);
40
+ }
41
+ ca->size = cnt;
42
+ }
43
+ id--;
44
+ for (i = ca->cnt; i < id; i++) {
45
+ ca->objs[i] = Qnil;
46
+ }
47
+ ca->objs[id] = obj;
48
+ if (ca->cnt <= id) {
49
+ ca->cnt = id + 1;
50
+ }
56
51
  }
57
52
  }
58
53
 
59
54
  VALUE
60
55
  oj_circ_array_get(CircArray ca, unsigned long id) {
61
- VALUE obj = Qnil;
56
+ VALUE obj = Qnil;
62
57
 
63
58
  if (id <= ca->cnt && 0 != ca) {
64
- obj = ca->objs[id - 1];
59
+ obj = ca->objs[id - 1];
65
60
  }
66
61
  return obj;
67
62
  }
68
-
data/ext/oj/circarray.h CHANGED
@@ -1,23 +1,22 @@
1
- /* circarray.h
2
- * Copyright (c) 2012, Peter Ohler
3
- * All rights reserved.
4
- */
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.
5
4
 
6
- #ifndef __OJ_CIRCARRAY_H__
7
- #define __OJ_CIRCARRAY_H__
5
+ #ifndef OJ_CIRCARRAY_H
6
+ #define OJ_CIRCARRAY_H
8
7
 
9
8
  #include "ruby.h"
10
9
 
11
- typedef struct _CircArray {
12
- VALUE obj_array[1024];
13
- VALUE *objs;
14
- unsigned long size; // allocated size or initial array size
15
- unsigned long cnt;
16
- } *CircArray;
10
+ typedef struct _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;
17
16
 
18
- extern CircArray oj_circ_array_new(void);
19
- extern void oj_circ_array_free(CircArray ca);
20
- extern void oj_circ_array_set(CircArray ca, VALUE obj, unsigned long id);
21
- 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);
22
21
 
23
- #endif /* __OJ_CIRCARRAY_H__ */
22
+ #endif /* OJ_CIRCARRAY_H */