summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ext/psych/lib/psych/visitors/to_ruby.rb3
-rw-r--r--ext/psych/psych_to_ruby.c9
2 files changed, 5 insertions, 7 deletions
diff --git a/ext/psych/lib/psych/visitors/to_ruby.rb b/ext/psych/lib/psych/visitors/to_ruby.rb
index 580a74e9fb..2814ce1a69 100644
--- a/ext/psych/lib/psych/visitors/to_ruby.rb
+++ b/ext/psych/lib/psych/visitors/to_ruby.rb
@@ -219,7 +219,8 @@ module Psych
revive_data_members(members, o)
end
data ||= allocate_anon_data(o, members)
- init_struct(data, **members)
+ values = data.members.map { |m| members[m] }
+ init_data(data, values)
data.freeze
data
diff --git a/ext/psych/psych_to_ruby.c b/ext/psych/psych_to_ruby.c
index d473a5f840..53a038270c 100644
--- a/ext/psych/psych_to_ruby.c
+++ b/ext/psych/psych_to_ruby.c
@@ -24,12 +24,9 @@ static VALUE path2class(VALUE self, VALUE path)
return rb_path_to_class(path);
}
-static VALUE init_struct(VALUE self, VALUE data, VALUE attrs)
+static VALUE init_data(VALUE self, VALUE data, VALUE values)
{
- VALUE args = rb_ary_new2(1);
- rb_ary_push(args, attrs);
- rb_struct_initialize(data, args);
-
+ rb_struct_initialize(data, values);
return data;
}
@@ -42,7 +39,7 @@ void Init_psych_to_ruby(void)
VALUE visitor = rb_define_class_under(visitors, "Visitor", rb_cObject);
cPsychVisitorsToRuby = rb_define_class_under(visitors, "ToRuby", visitor);
- rb_define_private_method(cPsychVisitorsToRuby, "init_struct", init_struct, 2);
+ rb_define_private_method(cPsychVisitorsToRuby, "init_data", init_data, 2);
rb_define_private_method(cPsychVisitorsToRuby, "build_exception", build_exception, 2);
rb_define_private_method(class_loader, "path2class", path2class, 1);
}