diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2009-12-01 19:27:31 -0800 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2009-12-01 19:27:31 -0800 |
commit | 8eb94e153ce730c88aebb95595a7f9f7b7f5e0f8 (patch) | |
tree | 4557f08682902d5d8b44175b1558eacfce51f5cb /lib | |
parent | 3a022eda91d60c27c3d943fb759b7cc10fe00e62 (diff) | |
download | psych-8eb94e153ce730c88aebb95595a7f9f7b7f5e0f8.zip |
dumping ordered maps
Diffstat (limited to 'lib')
-rw-r--r-- | lib/psych/visitors/yaml_tree.rb | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/lib/psych/visitors/yaml_tree.rb b/lib/psych/visitors/yaml_tree.rb index 57d23e2..ba0307b 100644 --- a/lib/psych/visitors/yaml_tree.rb +++ b/lib/psych/visitors/yaml_tree.rb @@ -15,13 +15,19 @@ module Psych target.class.ancestors.each do |klass| next unless klass.name method_name = :"visit_#{klass.name.split('::').join('_')}" - if respond_to?(method_name) - return send(method_name, target) - end + return send(method_name, target) if respond_to?(method_name) end raise TypeError, "Can't dump #{target.class}" end + def visit_Psych_Omap o + @stack.push append Nodes::Sequence.new(nil, '!omap', false) + o.each do |k,v| + accept k => v + end + @stack.pop + end + def visit_Object o klass = o.class == Object ? nil : o.class.name tag = ['!ruby/object', klass].compact.join(':') |