PHP 8.2.31
Preview: profiler.rb Size: 4.51 KB
/proc/thread-self/root/opt/alt/ruby21/lib64/ruby/2.1.0/profiler.rb

# Profile provides a way to Profile your Ruby application.
#
# Profiling your program is a way of determining which methods are called and
# how long each method takes to complete.  This way you can detect which
# methods are possible bottlenecks.
#
# Profiling your program will slow down your execution time considerably,
# so activate it only when you need it.  Don't confuse benchmarking with
# profiling.
#
# There are two ways to activate Profiling:
#
# == Command line
#
# Run your Ruby script with <code>-rprofile</code>:
#
#   ruby -rprofile example.rb
#
# If you're profiling an executable in your <code>$PATH</code> you can use
# <code>ruby -S</code>:
#
#   ruby -rprofile -S some_executable
#
# == From code
#
# Just require 'profile':
#
#   require 'profile'
#
#   def slow_method
#     5000.times do
#       9999999999999999*999999999
#     end
#   end
#
#   def fast_method
#     5000.times do
#       9999999999999999+999999999
#     end
#   end
#
#   slow_method
#   fast_method
#
# The output in both cases is a report when the execution is over:
#
#   ruby -rprofile example.rb
#
#     %   cumulative   self              self     total
#    time   seconds   seconds    calls  ms/call  ms/call  name
#    68.42     0.13      0.13        2    65.00    95.00  Integer#times
#    15.79     0.16      0.03     5000     0.01     0.01  Fixnum#*
#    15.79     0.19      0.03     5000     0.01     0.01  Fixnum#+
#     0.00     0.19      0.00        2     0.00     0.00  IO#set_encoding
#     0.00     0.19      0.00        1     0.00   100.00  Object#slow_method
#     0.00     0.19      0.00        2     0.00     0.00  Module#method_added
#     0.00     0.19      0.00        1     0.00    90.00  Object#fast_method
#     0.00     0.19      0.00        1     0.00   190.00  #toplevel

