2009-07-10 02:50:41 -04:00
|
|
|
require 'benchmark'
|
|
|
|
require 'rubygems'
|
|
|
|
require 'nokogiri'
|
|
|
|
|
|
|
|
class Parser < Nokogiri::XML::SAX::Document
|
|
|
|
|
|
|
|
attr_reader :response
|
|
|
|
|
|
|
|
def initialize
|
|
|
|
reset
|
|
|
|
end
|
|
|
|
|
|
|
|
def reset
|
|
|
|
@item = {}
|
|
|
|
@response = { :items => [] }
|
|
|
|
end
|
|
|
|
|
|
|
|
def characters(string)
|
|
|
|
@value << string.strip
|
|
|
|
end
|
|
|
|
|
|
|
|
def start_element(name, attrs = [])
|
2010-05-05 16:39:41 -04:00
|
|
|
@value = nil
|
2009-07-10 02:50:41 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def end_element(name)
|
|
|
|
case name
|
|
|
|
when 'item'
|
|
|
|
@response[:items] << @item
|
|
|
|
@item = {}
|
|
|
|
when 'key'
|
|
|
|
@item[:key] = @value
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
data = <<-DATA
|
|
|
|
<items>
|
|
|
|
<item>
|
|
|
|
<key>value</key>
|
|
|
|
</item>
|
|
|
|
</items>
|
|
|
|
DATA
|
|
|
|
|
|
|
|
COUNT = 100
|
|
|
|
|
|
|
|
Benchmark.bmbm(25) do |bench|
|
|
|
|
bench.report('parse') do
|
|
|
|
parser = Parser.new
|
|
|
|
Nokogiri::XML::SAX::Parser.new(parser).parse(data)
|
|
|
|
parser.response
|
|
|
|
end
|
|
|
|
|
|
|
|
bench.report('push') do
|
|
|
|
parser = Parser.new
|
|
|
|
Nokogiri::XML::SAX::PushParser.new(parser).write(data, true)
|
|
|
|
parser.response
|
|
|
|
end
|
|
|
|
end
|