Sha256: 2e7367c29a87327b488b2c6bed244d633b892a60346dcbfd3382d7a822f0e5a6
Contents?: true
Size: 1.94 KB
Versions: 2
Compression:
Stored size: 1.94 KB
Contents
# encoding: UTF-8 $LOAD_PATH.unshift File.expand_path(File.dirname(__FILE__) + '/..') $LOAD_PATH.unshift File.expand_path(File.dirname(__FILE__) + '/../lib') require 'rubygems' require 'benchmark' require 'yaml' require 'yajl' begin require 'json' rescue LoadError end begin require 'psych' rescue LoadError end begin require 'active_support' rescue LoadError end filename = ARGV[0] || 'benchmark/subjects/item.json' json = File.new(filename, 'r') times = ARGV[1] ? ARGV[1].to_i : 10_000 puts "Starting benchmark parsing #{File.size(filename)} bytes of JSON data #{times} times\n\n" Benchmark.bmbm { |x| io_parser = Yajl::Parser.new io_parser.on_parse_complete = lambda {|obj|} if times > 1 x.report { puts "Yajl::Parser#parse (from an IO)" times.times { json.rewind io_parser.parse(json) } } string_parser = Yajl::Parser.new string_parser.on_parse_complete = lambda {|obj|} if times > 1 x.report { puts "Yajl::Parser#parse (from a String)" times.times { json.rewind string_parser.parse(json.read) } } if defined?(JSON) x.report { puts "JSON.parse" times.times { json.rewind JSON.parse(json.read, :max_nesting => false) } } end if defined?(ActiveSupport::JSON) x.report { puts "ActiveSupport::JSON.decode" times.times { json.rewind ActiveSupport::JSON.decode(json.read) } } end x.report { puts "YAML.load (from an IO)" times.times { json.rewind YAML.load(json) } } x.report { puts "YAML.load (from a String)" times.times { json.rewind YAML.load(json.read) } } if defined?(Psych) x.report { puts "Psych.load (from an IO)" times.times { json.rewind Psych.load(json) } } x.report { puts "Psych.load (from a String)" times.times { json.rewind Psych.load(json.read) } } end } json.close
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
yajl-ruby-0.8.3 | benchmark/parse.rb |
yajl-ruby-0.8.2 | benchmark/parse.rb |