module Profiler__
  class Wrapper < Struct.new(:defined_class, :method_id, :hash) # :nodoc:
    private :defined_class=, :method_id=, :hash=

    def initialize(klass, mid)
      super(klass, mid, nil)
      self.hash = Struct.instance_method(:hash).bind(self).call
    end

    def to_s
      "#{defined_class.inspect}#".sub(/\A\#<Class:(.*)>#\z/, '\1.') << method_id.to_s
    end
    alias inspect to_s
  end

  # internal values
  @@start = nil # the start time that profiling began
  @@stacks = nil # the map of stacks keyed by thread
  @@maps = nil # the map of call data keyed by thread, class and id. Call data contains the call count, total time,
  PROFILE_CALL_PROC = TracePoint.new(*%i[call c_call b_call]) {|tp| # :nodoc:
    now = Process.times[0]
    stack = (@@stacks[Thread.current] ||= [])
    stack.push [now, 0.0]
  }
  PROFILE_RETURN_PROC = TracePoint.new(*%i[return c_return b_return]) {|tp| # :nodoc:
    now = Process.times[0]
    key = Wrapper.new(tp.defined_class, tp.method_id)
    stack = (@@stacks[Thread.current] ||= [])
    if tick = stack.pop
      threadmap = (@@maps[Thread.current] ||= {})
      data = (threadmap[key] ||= [0, 0.0, 0.0, key])
      data[0] += 1
      cost = now - tick[0]
      data[1] += cost
      data[2] += cost - tick[1]
      stack[-1][1] += cost if stack[-1]
    end
  }
module_function
  # Starts the profiler.
  #
  # See Profiler__ for more information.
  def start_profile
    @@start = Process.times[0]
    @@stacks = {}
    @@maps = {}
    PROFILE_CALL_PROC.enable
    PROFILE_RETURN_PROC.enable
  end
  # Stops the profiler.
  #
  # See Profiler__ for more information.
  def stop_profile
    PROFILE_CALL_PROC.disable
    PROFILE_RETURN_PROC.disable
  end
  # Outputs the results from the profiler.
  #
  # See Profiler__ for more information.
  def print_profile(f)
    stop_profile
    total = Process.times[0] - @@start
    if total == 0 then total = 0.01 end
    totals = {}
    @@maps.values.each do |threadmap|
      threadmap.each do |key, data|
        total_data = (totals[key] ||= [0, 0.0, 0.0, key])
        total_data[0] += data[0]
        total_data[1] += data[1]
        total_data[2] += data[2]
      end
    end

    # Maybe we should show a per thread output and a totals view?

    data = totals.values
    data = data.sort_by{|x| -x[2]}
    sum = 0
    f.printf "  %%   cumulative   self              self     total\n"
    f.printf " time   seconds   seconds    calls  ms/call  ms/call  name\n"
    for d in data
      sum += d[2]
      f.printf "%6.2f %8.2f  %8.2f %8d ", d[2]/total*100, sum, d[2], d[0]
      f.printf "%8.2f %8.2f  %s\n", d[2]*1000/d[0], d[1]*1000/d[0], d[3]
    end
    f.printf "%6.2f %8.2f  %8.2f %8d ", 0.0, total, 0.0, 1     # ???
    f.printf "%8.2f %8.2f  %s\n", 0.0, total*1000, "#toplevel" # ???
  end
end

Directory Contents

Dirs: 31 × Files: 77

Name Size Perms Modified Actions
cgi DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
date DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
digest DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
dl DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
drb DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
fiddle DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
io DIR
- drwxr-xr-x 2024-03-03 22:43:07
Edit Download
irb DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
json DIR
- drwxr-xr-x 2024-03-03 22:43:07
Edit Download
matrix DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
net DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
openssl DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
optparse DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
psych DIR
- drwxr-xr-x 2024-03-03 22:43:08
Edit Download
racc DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
rake DIR
- drwxr-xr-x 2024-03-03 22:53:20
Edit Download
rbconfig DIR
- drwxr-xr-x 2024-03-03 22:43:11
Edit Download
rdoc DIR
- drwxr-xr-x 2024-03-03 22:43:10
Edit Download
rexml DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
rinda DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
ripper DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
rss DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
rubygems DIR
- drwxr-xr-x 2024-03-03 22:43:11
Edit Download
shell DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
syslog DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
test DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
uri DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
webrick DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
- drwxr-xr-x 2024-03-03 22:43:08
Edit Download
xmlrpc DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
yaml DIR
- drwxr-xr-x 2024-03-03 22:43:05
Edit Download
3.31 KB lrw-r--r-- 2013-02-21 17:35:32
Edit Download
2.63 KB lrw-r--r-- 2013-05-19 03:10:21
Edit Download
17.95 KB lrw-r--r-- 2013-09-20 16:05:48
Edit Download
9.84 KB lrw-r--r-- 2013-07-18 13:50:32
Edit Download
8.93 KB lrw-r--r-- 2015-07-03 09:12:53
Edit Download
380 B lrw-r--r-- 2009-08-16 15:34:35
Edit Download
81.68 KB lrw-r--r-- 2014-09-14 15:25:34
Edit Download
946 B lrw-r--r-- 2023-07-26 14:22:11
Edit Download
29.08 KB lrw-r--r-- 2013-12-14 14:48:36
Edit Download
11.13 KB lrw-r--r-- 2014-02-02 13:46:46
Edit Download
2.34 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
280 B lrw-r--r-- 2023-07-26 14:22:11
Edit Download
19 B lrw-r--r-- 2009-10-02 10:45:39
Edit Download
3.89 KB lrw-r--r-- 2013-12-17 11:20:10
Edit Download
6.44 KB lrw-r--r-- 2013-02-04 02:50:20
Edit Download
26.07 KB lrw-r--r-- 2014-08-11 14:55:58
Edit Download
2.14 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
1.65 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
47.17 KB lrw-r--r-- 2015-04-28 05:16:46
Edit Download
2.36 KB lrw-r--r-- 2014-10-15 15:31:03
Edit Download
7.86 KB lrw-r--r-- 2013-05-23 21:46:43
Edit Download
15.38 KB lrw-r--r-- 2013-05-19 14:50:47
Edit Download
8.86 KB lrw-r--r-- 2014-07-06 13:57:45
Edit Download
17.05 KB lrw-r--r-- 2015-10-29 14:36:05
Edit Download
20.03 KB lrw-r--r-- 2016-03-25 08:22:04
Edit Download
1.74 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
5.74 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
22.37 KB lrw-r--r-- 2016-02-25 11:04:33
Edit Download
6.52 KB lrw-r--r-- 2011-08-26 22:22:37
Edit Download
45.43 KB lrw-r--r-- 2014-07-11 14:08:51
Edit Download
80.50 KB lrw-r--r-- 2023-07-26 14:19:40
Edit Download
6.93 KB lrw-r--r-- 2012-11-16 16:55:29
Edit Download
2.00 KB lrw-r--r-- 2013-02-20 02:51:51
Edit Download
5.81 KB lrw-r--r-- 2013-11-21 04:44:45
Edit Download
24.27 KB lrw-r--r-- 2014-02-22 08:54:43
Edit Download
20.37 KB lrw-r--r-- 2013-12-01 03:13:11
Edit Download
528 B lrw-r--r-- 2023-07-26 14:22:11
Edit Download
50.80 KB lrw-r--r-- 2013-11-28 07:34:15
Edit Download
7.70 KB lrw-r--r-- 2013-10-23 15:14:17
Edit Download
15.30 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
14.10 KB lrw-r--r-- 2013-10-22 09:29:53
Edit Download
16.33 KB lrw-r--r-- 2013-05-19 03:10:21
Edit Download
13.20 KB lrw-r--r-- 2013-07-15 04:21:34
Edit Download
205 B lrw-r--r-- 2009-10-02 10:45:39
Edit Download
4.51 KB lrw-r--r-- 2013-05-19 23:04:36
Edit Download
14.85 KB lrw-r--r-- 2012-11-11 04:23:04
Edit Download
14.88 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
2.12 KB lrw-r--r-- 2013-10-11 21:35:01
Edit Download
308 B lrw-r--r-- 2009-09-24 00:42:23
Edit Download
4.92 KB lrw-r--r-- 2013-12-22 10:25:26
Edit Download
1.73 KB lrw-r--r-- 2013-03-11 13:47:04
Edit Download
72.31 KB lrw-r--r-- 2015-05-13 05:33:45
Edit Download
2.53 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
2.84 KB lrw-r--r-- 2011-05-11 10:22:16
Edit Download
30.97 KB lrw-r--r-- 2023-07-26 14:19:40
Edit Download
23.54 KB lrw-r--r-- 2013-12-14 02:55:33
Edit Download
8.49 KB lrw-r--r-- 2013-11-07 18:04:05
Edit Download
18.70 KB lrw-r--r-- 2013-11-22 23:50:06
Edit Download
10.30 KB lrw-r--r-- 2013-05-19 03:10:21
Edit Download
5.94 KB lrw-r--r-- 2013-12-14 18:26:59
Edit Download
4.02 KB lrw-r--r-- 2011-05-18 14:09:38
Edit Download
25.60 KB lrw-r--r-- 2023-07-26 14:22:11
Edit Download
7.25 KB lrw-r--r-- 2013-05-19 03:10:21
Edit Download
11.40 KB lrw-r--r-- 2013-11-21 09:28:43
Edit Download
3.38 KB lrw-r--r-- 2013-11-07 17:02:56
Edit Download
21.32 KB lrw-r--r-- 2015-08-17 07:41:58
Edit Download
3.70 KB lrw-r--r-- 2015-08-17 07:55:26
Edit Download
4.15 KB lrw-r--r-- 2013-05-19 03:10:21
Edit Download
6.40 KB lrw-r--r-- 2013-07-18 13:50:32
Edit Download
14.14 KB lrw-r--r-- 2013-10-17 15:59:40
Edit Download
268 B lrw-r--r-- 2009-10-02 10:45:39
Edit Download
8.87 KB lrw-r--r-- 2013-07-05 13:43:25
Edit Download
3.07 KB lrw-r--r-- 2011-05-13 20:03:21
Edit Download
3.23 KB lrw-r--r-- 2013-11-09 22:42:20
Edit Download
6.69 KB lrw-r--r-- 2013-10-05 23:39:32
Edit Download
8.49 KB lrw-r--r-- 2013-12-12 03:09:19
Edit Download
2.31 KB lrw-r--r-- 2013-08-12 03:49:50
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).