Sha256: 70aba1242b700a30fa03e7eb188e3036b515accee63a2389c3cfab41add67cef
Contents?: true
Size: 1.23 KB
Versions: 11
Compression:
Stored size: 1.23 KB
Contents
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
11 entries across 11 versions & 3 rubygems