aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/lib
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2007-10-23 00:42:16 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2007-10-23 00:42:16 +0000
commit24077a1ffc3d7e944ba0e78df9a387523fb4f419 (patch)
tree8043874317d33516318635cdffde32193848eb70 /activesupport/lib
parent902533e6f00114717e13758339299d9acd328b10 (diff)
downloadrails-24077a1ffc3d7e944ba0e78df9a387523fb4f419.tar.gz
rails-24077a1ffc3d7e944ba0e78df9a387523fb4f419.tar.bz2
rails-24077a1ffc3d7e944ba0e78df9a387523fb4f419.zip
Hash#to_xml handles symbol values. Closes #9954.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7997 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activesupport/lib')
-rw-r--r--activesupport/lib/active_support/core_ext/hash/conversions.rb5
1 files changed, 5 insertions, 0 deletions
diff --git a/activesupport/lib/active_support/core_ext/hash/conversions.rb b/activesupport/lib/active_support/core_ext/hash/conversions.rb
index 74fe577030..bbe35c25e4 100644
--- a/activesupport/lib/active_support/core_ext/hash/conversions.rb
+++ b/activesupport/lib/active_support/core_ext/hash/conversions.rb
@@ -47,6 +47,7 @@ module ActiveSupport #:nodoc:
module Hash #:nodoc:
module Conversions
XML_TYPE_NAMES = {
+ "Symbol" => "symbol",
"Fixnum" => "integer",
"Bignum" => "integer",
"BigDecimal" => "decimal",
@@ -59,14 +60,18 @@ module ActiveSupport #:nodoc:
} unless defined?(XML_TYPE_NAMES)
XML_FORMATTING = {
+ "symbol" => Proc.new { |symbol| symbol.to_s },
"date" => Proc.new { |date| date.to_s(:db) },
"datetime" => Proc.new { |time| time.xmlschema },
"binary" => Proc.new { |binary| Base64.encode64(binary) },
"yaml" => Proc.new { |yaml| yaml.to_yaml }
} unless defined?(XML_FORMATTING)
+ # TODO: use Time.xmlschema instead of Time.parse;
+ # use regexp instead of Date.parse
unless defined?(XML_PARSING)
XML_PARSING = {
+ "symbol" => Proc.new { |symbol| symbol.to_sym },
"date" => Proc.new { |date| ::Date.parse(date) },
"datetime" => Proc.new { |time| ::Time.parse(time).utc },
"integer" => Proc.new { |integer| integer.to_i },