Sha256: 9e2c52a895ada3a48bff02a6a9f20b034dde85d95253a8a3d6c5c7f9268c43f9

Contents?: true

Size: 1.24 KB

Versions: 2

Compression:

Stored size: 1.24 KB

Contents

# encoding: utf-8

module RubyProf
  class AggregateCallInfo
    attr_reader :call_infos
    def initialize(call_infos)
      if call_infos.length == 0
        raise(ArgumentError, "Must specify at least one call info.")
      end
      @call_infos = call_infos
    end

    def target
      call_infos.first.target
    end

    def parent
      call_infos.first.parent
    end

    def line
      call_infos.first.line
    end

    def children
      call_infos.inject(Array.new) do |result, call_info|
        result.concat(call_info.children)
      end
    end

    def total_time
      aggregate_minimal(:total_time)
    end

    def self_time
      aggregate(:self_time)
    end

    def wait_time
      aggregate(:wait_time)
    end

    def children_time
      aggregate_minimal(:children_time)
    end

    def called
      aggregate(:called)
    end

    def to_s
      "#{call_infos.first.full_name}"
    end

    private

    def aggregate(method_name)
      self.call_infos.inject(0) do |sum, call_info|
        sum += call_info.send(method_name)
      end
    end

    def aggregate_minimal(method_name)
      self.call_infos.inject(0) do |sum, call_info|
        sum += call_info.send(method_name) if call_info.minimal?
        sum
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
ruby-prof-0.11.0.rc1-x86-mingw32 lib/ruby-prof/aggregate_call_info.rb
ruby-prof-0.11.0.rc1 lib/ruby-prof/aggregate_call_info.rb