summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2011-12-17 19:45:07 -0800
committerAaron Patterson <aaron.patterson@gmail.com>2011-12-17 19:45:07 -0800
commit33ce8650bac29190dde937b1b7d3e21fd06926e7 (patch)
treecd76ef712ba565c1189ece2b4e098e823e6497aa /lib
parent1caecdca27675e80f9a762875fcf7ced81b2d9f1 (diff)
downloadpsych-33ce8650bac29190dde937b1b7d3e21fd06926e7.zip
* ext/psych/lib/psych/visitors/to_ruby.rb: BigDecimals can be restored
from YAML. * ext/psych/lib/psych/visitors/yaml_tree.rb: BigDecimals can be dumped to YAML. * test/psych/test_numeric.rb: tests for BigDecimal serialization Fixes #31
Diffstat (limited to 'lib')
-rw-r--r--lib/psych/visitors/to_ruby.rb3
-rw-r--r--lib/psych/visitors/yaml_tree.rb4
2 files changed, 7 insertions, 0 deletions
diff --git a/lib/psych/visitors/to_ruby.rb b/lib/psych/visitors/to_ruby.rb
index 4267f4d..bf48f9d 100644
--- a/lib/psych/visitors/to_ruby.rb
+++ b/lib/psych/visitors/to_ruby.rb
@@ -52,6 +52,9 @@ module Psych
o.value.unpack('m').first
when '!str', 'tag:yaml.org,2002:str'
o.value
+ when '!ruby/object:BigDecimal'
+ require 'bigdecimal'
+ BigDecimal._load o.value
when "!ruby/object:DateTime"
require 'date'
@ss.parse_time(o.value).to_datetime
diff --git a/lib/psych/visitors/yaml_tree.rb b/lib/psych/visitors/yaml_tree.rb
index 523ad77..f373966 100644
--- a/lib/psych/visitors/yaml_tree.rb
+++ b/lib/psych/visitors/yaml_tree.rb
@@ -214,6 +214,10 @@ module Psych
end
end
+ def visit_BigDecimal o
+ @emitter.scalar o._dump, nil, '!ruby/object:BigDecimal', false, false, Nodes::Scalar::ANY
+ end
+
def binary? string
string.encoding == Encoding::ASCII_8BIT ||
string.index("\x00") ||