diff options
author | Bradley Harris <bharris@sermo.com> | 2011-04-29 14:47:49 -0400 |
---|---|---|
committer | Bradley Harris <bharris@sermo.com> | 2011-04-29 14:47:49 -0400 |
commit | aba149d702e4dcd999ce1b71688ec15b0c637875 (patch) | |
tree | e54a345b51d7469c747e4315874477565f77ee0f /activesupport/lib/active_support/core_ext/hash | |
parent | 245017765644745b0e550ceaf815ea4e73a12681 (diff) | |
download | rails-aba149d702e4dcd999ce1b71688ec15b0c637875.tar.gz rails-aba149d702e4dcd999ce1b71688ec15b0c637875.tar.bz2 rails-aba149d702e4dcd999ce1b71688ec15b0c637875.zip |
Fix bug with empty CDATA not being handled in Hash.from_xml
Diffstat (limited to 'activesupport/lib/active_support/core_ext/hash')
-rw-r--r-- | activesupport/lib/active_support/core_ext/hash/conversions.rb | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/activesupport/lib/active_support/core_ext/hash/conversions.rb b/activesupport/lib/active_support/core_ext/hash/conversions.rb index 61a1d88b0e..102378a029 100644 --- a/activesupport/lib/active_support/core_ext/hash/conversions.rb +++ b/activesupport/lib/active_support/core_ext/hash/conversions.rb @@ -108,7 +108,8 @@ class Hash raise "can't typecast #{entries.inspect}" end end - elsif value['type'] == 'file' || value["__content__"].present? + elsif value['type'] == 'file' || + (value["__content__"] && (value.keys.size == 1 || value["__content__"].present?)) content = value["__content__"] if parser = ActiveSupport::XmlMini::PARSING[value["type"]] parser.arity == 1 ? parser.call(content) : parser.call(content, value) |