diff options
author | Aaron Patterson <tenderlove@ruby-lang.org> | 2021-02-24 09:01:32 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-24 09:01:32 -0800 |
commit | 8c3afaa0a3db2f3afc187e91886adf278e8e0190 (patch) | |
tree | 38c77ed6644c227b1ac00ffdfac5c527b2dfdd0c /lib | |
parent | a88ff77f02bafafabfc6df9d159141bca2ae0217 (diff) | |
parent | ee26f26ab5e39eec402ea01109b9ba736d06b5b6 (diff) | |
download | psych-8c3afaa0a3db2f3afc187e91886adf278e8e0190.zip |
Merge pull request #476 from Shopify/symbolize-name-ruby-object
Fix custom marshalization with symbolize_names: true
Diffstat (limited to 'lib')
-rw-r--r-- | lib/psych/visitors/to_ruby.rb | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/lib/psych/visitors/to_ruby.rb b/lib/psych/visitors/to_ruby.rb index a100188..4d98850 100644 --- a/lib/psych/visitors/to_ruby.rb +++ b/lib/psych/visitors/to_ruby.rb @@ -339,7 +339,7 @@ module Psych list end - def revive_hash hash, o + def revive_hash hash, o, tagged= false o.children.each_slice(2) { |k,v| key = accept(k) val = accept(v) @@ -366,7 +366,7 @@ module Psych hash[key] = val end else - if @symbolize_names + if !tagged && @symbolize_names key = key.to_sym elsif !@freeze key = deduplicate(key) @@ -404,7 +404,7 @@ module Psych def revive klass, node s = register(node, klass.allocate) - init_with(s, revive_hash({}, node), node) + init_with(s, revive_hash({}, node, true), node) end def init_with o, h, node |