ruby-prof 0.16.2 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/CHANGES +532 -467
- data/LICENSE +24 -24
- data/README.rdoc +5 -454
- data/Rakefile +110 -113
- data/bin/ruby-prof +380 -340
- data/bin/ruby-prof-check-trace +45 -45
- data/ext/ruby_prof/extconf.rb +36 -64
- data/ext/ruby_prof/rp_allocation.c +279 -0
- data/ext/ruby_prof/rp_allocation.h +31 -0
- data/ext/ruby_prof/rp_call_info.c +271 -407
- data/ext/ruby_prof/rp_call_info.h +35 -48
- data/ext/ruby_prof/rp_measure_allocations.c +52 -76
- data/ext/ruby_prof/rp_measure_memory.c +42 -77
- data/ext/ruby_prof/rp_measure_process_time.c +67 -71
- data/ext/ruby_prof/rp_measure_wall_time.c +62 -45
- data/ext/ruby_prof/rp_measurement.c +230 -0
- data/ext/ruby_prof/rp_measurement.h +50 -0
- data/ext/ruby_prof/rp_method.c +630 -411
- data/ext/ruby_prof/rp_method.h +70 -52
- data/ext/ruby_prof/rp_profile.c +895 -0
- data/ext/ruby_prof/rp_profile.h +37 -0
- data/ext/ruby_prof/rp_stack.c +196 -128
- data/ext/ruby_prof/rp_stack.h +56 -51
- data/ext/ruby_prof/rp_thread.c +337 -273
- data/ext/ruby_prof/rp_thread.h +36 -27
- data/ext/ruby_prof/ruby_prof.c +48 -671
- data/ext/ruby_prof/ruby_prof.h +17 -56
- data/ext/ruby_prof/vc/ruby_prof.sln +20 -21
- data/ext/ruby_prof/vc/{ruby_prof_20.vcxproj → ruby_prof.vcxproj} +38 -5
- data/lib/ruby-prof.rb +52 -58
- data/lib/ruby-prof/assets/call_stack_printer.html.erb +713 -0
- data/lib/ruby-prof/assets/call_stack_printer.png +0 -0
- data/lib/ruby-prof/assets/graph_printer.html.erb +356 -0
- data/lib/ruby-prof/call_info.rb +57 -126
- data/lib/ruby-prof/call_info_visitor.rb +38 -40
- data/lib/ruby-prof/compatibility.rb +109 -178
- data/lib/ruby-prof/exclude_common_methods.rb +198 -0
- data/lib/ruby-prof/measurement.rb +14 -0
- data/lib/ruby-prof/method_info.rb +90 -129
- data/lib/ruby-prof/printers/abstract_printer.rb +127 -85
- data/lib/ruby-prof/printers/call_info_printer.rb +51 -41
- data/lib/ruby-prof/printers/call_stack_printer.rb +182 -260
- data/lib/ruby-prof/printers/call_tree_printer.rb +151 -130
- data/lib/ruby-prof/printers/dot_printer.rb +132 -132
- data/lib/ruby-prof/printers/flat_printer.rb +52 -70
- data/lib/ruby-prof/printers/graph_html_printer.rb +63 -244
- data/lib/ruby-prof/printers/graph_printer.rb +114 -116
- data/lib/ruby-prof/printers/multi_printer.rb +127 -58
- data/lib/ruby-prof/profile.rb +33 -55
- data/lib/ruby-prof/rack.rb +171 -95
- data/lib/ruby-prof/task.rb +147 -147
- data/lib/ruby-prof/thread.rb +35 -41
- data/lib/ruby-prof/version.rb +3 -3
- data/lib/unprof.rb +10 -10
- data/ruby-prof.gemspec +58 -57
- data/test/abstract_printer_test.rb +26 -0
- data/test/alias_test.rb +129 -0
- data/test/basic_test.rb +129 -128
- data/test/call_info_visitor_test.rb +31 -31
- data/test/duplicate_names_test.rb +32 -32
- data/test/dynamic_method_test.rb +53 -55
- data/test/enumerable_test.rb +21 -21
- data/test/exceptions_test.rb +24 -16
- data/test/exclude_methods_test.rb +146 -0
- data/test/exclude_threads_test.rb +53 -53
- data/test/fiber_test.rb +73 -79
- data/test/gc_test.rb +96 -0
- data/test/line_number_test.rb +161 -71
- data/test/marshal_test.rb +119 -0
- data/test/measure_allocations.rb +30 -0
- data/test/measure_allocations_test.rb +385 -26
- data/test/measure_allocations_trace_test.rb +385 -0
- data/test/measure_memory_trace_test.rb +756 -0
- data/test/measure_process_time_test.rb +849 -63
- data/test/measure_times.rb +54 -0
- data/test/measure_wall_time_test.rb +459 -255
- data/test/multi_printer_test.rb +71 -83
- data/test/no_method_class_test.rb +15 -15
- data/test/parser_timings.rb +24 -0
- data/test/pause_resume_test.rb +166 -166
- data/test/prime.rb +56 -54
- data/test/printer_call_stack_test.rb +28 -0
- data/test/printer_call_tree_test.rb +31 -0
- data/test/printer_flat_test.rb +68 -0
- data/test/printer_graph_html_test.rb +60 -0
- data/test/printer_graph_test.rb +41 -0
- data/test/printers_test.rb +141 -255
- data/test/printing_recursive_graph_test.rb +81 -127
- data/test/rack_test.rb +157 -93
- data/test/recursive_test.rb +210 -215
- data/test/singleton_test.rb +38 -38
- data/test/stack_printer_test.rb +64 -78
- data/test/start_stop_test.rb +109 -112
- data/test/test_helper.rb +24 -264
- data/test/thread_test.rb +144 -187
- data/test/unique_call_path_test.rb +190 -202
- data/test/yarv_test.rb +56 -55
- metadata +34 -114
- data/doc/LICENSE.html +0 -114
- data/doc/README_rdoc.html +0 -603
- data/doc/Rack.html +0 -95
- data/doc/Rack/RubyProf.html +0 -226
- data/doc/RubyProf.html +0 -962
- data/doc/RubyProf/AbstractPrinter.html +0 -546
- data/doc/RubyProf/AggregateCallInfo.html +0 -551
- data/doc/RubyProf/CallInfo.html +0 -639
- data/doc/RubyProf/CallInfoPrinter.html +0 -120
- data/doc/RubyProf/CallInfoVisitor.html +0 -198
- data/doc/RubyProf/CallStackPrinter.html +0 -1121
- data/doc/RubyProf/CallTreePrinter.html +0 -641
- data/doc/RubyProf/Cmd.html +0 -631
- data/doc/RubyProf/DotPrinter.html +0 -257
- data/doc/RubyProf/FlatPrinter.html +0 -163
- data/doc/RubyProf/FlatPrinterWithLineNumbers.html +0 -208
- data/doc/RubyProf/GraphHtmlPrinter.html +0 -552
- data/doc/RubyProf/GraphPrinter.html +0 -139
- data/doc/RubyProf/MethodInfo.html +0 -745
- data/doc/RubyProf/MultiPrinter.html +0 -360
- data/doc/RubyProf/Profile.html +0 -763
- data/doc/RubyProf/ProfileTask.html +0 -490
- data/doc/RubyProf/Thread.html +0 -310
- data/doc/created.rid +0 -31
- data/doc/css/fonts.css +0 -167
- data/doc/css/rdoc.css +0 -590
- data/doc/examples/flat_txt.html +0 -138
- data/doc/examples/graph_html.html +0 -909
- data/doc/examples/graph_txt.html +0 -247
- data/doc/fonts/Lato-Light.ttf +0 -0
- data/doc/fonts/Lato-LightItalic.ttf +0 -0
- data/doc/fonts/Lato-Regular.ttf +0 -0
- data/doc/fonts/Lato-RegularItalic.ttf +0 -0
- data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
- data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
- data/doc/images/add.png +0 -0
- data/doc/images/arrow_up.png +0 -0
- data/doc/images/brick.png +0 -0
- data/doc/images/brick_link.png +0 -0
- data/doc/images/bug.png +0 -0
- data/doc/images/bullet_black.png +0 -0
- data/doc/images/bullet_toggle_minus.png +0 -0
- data/doc/images/bullet_toggle_plus.png +0 -0
- data/doc/images/date.png +0 -0
- data/doc/images/delete.png +0 -0
- data/doc/images/find.png +0 -0
- data/doc/images/loadingAnimation.gif +0 -0
- data/doc/images/macFFBgHack.png +0 -0
- data/doc/images/package.png +0 -0
- data/doc/images/page_green.png +0 -0
- data/doc/images/page_white_text.png +0 -0
- data/doc/images/page_white_width.png +0 -0
- data/doc/images/plugin.png +0 -0
- data/doc/images/ruby.png +0 -0
- data/doc/images/tag_blue.png +0 -0
- data/doc/images/tag_green.png +0 -0
- data/doc/images/transparent.png +0 -0
- data/doc/images/wrench.png +0 -0
- data/doc/images/wrench_orange.png +0 -0
- data/doc/images/zoom.png +0 -0
- data/doc/index.html +0 -626
- data/doc/js/darkfish.js +0 -161
- data/doc/js/jquery.js +0 -4
- data/doc/js/navigation.js +0 -142
- data/doc/js/navigation.js.gz +0 -0
- data/doc/js/search.js +0 -109
- data/doc/js/search_index.js +0 -1
- data/doc/js/search_index.js.gz +0 -0
- data/doc/js/searcher.js +0 -228
- data/doc/js/searcher.js.gz +0 -0
- data/doc/table_of_contents.html +0 -942
- data/examples/cachegrind.out.1 +0 -114
- data/examples/cachegrind.out.1.32313213 +0 -114
- data/examples/flat.txt +0 -50
- data/examples/graph.dot +0 -84
- data/examples/graph.html +0 -823
- data/examples/graph.txt +0 -139
- data/examples/multi.flat.txt +0 -23
- data/examples/multi.graph.html +0 -760
- data/examples/multi.grind.dat +0 -114
- data/examples/multi.stack.html +0 -547
- data/examples/stack.html +0 -547
- data/ext/ruby_prof/rp_measure.c +0 -40
- data/ext/ruby_prof/rp_measure.h +0 -45
- data/ext/ruby_prof/rp_measure_cpu_time.c +0 -136
- data/ext/ruby_prof/rp_measure_gc_runs.c +0 -73
- data/ext/ruby_prof/rp_measure_gc_time.c +0 -60
- data/ext/ruby_prof/vc/ruby_prof_18.vcxproj +0 -108
- data/ext/ruby_prof/vc/ruby_prof_19.vcxproj +0 -110
- data/lib/ruby-prof/aggregate_call_info.rb +0 -76
- data/lib/ruby-prof/assets/call_stack_printer.css.html +0 -117
- data/lib/ruby-prof/assets/call_stack_printer.js.html +0 -385
- data/lib/ruby-prof/printers/flat_printer_with_line_numbers.rb +0 -64
- data/test/aggregate_test.rb +0 -136
- data/test/block_test.rb +0 -74
- data/test/call_info_test.rb +0 -78
- data/test/issue137_test.rb +0 -63
- data/test/measure_cpu_time_test.rb +0 -213
- data/test/measure_gc_runs_test.rb +0 -32
- data/test/measure_gc_time_test.rb +0 -36
- data/test/measure_memory_test.rb +0 -33
- data/test/method_elimination_test.rb +0 -84
- data/test/module_test.rb +0 -45
- data/test/stack_test.rb +0 -138
@@ -1,641 +0,0 @@
|
|
1
|
-
<!DOCTYPE html>
|
2
|
-
|
3
|
-
<html>
|
4
|
-
<head>
|
5
|
-
<meta charset="UTF-8">
|
6
|
-
|
7
|
-
<title>class RubyProf::CallTreePrinter - ruby-prof</title>
|
8
|
-
|
9
|
-
<script type="text/javascript">
|
10
|
-
var rdoc_rel_prefix = "../";
|
11
|
-
</script>
|
12
|
-
|
13
|
-
<script src="../js/jquery.js"></script>
|
14
|
-
<script src="../js/darkfish.js"></script>
|
15
|
-
|
16
|
-
<link href="../css/fonts.css" rel="stylesheet">
|
17
|
-
<link href="../css/rdoc.css" rel="stylesheet">
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
<body id="top" role="document" class="class">
|
22
|
-
<nav role="navigation">
|
23
|
-
<div id="project-navigation">
|
24
|
-
<div id="home-section" role="region" title="Quick navigation" class="nav-section">
|
25
|
-
<h2>
|
26
|
-
<a href="../index.html" rel="home">Home</a>
|
27
|
-
</h2>
|
28
|
-
|
29
|
-
<div id="table-of-contents-navigation">
|
30
|
-
<a href="../table_of_contents.html#pages">Pages</a>
|
31
|
-
<a href="../table_of_contents.html#classes">Classes</a>
|
32
|
-
<a href="../table_of_contents.html#methods">Methods</a>
|
33
|
-
</div>
|
34
|
-
</div>
|
35
|
-
|
36
|
-
<div id="search-section" role="search" class="project-section initially-hidden">
|
37
|
-
<form action="#" method="get" accept-charset="utf-8">
|
38
|
-
<div id="search-field-wrapper">
|
39
|
-
<input id="search-field" role="combobox" aria-label="Search"
|
40
|
-
aria-autocomplete="list" aria-controls="search-results"
|
41
|
-
type="text" name="search" placeholder="Search" spellcheck="false"
|
42
|
-
title="Type to search, Up and Down to navigate, Enter to load">
|
43
|
-
</div>
|
44
|
-
|
45
|
-
<ul id="search-results" aria-label="Search Results"
|
46
|
-
aria-busy="false" aria-expanded="false"
|
47
|
-
aria-atomic="false" class="initially-hidden"></ul>
|
48
|
-
</form>
|
49
|
-
</div>
|
50
|
-
|
51
|
-
</div>
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
<div id="class-metadata">
|
56
|
-
|
57
|
-
<div id="parent-class-section" class="nav-section">
|
58
|
-
<h3>Parent</h3>
|
59
|
-
|
60
|
-
|
61
|
-
<p class="link"><a href="AbstractPrinter.html">RubyProf::AbstractPrinter</a>
|
62
|
-
|
63
|
-
</div>
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
<!-- Method Quickref -->
|
68
|
-
<div id="method-list-section" class="nav-section">
|
69
|
-
<h3>Methods</h3>
|
70
|
-
|
71
|
-
<ul class="link-list" role="directory">
|
72
|
-
|
73
|
-
<li ><a href="#method-i-base_name">#base_name</a>
|
74
|
-
|
75
|
-
<li ><a href="#method-i-convert">#convert</a>
|
76
|
-
|
77
|
-
<li ><a href="#method-i-determine_event_specification_and_value_scale">#determine_event_specification_and_value_scale</a>
|
78
|
-
|
79
|
-
<li ><a href="#method-i-file">#file</a>
|
80
|
-
|
81
|
-
<li ><a href="#method-i-file_name_for_thread">#file_name_for_thread</a>
|
82
|
-
|
83
|
-
<li ><a href="#method-i-file_path_for_thread">#file_path_for_thread</a>
|
84
|
-
|
85
|
-
<li ><a href="#method-i-path">#path</a>
|
86
|
-
|
87
|
-
<li ><a href="#method-i-print">#print</a>
|
88
|
-
|
89
|
-
<li ><a href="#method-i-print_headers">#print_headers</a>
|
90
|
-
|
91
|
-
<li ><a href="#method-i-print_method">#print_method</a>
|
92
|
-
|
93
|
-
<li ><a href="#method-i-print_thread">#print_thread</a>
|
94
|
-
|
95
|
-
<li ><a href="#method-i-print_threads">#print_threads</a>
|
96
|
-
|
97
|
-
<li ><a href="#method-i-remove_subsidiary_files_from_previous_profile_runs">#remove_subsidiary_files_from_previous_profile_runs</a>
|
98
|
-
|
99
|
-
</ul>
|
100
|
-
</div>
|
101
|
-
|
102
|
-
</div>
|
103
|
-
</nav>
|
104
|
-
|
105
|
-
<main role="main" aria-labelledby="class-RubyProf::CallTreePrinter">
|
106
|
-
<h1 id="class-RubyProf::CallTreePrinter" class="class">
|
107
|
-
class RubyProf::CallTreePrinter
|
108
|
-
</h1>
|
109
|
-
|
110
|
-
<section class="description">
|
111
|
-
|
112
|
-
<p>Generate profiling information in callgrind format for use by kcachegrind
|
113
|
-
and similar tools.</p>
|
114
|
-
|
115
|
-
<p>Note: when profiling for a callgrind printer, one should use the
|
116
|
-
merge_fibers: true option when creating the profile. Otherwise each fiber
|
117
|
-
would appear as a separate profile.</p>
|
118
|
-
|
119
|
-
</section>
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
<section id="5Buntitled-5D" class="documentation-section">
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
<section id="public-instance-5Buntitled-5D-method-details" class="method-section">
|
135
|
-
<header>
|
136
|
-
<h3>Public Instance Methods</h3>
|
137
|
-
</header>
|
138
|
-
|
139
|
-
|
140
|
-
<div id="method-i-base_name" class="method-detail ">
|
141
|
-
|
142
|
-
<div class="method-heading">
|
143
|
-
<span class="method-name">base_name</span><span
|
144
|
-
class="method-args">()</span>
|
145
|
-
|
146
|
-
<span class="method-click-advice">click to toggle source</span>
|
147
|
-
|
148
|
-
</div>
|
149
|
-
|
150
|
-
|
151
|
-
<div class="method-description">
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
<div class="method-source-code" id="base_name-source">
|
159
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 81</span>
|
160
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">base_name</span>
|
161
|
-
<span class="ruby-ivar">@options</span>[<span class="ruby-value">:profile</span>] <span class="ruby-operator">||</span> <span class="ruby-string">"profile"</span>
|
162
|
-
<span class="ruby-keyword">end</span></pre>
|
163
|
-
</div>
|
164
|
-
|
165
|
-
</div>
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
</div>
|
171
|
-
|
172
|
-
|
173
|
-
<div id="method-i-convert" class="method-detail ">
|
174
|
-
|
175
|
-
<div class="method-heading">
|
176
|
-
<span class="method-name">convert</span><span
|
177
|
-
class="method-args">(value)</span>
|
178
|
-
|
179
|
-
<span class="method-click-advice">click to toggle source</span>
|
180
|
-
|
181
|
-
</div>
|
182
|
-
|
183
|
-
|
184
|
-
<div class="method-description">
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
<div class="method-source-code" id="convert-source">
|
192
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 60</span>
|
193
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">convert</span>(<span class="ruby-identifier">value</span>)
|
194
|
-
(<span class="ruby-identifier">value</span> <span class="ruby-operator">*</span> <span class="ruby-ivar">@value_scale</span>).<span class="ruby-identifier">round</span>
|
195
|
-
<span class="ruby-keyword">end</span></pre>
|
196
|
-
</div>
|
197
|
-
|
198
|
-
</div>
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
</div>
|
204
|
-
|
205
|
-
|
206
|
-
<div id="method-i-determine_event_specification_and_value_scale" class="method-detail ">
|
207
|
-
|
208
|
-
<div class="method-heading">
|
209
|
-
<span class="method-name">determine_event_specification_and_value_scale</span><span
|
210
|
-
class="method-args">()</span>
|
211
|
-
|
212
|
-
<span class="method-click-advice">click to toggle source</span>
|
213
|
-
|
214
|
-
</div>
|
215
|
-
|
216
|
-
|
217
|
-
<div class="method-description">
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
<div class="method-source-code" id="determine_event_specification_and_value_scale-source">
|
225
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 16</span>
|
226
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">determine_event_specification_and_value_scale</span>
|
227
|
-
<span class="ruby-ivar">@event_specification</span> = <span class="ruby-string">"events: "</span>
|
228
|
-
<span class="ruby-keyword">case</span> <span class="ruby-constant">RubyProf</span>.<span class="ruby-identifier">measure_mode</span>
|
229
|
-
<span class="ruby-keyword">when</span> <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">PROCESS_TIME</span>
|
230
|
-
<span class="ruby-ivar">@value_scale</span> = <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">CLOCKS_PER_SEC</span>
|
231
|
-
<span class="ruby-ivar">@event_specification</span> <span class="ruby-operator"><<</span> <span class="ruby-string">'process_time'</span>
|
232
|
-
<span class="ruby-keyword">when</span> <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">WALL_TIME</span>
|
233
|
-
<span class="ruby-ivar">@value_scale</span> = <span class="ruby-value">1_000_000</span>
|
234
|
-
<span class="ruby-ivar">@event_specification</span> <span class="ruby-operator"><<</span> <span class="ruby-string">'wall_time'</span>
|
235
|
-
<span class="ruby-keyword">when</span> <span class="ruby-constant">RubyProf</span>.<span class="ruby-identifier">const_defined?</span>(<span class="ruby-value">:CPU_TIME</span>) <span class="ruby-operator">&&</span> <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">CPU_TIME</span>
|
236
|
-
<span class="ruby-ivar">@value_scale</span> = <span class="ruby-constant">RubyProf</span>.<span class="ruby-identifier">cpu_frequency</span>
|
237
|
-
<span class="ruby-ivar">@event_specification</span> <span class="ruby-operator"><<</span> <span class="ruby-string">'cpu_time'</span>
|
238
|
-
<span class="ruby-keyword">when</span> <span class="ruby-constant">RubyProf</span>.<span class="ruby-identifier">const_defined?</span>(<span class="ruby-value">:ALLOCATIONS</span>) <span class="ruby-operator">&&</span> <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">ALLOCATIONS</span>
|
239
|
-
<span class="ruby-ivar">@value_scale</span> = <span class="ruby-value">1</span>
|
240
|
-
<span class="ruby-ivar">@event_specification</span> <span class="ruby-operator"><<</span> <span class="ruby-string">'allocations'</span>
|
241
|
-
<span class="ruby-keyword">when</span> <span class="ruby-constant">RubyProf</span>.<span class="ruby-identifier">const_defined?</span>(<span class="ruby-value">:MEMORY</span>) <span class="ruby-operator">&&</span> <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">MEMORY</span>
|
242
|
-
<span class="ruby-ivar">@value_scale</span> = <span class="ruby-value">1</span>
|
243
|
-
<span class="ruby-ivar">@event_specification</span> <span class="ruby-operator"><<</span> <span class="ruby-string">'memory'</span>
|
244
|
-
<span class="ruby-keyword">when</span> <span class="ruby-constant">RubyProf</span>.<span class="ruby-identifier">const_defined?</span>(<span class="ruby-value">:GC_RUNS</span>) <span class="ruby-operator">&&</span> <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">GC_RUNS</span>
|
245
|
-
<span class="ruby-ivar">@value_scale</span> = <span class="ruby-value">1</span>
|
246
|
-
<span class="ruby-ivar">@event_specification</span> <span class="ruby-operator"><<</span> <span class="ruby-string">'gc_runs'</span>
|
247
|
-
<span class="ruby-keyword">when</span> <span class="ruby-constant">RubyProf</span>.<span class="ruby-identifier">const_defined?</span>(<span class="ruby-value">:GC_TIME</span>) <span class="ruby-operator">&&</span> <span class="ruby-constant">RubyProf</span><span class="ruby-operator">::</span><span class="ruby-constant">GC_TIME</span>
|
248
|
-
<span class="ruby-ivar">@value_scale</span> = <span class="ruby-value">1000000</span>
|
249
|
-
<span class="ruby-ivar">@event_specification</span> <span class="ruby-operator"><<</span> <span class="ruby-string">'gc_time'</span>
|
250
|
-
<span class="ruby-keyword">else</span>
|
251
|
-
<span class="ruby-identifier">raise</span> <span class="ruby-node">"Unknown measure mode: #{RubyProf.measure_mode}"</span>
|
252
|
-
<span class="ruby-keyword">end</span>
|
253
|
-
<span class="ruby-keyword">end</span></pre>
|
254
|
-
</div>
|
255
|
-
|
256
|
-
</div>
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
</div>
|
262
|
-
|
263
|
-
|
264
|
-
<div id="method-i-file" class="method-detail ">
|
265
|
-
|
266
|
-
<div class="method-heading">
|
267
|
-
<span class="method-name">file</span><span
|
268
|
-
class="method-args">(method)</span>
|
269
|
-
|
270
|
-
<span class="method-click-advice">click to toggle source</span>
|
271
|
-
|
272
|
-
</div>
|
273
|
-
|
274
|
-
|
275
|
-
<div class="method-description">
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
<div class="method-source-code" id="file-source">
|
283
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 64</span>
|
284
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">file</span>(<span class="ruby-identifier">method</span>)
|
285
|
-
<span class="ruby-constant">File</span>.<span class="ruby-identifier">expand_path</span>(<span class="ruby-identifier">method</span>.<span class="ruby-identifier">source_file</span>)
|
286
|
-
<span class="ruby-keyword">end</span></pre>
|
287
|
-
</div>
|
288
|
-
|
289
|
-
</div>
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
</div>
|
295
|
-
|
296
|
-
|
297
|
-
<div id="method-i-file_name_for_thread" class="method-detail ">
|
298
|
-
|
299
|
-
<div class="method-heading">
|
300
|
-
<span class="method-name">file_name_for_thread</span><span
|
301
|
-
class="method-args">(thread)</span>
|
302
|
-
|
303
|
-
<span class="method-click-advice">click to toggle source</span>
|
304
|
-
|
305
|
-
</div>
|
306
|
-
|
307
|
-
|
308
|
-
<div class="method-description">
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
<div class="method-source-code" id="file_name_for_thread-source">
|
316
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 91</span>
|
317
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">file_name_for_thread</span>(<span class="ruby-identifier">thread</span>)
|
318
|
-
<span class="ruby-keyword">if</span> <span class="ruby-identifier">thread</span>.<span class="ruby-identifier">fiber_id</span> <span class="ruby-operator">==</span> <span class="ruby-constant">Fiber</span>.<span class="ruby-identifier">current</span>.<span class="ruby-identifier">object_id</span>
|
319
|
-
[<span class="ruby-identifier">base_name</span>, <span class="ruby-string">"callgrind.out"</span>, <span class="ruby-identifier">$$</span>].<span class="ruby-identifier">join</span>(<span class="ruby-string">"."</span>)
|
320
|
-
<span class="ruby-keyword">else</span>
|
321
|
-
[<span class="ruby-identifier">base_name</span>, <span class="ruby-string">"callgrind.out"</span>, <span class="ruby-identifier">$$</span>, <span class="ruby-identifier">thread</span>.<span class="ruby-identifier">fiber_id</span>].<span class="ruby-identifier">join</span>(<span class="ruby-string">"."</span>)
|
322
|
-
<span class="ruby-keyword">end</span>
|
323
|
-
<span class="ruby-keyword">end</span></pre>
|
324
|
-
</div>
|
325
|
-
|
326
|
-
</div>
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
</div>
|
332
|
-
|
333
|
-
|
334
|
-
<div id="method-i-file_path_for_thread" class="method-detail ">
|
335
|
-
|
336
|
-
<div class="method-heading">
|
337
|
-
<span class="method-name">file_path_for_thread</span><span
|
338
|
-
class="method-args">(thread)</span>
|
339
|
-
|
340
|
-
<span class="method-click-advice">click to toggle source</span>
|
341
|
-
|
342
|
-
</div>
|
343
|
-
|
344
|
-
|
345
|
-
<div class="method-description">
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
<div class="method-source-code" id="file_path_for_thread-source">
|
353
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 99</span>
|
354
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">file_path_for_thread</span>(<span class="ruby-identifier">thread</span>)
|
355
|
-
<span class="ruby-constant">File</span>.<span class="ruby-identifier">join</span>(<span class="ruby-identifier">path</span>, <span class="ruby-identifier">file_name_for_thread</span>(<span class="ruby-identifier">thread</span>))
|
356
|
-
<span class="ruby-keyword">end</span></pre>
|
357
|
-
</div>
|
358
|
-
|
359
|
-
</div>
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
</div>
|
365
|
-
|
366
|
-
|
367
|
-
<div id="method-i-path" class="method-detail ">
|
368
|
-
|
369
|
-
<div class="method-heading">
|
370
|
-
<span class="method-name">path</span><span
|
371
|
-
class="method-args">()</span>
|
372
|
-
|
373
|
-
<span class="method-click-advice">click to toggle source</span>
|
374
|
-
|
375
|
-
</div>
|
376
|
-
|
377
|
-
|
378
|
-
<div class="method-description">
|
379
|
-
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
|
384
|
-
|
385
|
-
<div class="method-source-code" id="path-source">
|
386
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 77</span>
|
387
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">path</span>
|
388
|
-
<span class="ruby-ivar">@options</span>[<span class="ruby-value">:path</span>] <span class="ruby-operator">||</span> <span class="ruby-string">"."</span>
|
389
|
-
<span class="ruby-keyword">end</span></pre>
|
390
|
-
</div>
|
391
|
-
|
392
|
-
</div>
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
|
397
|
-
</div>
|
398
|
-
|
399
|
-
|
400
|
-
<div id="method-i-print" class="method-detail ">
|
401
|
-
|
402
|
-
<div class="method-heading">
|
403
|
-
<span class="method-name">print</span><span
|
404
|
-
class="method-args">(options = {})</span>
|
405
|
-
|
406
|
-
<span class="method-click-advice">click to toggle source</span>
|
407
|
-
|
408
|
-
</div>
|
409
|
-
|
410
|
-
|
411
|
-
<div class="method-description">
|
412
|
-
|
413
|
-
|
414
|
-
|
415
|
-
|
416
|
-
|
417
|
-
|
418
|
-
<div class="method-source-code" id="print-source">
|
419
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 45</span>
|
420
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">print</span>(<span class="ruby-identifier">options</span> = {})
|
421
|
-
<span class="ruby-identifier">setup_options</span>(<span class="ruby-identifier">options</span>)
|
422
|
-
<span class="ruby-identifier">determine_event_specification_and_value_scale</span>
|
423
|
-
<span class="ruby-identifier">print_threads</span>
|
424
|
-
<span class="ruby-keyword">end</span></pre>
|
425
|
-
</div>
|
426
|
-
|
427
|
-
</div>
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
</div>
|
433
|
-
|
434
|
-
|
435
|
-
<div id="method-i-print_headers" class="method-detail ">
|
436
|
-
|
437
|
-
<div class="method-heading">
|
438
|
-
<span class="method-name">print_headers</span><span
|
439
|
-
class="method-args">(output, thread)</span>
|
440
|
-
|
441
|
-
<span class="method-click-advice">click to toggle source</span>
|
442
|
-
|
443
|
-
</div>
|
444
|
-
|
445
|
-
|
446
|
-
<div class="method-description">
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
|
451
|
-
|
452
|
-
|
453
|
-
<div class="method-source-code" id="print_headers-source">
|
454
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 103</span>
|
455
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">print_headers</span>(<span class="ruby-identifier">output</span>, <span class="ruby-identifier">thread</span>)
|
456
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"#{@event_specification}\n\n"</span>
|
457
|
-
<span class="ruby-comment"># this doesn't work. kcachegrind does not fully support the spec.</span>
|
458
|
-
<span class="ruby-comment"># output << "thread: #{thread.id}\n\n"</span>
|
459
|
-
<span class="ruby-keyword">end</span></pre>
|
460
|
-
</div>
|
461
|
-
|
462
|
-
</div>
|
463
|
-
|
464
|
-
|
465
|
-
|
466
|
-
|
467
|
-
</div>
|
468
|
-
|
469
|
-
|
470
|
-
<div id="method-i-print_method" class="method-detail ">
|
471
|
-
|
472
|
-
<div class="method-heading">
|
473
|
-
<span class="method-name">print_method</span><span
|
474
|
-
class="method-args">(output, method)</span>
|
475
|
-
|
476
|
-
<span class="method-click-advice">click to toggle source</span>
|
477
|
-
|
478
|
-
</div>
|
479
|
-
|
480
|
-
|
481
|
-
<div class="method-description">
|
482
|
-
|
483
|
-
|
484
|
-
|
485
|
-
|
486
|
-
|
487
|
-
|
488
|
-
<div class="method-source-code" id="print_method-source">
|
489
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 109</span>
|
490
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">print_method</span>(<span class="ruby-identifier">output</span>, <span class="ruby-identifier">method</span>)
|
491
|
-
<span class="ruby-comment"># Print out the file and method name</span>
|
492
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"fl=#{file(method)}\n"</span>
|
493
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"fn=#{method_name(method)}\n"</span>
|
494
|
-
|
495
|
-
<span class="ruby-comment"># Now print out the function line number and its self time</span>
|
496
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"#{method.line} #{convert(method.self_time)}\n"</span>
|
497
|
-
|
498
|
-
<span class="ruby-comment"># Now print out all the children methods</span>
|
499
|
-
<span class="ruby-identifier">method</span>.<span class="ruby-identifier">children</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">callee</span><span class="ruby-operator">|</span>
|
500
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"cfl=#{file(callee.target)}\n"</span>
|
501
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"cfn=#{method_name(callee.target)}\n"</span>
|
502
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"calls=#{callee.called} #{callee.line}\n"</span>
|
503
|
-
|
504
|
-
<span class="ruby-comment"># Print out total times here!</span>
|
505
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"#{callee.line} #{convert(callee.total_time)}\n"</span>
|
506
|
-
<span class="ruby-keyword">end</span>
|
507
|
-
<span class="ruby-identifier">output</span> <span class="ruby-operator"><<</span> <span class="ruby-string">"\n"</span>
|
508
|
-
<span class="ruby-keyword">end</span></pre>
|
509
|
-
</div>
|
510
|
-
|
511
|
-
</div>
|
512
|
-
|
513
|
-
|
514
|
-
|
515
|
-
|
516
|
-
</div>
|
517
|
-
|
518
|
-
|
519
|
-
<div id="method-i-print_thread" class="method-detail ">
|
520
|
-
|
521
|
-
<div class="method-heading">
|
522
|
-
<span class="method-name">print_thread</span><span
|
523
|
-
class="method-args">(thread)</span>
|
524
|
-
|
525
|
-
<span class="method-click-advice">click to toggle source</span>
|
526
|
-
|
527
|
-
</div>
|
528
|
-
|
529
|
-
|
530
|
-
<div class="method-description">
|
531
|
-
|
532
|
-
|
533
|
-
|
534
|
-
|
535
|
-
|
536
|
-
|
537
|
-
<div class="method-source-code" id="print_thread-source">
|
538
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 68</span>
|
539
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">print_thread</span>(<span class="ruby-identifier">thread</span>)
|
540
|
-
<span class="ruby-constant">File</span>.<span class="ruby-identifier">open</span>(<span class="ruby-identifier">file_path_for_thread</span>(<span class="ruby-identifier">thread</span>), <span class="ruby-string">"w"</span>) <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">f</span><span class="ruby-operator">|</span>
|
541
|
-
<span class="ruby-identifier">print_headers</span>(<span class="ruby-identifier">f</span>, <span class="ruby-identifier">thread</span>)
|
542
|
-
<span class="ruby-identifier">thread</span>.<span class="ruby-identifier">methods</span>.<span class="ruby-identifier">reverse_each</span> <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">method</span><span class="ruby-operator">|</span>
|
543
|
-
<span class="ruby-identifier">print_method</span>(<span class="ruby-identifier">f</span>, <span class="ruby-identifier">method</span>)
|
544
|
-
<span class="ruby-keyword">end</span>
|
545
|
-
<span class="ruby-keyword">end</span>
|
546
|
-
<span class="ruby-keyword">end</span></pre>
|
547
|
-
</div>
|
548
|
-
|
549
|
-
</div>
|
550
|
-
|
551
|
-
|
552
|
-
|
553
|
-
|
554
|
-
</div>
|
555
|
-
|
556
|
-
|
557
|
-
<div id="method-i-print_threads" class="method-detail ">
|
558
|
-
|
559
|
-
<div class="method-heading">
|
560
|
-
<span class="method-name">print_threads</span><span
|
561
|
-
class="method-args">()</span>
|
562
|
-
|
563
|
-
<span class="method-click-advice">click to toggle source</span>
|
564
|
-
|
565
|
-
</div>
|
566
|
-
|
567
|
-
|
568
|
-
<div class="method-description">
|
569
|
-
|
570
|
-
|
571
|
-
|
572
|
-
|
573
|
-
|
574
|
-
|
575
|
-
<div class="method-source-code" id="print_threads-source">
|
576
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 51</span>
|
577
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">print_threads</span>
|
578
|
-
<span class="ruby-identifier">remove_subsidiary_files_from_previous_profile_runs</span>
|
579
|
-
<span class="ruby-comment"># TODO: merge fibers of a given thread here, instead of relying</span>
|
580
|
-
<span class="ruby-comment"># on the profiler to merge fibers.</span>
|
581
|
-
<span class="ruby-ivar">@result</span>.<span class="ruby-identifier">threads</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">thread</span><span class="ruby-operator">|</span>
|
582
|
-
<span class="ruby-identifier">print_thread</span>(<span class="ruby-identifier">thread</span>)
|
583
|
-
<span class="ruby-keyword">end</span>
|
584
|
-
<span class="ruby-keyword">end</span></pre>
|
585
|
-
</div>
|
586
|
-
|
587
|
-
</div>
|
588
|
-
|
589
|
-
|
590
|
-
|
591
|
-
|
592
|
-
</div>
|
593
|
-
|
594
|
-
|
595
|
-
<div id="method-i-remove_subsidiary_files_from_previous_profile_runs" class="method-detail ">
|
596
|
-
|
597
|
-
<div class="method-heading">
|
598
|
-
<span class="method-name">remove_subsidiary_files_from_previous_profile_runs</span><span
|
599
|
-
class="method-args">()</span>
|
600
|
-
|
601
|
-
<span class="method-click-advice">click to toggle source</span>
|
602
|
-
|
603
|
-
</div>
|
604
|
-
|
605
|
-
|
606
|
-
<div class="method-description">
|
607
|
-
|
608
|
-
|
609
|
-
|
610
|
-
|
611
|
-
|
612
|
-
|
613
|
-
<div class="method-source-code" id="remove_subsidiary_files_from_previous_profile_runs-source">
|
614
|
-
<pre><span class="ruby-comment"># File lib/ruby-prof/printers/call_tree_printer.rb, line 85</span>
|
615
|
-
<span class="ruby-keyword">def</span> <span class="ruby-identifier">remove_subsidiary_files_from_previous_profile_runs</span>
|
616
|
-
<span class="ruby-identifier">pattern</span> = [<span class="ruby-identifier">base_name</span>, <span class="ruby-string">"callgrind.out"</span>, <span class="ruby-identifier">$$</span>, <span class="ruby-string">"*"</span>].<span class="ruby-identifier">join</span>(<span class="ruby-string">"."</span>)
|
617
|
-
<span class="ruby-identifier">files</span> = <span class="ruby-constant">Dir</span>.<span class="ruby-identifier">glob</span>(<span class="ruby-constant">File</span>.<span class="ruby-identifier">join</span>(<span class="ruby-identifier">path</span>, <span class="ruby-identifier">pattern</span>))
|
618
|
-
<span class="ruby-constant">FileUtils</span>.<span class="ruby-identifier">rm_f</span>(<span class="ruby-identifier">files</span>)
|
619
|
-
<span class="ruby-keyword">end</span></pre>
|
620
|
-
</div>
|
621
|
-
|
622
|
-
</div>
|
623
|
-
|
624
|
-
|
625
|
-
|
626
|
-
|
627
|
-
</div>
|
628
|
-
|
629
|
-
|
630
|
-
</section>
|
631
|
-
|
632
|
-
</section>
|
633
|
-
</main>
|
634
|
-
|
635
|
-
|
636
|
-
<footer id="validator-badges" role="contentinfo">
|
637
|
-
<p><a href="http://validator.w3.org/check/referer">Validate</a>
|
638
|
-
<p>Generated by <a href="http://docs.seattlerb.org/rdoc/">RDoc</a> 4.2.2.
|
639
|
-
<p>Based on <a href="http://deveiate.org/projects/Darkfish-RDoc/">Darkfish</a> by <a href="http://deveiate.org">Michael Granger</a>.
|
640
|
-
</footer>
|
641
|
-
|