Sha256: a888a536bdfc1ab64556933ea82d2841c94cfe595a1b6aced9d323b97183b71c

Contents?: true

Size: 1.07 KB

Versions: 7

Compression:

Stored size: 1.07 KB

Contents

# The call info visitor class does a depth-first traversal
# across a thread's call stack.  At each call_info node,
# the visitor executes the block provided in the
# #visit method.  The block is passed two parameters, the
# event and the call_info instance.  Event will be
# either :enter or :exit.
#
#   visitor = RubyProf::CallInfoVisitor.new(result.threads.first)
#
#   method_names = Array.new
#
#   visitor.visit do |call_info, event|
#     method_names << call_info.target.full_name if event == :enter
#   end
#
#   puts method_names

module RubyProf
  class CallInfoVisitor
    attr_reader :block, :thread

    def initialize(thread)
      @thread = thread
    end

    def visit(&block)
      @block = block

      self.thread.top_method.call_infos.each do |call_info|
        self.visit_call_info(call_info)
      end
    end

    def visit_call_info(call_info)
      self.block.call(call_info, :enter)
      call_info.children.each do |child|
        visit_call_info(child)
      end
      self.block.call(call_info, :exit)
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
ruby-prof-0.11.3 lib/ruby-prof/call_info_visitor.rb
ruby-prof-0.11.2-x86-mingw32 lib/ruby-prof/call_info_visitor.rb
ruby-prof-0.11.2 lib/ruby-prof/call_info_visitor.rb
ruby-prof-0.11.0.rc3-x86-mingw32 lib/ruby-prof/call_info_visitor.rb
ruby-prof-0.11.0.rc3 lib/ruby-prof/call_info_visitor.rb
ruby-prof-0.11.0.rc2-x86-mingw32 lib/ruby-prof/call_info_visitor.rb
ruby-prof-0.11.0.rc2 lib/ruby-prof/call_info_visitor.rb