Module: Prof

Defined in:
lib/rails/rubyprof_ext.rb

Overview

:nodoc:

Class Method Summary collapse

Class Method Details

Adapted from Shugo Maeda’s unprof.rb



5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/rails/rubyprof_ext.rb', line 5

def self.print_profile(results, io = $stderr)
  total = results.detect { |i|
    i.method_class.nil? && i.method_id == :"#toplevel"
  }.total_time
  total = 0.001 if total < 0.001

  io.puts "  %%   cumulative   self              self     total"
  io.puts " time   seconds   seconds    calls  ms/call  ms/call  name"

  sum = 0.0
  results.each do |r|
    sum += r.self_time

    name =  if r.method_class.nil?
              r.method_id.to_s
            elsif r.method_class.is_a?(Class)
              "#{r.method_class}##{r.method_id}"
            else
              "#{r.method_class}.#{r.method_id}"
            end
    io.printf "%6.2f %8.3f  %8.3f %8d %8.2f %8.2f  %s\n",
      r.self_time / total * 100,
      sum,
      r.self_time,
      r.count,
      r.self_time * 1000 / r.count,
      r.total_time * 1000 / r.count,
      name
  end
end