83 lines
1.9 KiB
Ruby
83 lines
1.9 KiB
Ruby
#--
|
|
# Copyright (C) 2006 Andrea Censi <andrea (at) rubyforge.org>
|
|
#
|
|
# This file is part of Maruku.
|
|
#
|
|
# Maruku is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# Maruku is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with Maruku; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
#++
|
|
|
|
|
|
require 'maruku'
|
|
require 'bluecloth'
|
|
|
|
|
|
data = $stdin.read
|
|
|
|
num = 10
|
|
|
|
if ARGV.size > 0 && ((n=ARGV[0].to_i) != 0)
|
|
num = n
|
|
end
|
|
|
|
methods =
|
|
[
|
|
|
|
[Maruku, :to_html],
|
|
[BlueCloth, :to_html],
|
|
[Maruku, :to_latex]
|
|
|
|
]
|
|
|
|
#methods = [[Maruku, :class]]
|
|
#num = 10
|
|
|
|
stats =
|
|
methods .map do |c, method|
|
|
puts "Computing for #{c}"
|
|
|
|
start = Time.now
|
|
doc = nil
|
|
for i in 1..num
|
|
$stdout.write "#{i} "; $stdout.flush
|
|
doc = c.new(data)
|
|
end
|
|
stop = Time.now
|
|
parsing = (stop-start)/num
|
|
|
|
start = Time.now
|
|
for i in 1..num
|
|
$stdout.write "#{i} "; $stdout.flush
|
|
s = doc.send method
|
|
end
|
|
stop = Time.now
|
|
rendering = (stop-start)/num
|
|
|
|
puts ("%s (%s): parsing %0.2f sec + rendering %0.2f sec "+
|
|
"= %0.2f sec ") % [c, method, parsing,rendering,parsing+rendering]
|
|
|
|
[c, method, parsing, rendering]
|
|
end
|
|
|
|
puts "\n\n\n"
|
|
stats.each do |x| x.push(x[2]+x[3]) end
|
|
max = stats.map{|x|x[4]}.max
|
|
stats.sort! { |x,y| x[4] <=> y[4] } . reverse!
|
|
for c, method, parsing, rendering, tot in stats
|
|
puts ("%20s: parsing %0.2f sec + rendering %0.2f sec "+
|
|
"= %0.2f sec (%0.2fx)") %
|
|
["#{c} (#{method})", parsing,rendering,tot,max/tot]
|
|
end
|
|
|