Class: RubyProf::Thread
- Inherits:
-
Object
- Object
- RubyProf::Thread
- Defined in:
- lib/ruby-prof/thread.rb,
ext/ruby_prof/rp_thread.c
Instance Method Summary collapse
-
#fiber_id ⇒ Numeric
Returns the fiber id of this thread.
-
#id ⇒ Numeric
Returns the id of this thread.
-
#methods ⇒ Array of MethodInfo
Returns an array of methods that were called from this thread during program execution.
- #top_methods ⇒ Object
- #total_time ⇒ Object
Instance Method Details
#fiber_id ⇒ Numeric
Returns the fiber id of this thread.
236 237 238 239 240 241 |
# File 'ext/ruby_prof/rp_thread.c', line 236 static VALUE prof_fiber_id(VALUE self) { thread_data_t* thread = prof_get_thread(self); return thread->fiber_id; } |
#id ⇒ Numeric
Returns the id of this thread.
225 226 227 228 229 230 |
# File 'ext/ruby_prof/rp_thread.c', line 225 static VALUE prof_thread_id(VALUE self) { thread_data_t* thread = prof_get_thread(self); return thread->thread_id; } |
#methods ⇒ Array of MethodInfo
Returns an array of methods that were called from this thread during program execution.
248 249 250 251 252 253 254 255 256 257 258 |
# File 'ext/ruby_prof/rp_thread.c', line 248 static VALUE prof_thread_methods(VALUE self) { thread_data_t* thread = prof_get_thread(self); if (thread->methods == Qnil) { thread->methods = rb_ary_new(); st_foreach(thread->method_table, collect_methods, thread->methods); } return thread->methods; } |
#top_methods ⇒ Object
3 4 5 6 7 8 9 |
# File 'lib/ruby-prof/thread.rb', line 3 def top_methods self.methods.select do |method_info| method_info.call_infos.detect do |call_info| call_info.parent.nil? end end end |
#total_time ⇒ Object
11 12 13 14 15 16 17 18 19 20 |
# File 'lib/ruby-prof/thread.rb', line 11 def total_time self.top_methods.inject(0) do |sum, method_info| method_info.call_infos.each do |call_info| if call_info.parent.nil? sum += call_info.total_time end end sum end end |