oj 3.16.6 → 3.16.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -0
- data/ext/oj/mimic_json.c +5 -1
- data/ext/oj/rails.c +2 -0
- data/ext/oj/string_writer.c +4 -4
- data/lib/oj/version.rb +1 -1
- data/test/test_compat.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 71fccfc65816b5412064b2295b66c038029cbea37dcae9475002753850d47740
|
4
|
+
data.tar.gz: f559a6cbe6ebce9443564d679ade4e527da6784d35c7a71bf7a85c4e2c0b2f75
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5cc33a15e43c946351d281b65f1f692a9ad8b4055c3848f8f540f9b7f1043a1f4f8844b67ff17ffe072193d4a1922a596f4b941ee3a93c2f4eb4b52fedf191ec
|
7
|
+
data.tar.gz: 1314ce1b2d92fe30dd971832a294ee2052ac1434a3f026fa534573c55488a60de3f2ff0f81bb1577c0dc8941c84c75e5a18ac8d79d2f86c9b52c56fc225a4eca
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,11 @@
|
|
1
1
|
# CHANGELOG
|
2
2
|
|
3
|
+
## 3.16.7 - 2024-11-01
|
4
|
+
|
5
|
+
- Changed string_writer_as_json to allow multiple arguments.
|
6
|
+
|
7
|
+
- Fixed Global variable registration added to mimic_json and rails code thanks to @byroot.
|
8
|
+
|
3
9
|
## 3.16.6 - 2024-09-09
|
4
10
|
|
5
11
|
- Fixed issue with Rails 7.2 that changed the order of calls to to_json and as_json.
|
data/ext/oj/mimic_json.c
CHANGED
@@ -837,11 +837,15 @@ void oj_mimic_json_methods(VALUE json) {
|
|
837
837
|
} else {
|
838
838
|
json_error = rb_define_class_under(json, "JSONError", rb_eStandardError);
|
839
839
|
}
|
840
|
+
|
841
|
+
rb_global_variable(&oj_json_parser_error_class);
|
840
842
|
if (rb_const_defined_at(json, rb_intern("ParserError"))) {
|
841
843
|
oj_json_parser_error_class = rb_const_get(json, rb_intern("ParserError"));
|
842
844
|
} else {
|
843
845
|
oj_json_parser_error_class = rb_define_class_under(json, "ParserError", json_error);
|
844
846
|
}
|
847
|
+
|
848
|
+
rb_global_variable(&oj_json_generator_error_class);
|
845
849
|
if (rb_const_defined_at(json, rb_intern("GeneratorError"))) {
|
846
850
|
oj_json_generator_error_class = rb_const_get(json, rb_intern("GeneratorError"));
|
847
851
|
} else {
|
@@ -867,8 +871,8 @@ void oj_mimic_json_methods(VALUE json) {
|
|
867
871
|
rb_require("oj/state");
|
868
872
|
}
|
869
873
|
// Pull in the JSON::State mimic file.
|
874
|
+
rb_global_variable(&state_class);
|
870
875
|
state_class = rb_const_get_at(generator, rb_intern("State"));
|
871
|
-
rb_gc_register_mark_object(state_class);
|
872
876
|
}
|
873
877
|
|
874
878
|
/* Document-module: JSON
|
data/ext/oj/rails.c
CHANGED
@@ -1101,6 +1101,8 @@ static VALUE rails_set_decoder(VALUE self) {
|
|
1101
1101
|
} else {
|
1102
1102
|
json_error = rb_define_class_under(json, "JSONError", rb_eStandardError);
|
1103
1103
|
}
|
1104
|
+
|
1105
|
+
rb_global_variable(&oj_json_parser_error_class);
|
1104
1106
|
if (rb_const_defined_at(json, rb_intern("ParserError"))) {
|
1105
1107
|
oj_json_parser_error_class = rb_const_get(json, rb_intern("ParserError"));
|
1106
1108
|
} else {
|
data/ext/oj/string_writer.c
CHANGED
@@ -475,16 +475,16 @@ static VALUE str_writer_to_s(VALUE self) {
|
|
475
475
|
}
|
476
476
|
|
477
477
|
/* Document-method: as_json
|
478
|
-
* call-seq: as_json()
|
478
|
+
* call-seq: as_json(*)
|
479
479
|
*
|
480
480
|
* Returns the contents of the writer as a JSON element. If called from inside
|
481
481
|
* an array or hash by Oj the raw buffer will be used othersize a more
|
482
482
|
* inefficient parse of the contents and a return of the result is
|
483
|
-
* completed. The parse uses the strict mode.
|
483
|
+
* completed. The parse uses the strict mode. Optional arguments are ignored.
|
484
484
|
*
|
485
485
|
* *return* [_Hash_|_Array_|_String_|_Integer_|_Float_|_True_|_False_|_nil|)
|
486
486
|
*/
|
487
|
-
static VALUE str_writer_as_json(VALUE self) {
|
487
|
+
static VALUE str_writer_as_json(int argc, VALUE *argv, VALUE self) {
|
488
488
|
if (string_writer_optimized) {
|
489
489
|
return self;
|
490
490
|
}
|
@@ -515,5 +515,5 @@ void oj_string_writer_init(void) {
|
|
515
515
|
rb_define_method(oj_string_writer_class, "reset", str_writer_reset, 0);
|
516
516
|
rb_define_method(oj_string_writer_class, "to_s", str_writer_to_s, 0);
|
517
517
|
rb_define_method(oj_string_writer_class, "raw_json", str_writer_to_s, 0);
|
518
|
-
rb_define_method(oj_string_writer_class, "as_json", str_writer_as_json,
|
518
|
+
rb_define_method(oj_string_writer_class, "as_json", str_writer_as_json, -1);
|
519
519
|
}
|
data/lib/oj/version.rb
CHANGED
data/test/test_compat.rb
CHANGED
@@ -468,7 +468,7 @@ class CompatJuice < Minitest::Test
|
|
468
468
|
|
469
469
|
def test_arg_passing
|
470
470
|
json = Oj.to_json(Argy.new(), :max_nesting => 40)
|
471
|
-
|
471
|
+
assert_match(/.*max_nesting.*40.*/, json)
|
472
472
|
end
|
473
473
|
|
474
474
|
def test_max_nesting
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: oj
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.16.
|
4
|
+
version: 3.16.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Peter Ohler
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-11-01 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bigdecimal
|