Class: ActiveSupport::XmlMini_NokogiriSAX::HashBuilder

Inherits:
Nokogiri::XML::SAX::Document
  • Object
show all
Defined in:
lib/active_support/xml_mini/nokogirisax.rb

Overview

Class that will build the hash while the XML document is being parsed using SAX events.

Constant Summary collapse

CONTENT_KEY =
'__content__'.freeze
HASH_SIZE_KEY =
'__hash_size__'.freeze

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#hashObject (readonly)

Returns the value of attribute hash.



21
22
23
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 21

def hash
  @hash
end

Instance Method Details

#characters(string) ⇒ Object Also known as: cdata_block



60
61
62
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 60

def characters(string)
  current_hash[CONTENT_KEY] << string
end

#current_hashObject



23
24
25
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 23

def current_hash
  @hash_stack.last
end

#end_documentObject



32
33
34
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 32

def end_document
  raise "Parse stack not empty!" if @hash_stack.size > 1
end

#end_element(name) ⇒ Object



53
54
55
56
57
58
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 53

def end_element(name)
  if current_hash.length > current_hash.delete(HASH_SIZE_KEY) && current_hash[CONTENT_KEY].blank? || current_hash[CONTENT_KEY] == ''
    current_hash.delete(CONTENT_KEY)
  end
  @hash_stack.pop
end

#error(error_message) ⇒ Object



36
37
38
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 36

def error(error_message)
  raise error_message
end

#start_documentObject



27
28
29
30
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 27

def start_document
  @hash = {}
  @hash_stack = [@hash]
end

#start_element(name, attrs = []) ⇒ Object



40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/active_support/xml_mini/nokogirisax.rb', line 40

def start_element(name, attrs = [])
  new_hash = { CONTENT_KEY => '' }.merge(Hash[attrs])
  new_hash[HASH_SIZE_KEY] = new_hash.size + 1

  case current_hash[name]
    when Array then current_hash[name] << new_hash
    when Hash  then current_hash[name] = [current_hash[name], new_hash]
    when nil   then current_hash[name] = new_hash
  end

  @hash_stack.push(new_hash)
end