mirror of
https://github.com/github/rails.git
synced 2026-04-26 03:00:59 -04:00
Fixing XMLMini_JDOM
This commit is contained in:
@@ -41,7 +41,7 @@ module ActiveSupport
|
||||
xml_string_reader = StringReader.new(data)
|
||||
xml_input_source = InputSource.new(xml_string_reader)
|
||||
doc = @dbf.new_document_builder.parse(xml_input_source)
|
||||
merge_element!({}, doc.document_element)
|
||||
merge_element!({CONTENT_KEY => ''}, doc.document_element)
|
||||
end
|
||||
end
|
||||
|
||||
@@ -54,9 +54,14 @@ module ActiveSupport
|
||||
# element::
|
||||
# XML element to merge into hash
|
||||
def merge_element!(hash, element)
|
||||
delete_empty(hash)
|
||||
merge!(hash, element.tag_name, collapse(element))
|
||||
end
|
||||
|
||||
def delete_empty(hash)
|
||||
hash.delete(CONTENT_KEY) if hash[CONTENT_KEY] == ''
|
||||
end
|
||||
|
||||
# Actually converts an XML document element into a data structure.
|
||||
#
|
||||
# element::
|
||||
@@ -84,6 +89,7 @@ module ActiveSupport
|
||||
# element::
|
||||
# XML element whose texts are to me merged into the hash
|
||||
def merge_texts!(hash, element)
|
||||
delete_empty(hash)
|
||||
text_children = texts(element)
|
||||
if text_children.join.empty?
|
||||
hash
|
||||
@@ -128,8 +134,9 @@ module ActiveSupport
|
||||
attribute_hash = {}
|
||||
attributes = element.attributes
|
||||
for i in 0...attributes.length
|
||||
attribute_hash[attributes.item(i).name] = attributes.item(i).value
|
||||
end
|
||||
attribute_hash[CONTENT_KEY] ||= ''
|
||||
attribute_hash[attributes.item(i).name] = attributes.item(i).value
|
||||
end
|
||||
attribute_hash
|
||||
end
|
||||
|
||||
|
||||
Reference in New Issue
Block a user