diff options
author | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-08-25 15:13:14 +0000 |
---|---|---|
committer | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-08-25 15:13:14 +0000 |
commit | d0233291bc8a5068e52c69c210e5979e5324b5bc (patch) | |
tree | 7d9459449c33792c63eeb7baa071e76352e0baab /trunk/tool/eval.rb | |
parent | 0dc342de848a642ecce8db697b8fecd83a63e117 (diff) | |
parent | 72eaacaa15256ab95c3b52ea386f88586fb9da40 (diff) |
re-adding tag v1_9_0_4 as an alias of trunk@18848v1_9_0_4
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v1_9_0_4@18849 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'trunk/tool/eval.rb')
-rw-r--r-- | trunk/tool/eval.rb | 161 |
1 files changed, 0 insertions, 161 deletions
diff --git a/trunk/tool/eval.rb b/trunk/tool/eval.rb deleted file mode 100644 index 906ba9c23c..0000000000 --- a/trunk/tool/eval.rb +++ /dev/null @@ -1,161 +0,0 @@ - -require 'rbconfig' -require 'fileutils' -require 'pp' - -Ruby = ENV['RUBY'] || - File.join(Config::CONFIG["bindir"], - Config::CONFIG["ruby_install_name"] + Config::CONFIG["EXEEXT"]) -# - -OPTIONS = %w{ - opt-direct-threaded-code - opt-basic-operations - opt-operands-unification - opt-instructions-unification - opt-inline-method-cache - opt-stack-caching -}.map{|opt| - '--disable-' + opt -} - -opts = OPTIONS.dup -Configs = OPTIONS.map{|opt| - o = opts.dup - opts.delete(opt) - o -} + [[]] - -pp Configs if $DEBUG - - -def exec_cmd(cmd) - puts cmd - unless system(cmd) - p cmd - raise "error" - end -end - -def dirname idx - "ev-#{idx}" -end - -def build - Configs.each_with_index{|config, idx| - dir = dirname(idx) - FileUtils.rm_rf(dir) if FileTest.exist?(dir) - Dir.mkdir(dir) - FileUtils.cd(dir){ - exec_cmd("#{Ruby} ../extconf.rb " + config.join(" ")) - exec_cmd("make clean test-all") - } - } -end - -def check - Configs.each_with_index{|c, idx| - puts "= #{idx}" - system("#{Ruby} -r ev-#{idx}/yarvcore -e 'puts YARVCore::OPTS'") - } -end - -def bench_each idx - puts "= #{idx}" - 5.times{|count| - print count - FileUtils.cd(dirname(idx)){ - exec_cmd("make benchmark OPT=-y ITEMS=#{ENV['ITEMS']} > ../b#{idx}-#{count}") - } - } - puts -end - -def bench - # return bench_each(6) - Configs.each_with_index{|c, idx| - bench_each idx - } -end - -def parse_result data - flag = false - stat = [] - data.each{|line| - if flag - if /(\w+)\t([\d\.]+)/ =~ line - stat << [$1, $2.to_f] - else - raise "not a data" - end - - end - if /benchmark summary/ =~ line - flag = true - end - } - stat -end - -def calc_each data - data.sort! - data.pop # remove max - data.shift # remove min - - data.inject(0.0){|res, e| - res += e - } / data.size -end - -def calc_stat stats - stat = [] - stats[0].each_with_index{|e, idx| - bm = e[0] - vals = stats.map{|st| - st[idx][1] - } - [bm, calc_each(vals)] - } -end - -def stat - total = [] - Configs.each_with_index{|c, idx| - stats = [] - 5.times{|count| - file = "b#{idx}-#{count}" - # p file - open(file){|f| - stats << parse_result(f.read) - } - } - # merge stats - total << calc_stat(stats) - total - } - # pp total - total[0].each_with_index{|e, idx| - bm = e[0] - # print "#{bm}\t" - total.each{|st| - print st[idx][1], "\t" - } - puts - } -end - -ARGV.each{|cmd| - case cmd - when 'build' - build - when 'check' - check - when 'bench' - bench - when 'stat' - stat - else - raise - end -} - |