Sha256: 0d3eb424f71bf6baad6d9709c10fd8f191c4f35395c8debc4a4850882adc62aa

Contents?: true

Size: 1.29 KB

Versions: 8

Compression:

Stored size: 1.29 KB

Contents

# encoding: utf-8

module RubyProf
  # Prints out the call graph based on CallInfo instances. This
  # is mainly for debugging purposes as it provides access into
  # into RubyProf's internals.

  class CallInfoPrinter < AbstractPrinter
    TIME_WIDTH = 0

    private

    def print_header(thread)
      @output << "Thread ID: #{thread.id}\n"
      @output << "Fiber ID: #{thread.fiber_id}\n"
      @output << "Total Time: #{thread.total_time}\n"
      @output << "Sort by: #{sort_method}\n"
      @output << "\n"
    end

    def print_methods(thread)
      visitor = CallInfoVisitor.new(thread.top_call_infos)

      visitor.visit do |call_info, event|
        if event == :enter
          @output << "  " * call_info.depth
          @output << call_info.target.full_name
          @output << " ("
          @output << "tt:#{sprintf("%#{TIME_WIDTH}.2f", call_info.total_time)}, "
          @output << "st:#{sprintf("%#{TIME_WIDTH}.2f", call_info.self_time)}, "
          @output << "wt:#{sprintf("%#{TIME_WIDTH}.2f", call_info.wait_time)}, "
          @output << "ct:#{sprintf("%#{TIME_WIDTH}.2f", call_info.children_time)}, "
          @output << "call:#{call_info.called}, "
          @output << "rec:#{call_info.recursive}"
          @output << ")"
          @output << "\n"
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 2 rubygems

Version Path
ruby-prof-0.16.2 lib/ruby-prof/printers/call_info_printer.rb
ruby-prof-0.16.1 lib/ruby-prof/printers/call_info_printer.rb
ruby-prof-0.16.0 lib/ruby-prof/printers/call_info_printer.rb
ish_lib_manager-0.0.1 test/dummy/vendor/bundle/ruby/2.3.0/gems/ruby-prof-0.15.9/lib/ruby-prof/printers/call_info_printer.rb
ruby-prof-0.15.9 lib/ruby-prof/printers/call_info_printer.rb
ruby-prof-0.15.8 lib/ruby-prof/printers/call_info_printer.rb
ruby-prof-0.15.7 lib/ruby-prof/printers/call_info_printer.rb
ruby-prof-0.15.6 lib/ruby-prof/printers/call_info_printer.rb