ruby-prof 0.17.0 → 0.18.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (185) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGES +500 -482
  3. data/LICENSE +24 -24
  4. data/README.rdoc +487 -485
  5. data/Rakefile +113 -113
  6. data/bin/ruby-prof +345 -345
  7. data/bin/ruby-prof-check-trace +45 -45
  8. data/examples/flat.txt +50 -50
  9. data/examples/graph.dot +84 -84
  10. data/examples/graph.html +823 -823
  11. data/examples/graph.txt +139 -139
  12. data/examples/multi.flat.txt +23 -23
  13. data/examples/multi.graph.html +760 -760
  14. data/examples/multi.grind.dat +114 -114
  15. data/examples/multi.stack.html +547 -547
  16. data/examples/stack.html +547 -547
  17. data/ext/ruby_prof/extconf.rb +68 -68
  18. data/ext/ruby_prof/rp_call_info.c +425 -425
  19. data/ext/ruby_prof/rp_call_info.h +53 -53
  20. data/ext/ruby_prof/rp_measure.c +40 -40
  21. data/ext/ruby_prof/rp_measure.h +45 -45
  22. data/ext/ruby_prof/rp_measure_allocations.c +76 -76
  23. data/ext/ruby_prof/rp_measure_cpu_time.c +136 -136
  24. data/ext/ruby_prof/rp_measure_gc_runs.c +73 -73
  25. data/ext/ruby_prof/rp_measure_gc_time.c +60 -60
  26. data/ext/ruby_prof/rp_measure_memory.c +77 -77
  27. data/ext/ruby_prof/rp_measure_process_time.c +71 -71
  28. data/ext/ruby_prof/rp_measure_wall_time.c +45 -45
  29. data/ext/ruby_prof/rp_method.c +630 -636
  30. data/ext/ruby_prof/rp_method.h +75 -75
  31. data/ext/ruby_prof/rp_stack.c +173 -173
  32. data/ext/ruby_prof/rp_stack.h +63 -63
  33. data/ext/ruby_prof/rp_thread.c +277 -276
  34. data/ext/ruby_prof/rp_thread.h +27 -27
  35. data/ext/ruby_prof/ruby_prof.c +794 -774
  36. data/ext/ruby_prof/ruby_prof.h +60 -59
  37. data/ext/ruby_prof/vc/ruby_prof.sln +20 -21
  38. data/ext/ruby_prof/vc/{ruby_prof_20.vcxproj → ruby_prof.vcxproj} +31 -0
  39. data/lib/ruby-prof.rb +68 -68
  40. data/lib/ruby-prof/aggregate_call_info.rb +76 -76
  41. data/lib/ruby-prof/assets/call_stack_printer.css.html +116 -116
  42. data/lib/ruby-prof/assets/call_stack_printer.js.html +384 -384
  43. data/lib/ruby-prof/call_info.rb +115 -115
  44. data/lib/ruby-prof/call_info_visitor.rb +40 -40
  45. data/lib/ruby-prof/compatibility.rb +179 -178
  46. data/lib/ruby-prof/method_info.rb +121 -121
  47. data/lib/ruby-prof/printers/abstract_printer.rb +104 -103
  48. data/lib/ruby-prof/printers/call_info_printer.rb +41 -41
  49. data/lib/ruby-prof/printers/call_stack_printer.rb +265 -265
  50. data/lib/ruby-prof/printers/call_tree_printer.rb +143 -143
  51. data/lib/ruby-prof/printers/dot_printer.rb +132 -132
  52. data/lib/ruby-prof/printers/flat_printer.rb +70 -70
  53. data/lib/ruby-prof/printers/flat_printer_with_line_numbers.rb +83 -83
  54. data/lib/ruby-prof/printers/graph_html_printer.rb +249 -249
  55. data/lib/ruby-prof/printers/graph_printer.rb +116 -116
  56. data/lib/ruby-prof/printers/multi_printer.rb +84 -84
  57. data/lib/ruby-prof/profile.rb +26 -26
  58. data/lib/ruby-prof/profile/exclude_common_methods.rb +207 -201
  59. data/lib/ruby-prof/profile/legacy_method_elimination.rb +50 -49
  60. data/lib/ruby-prof/rack.rb +174 -174
  61. data/lib/ruby-prof/task.rb +147 -147
  62. data/lib/ruby-prof/thread.rb +35 -35
  63. data/lib/ruby-prof/version.rb +3 -3
  64. data/lib/unprof.rb +10 -10
  65. data/ruby-prof.gemspec +58 -58
  66. data/test/abstract_printer_test.rb +53 -0
  67. data/test/aggregate_test.rb +136 -136
  68. data/test/basic_test.rb +128 -128
  69. data/test/block_test.rb +74 -74
  70. data/test/call_info_test.rb +78 -78
  71. data/test/call_info_visitor_test.rb +31 -31
  72. data/test/duplicate_names_test.rb +32 -32
  73. data/test/dynamic_method_test.rb +55 -55
  74. data/test/enumerable_test.rb +21 -21
  75. data/test/exceptions_test.rb +24 -16
  76. data/test/exclude_methods_test.rb +146 -146
  77. data/test/exclude_threads_test.rb +53 -53
  78. data/test/fiber_test.rb +79 -79
  79. data/test/issue137_test.rb +63 -63
  80. data/test/line_number_test.rb +80 -80
  81. data/test/measure_allocations_test.rb +26 -26
  82. data/test/measure_cpu_time_test.rb +212 -213
  83. data/test/measure_gc_runs_test.rb +32 -32
  84. data/test/measure_gc_time_test.rb +36 -36
  85. data/test/measure_memory_test.rb +33 -33
  86. data/test/measure_process_time_test.rb +61 -63
  87. data/test/measure_wall_time_test.rb +255 -255
  88. data/test/method_elimination_test.rb +84 -84
  89. data/test/module_test.rb +45 -45
  90. data/test/multi_printer_test.rb +104 -104
  91. data/test/no_method_class_test.rb +15 -15
  92. data/test/pause_resume_test.rb +166 -166
  93. data/test/prime.rb +54 -54
  94. data/test/printers_test.rb +275 -275
  95. data/test/printing_recursive_graph_test.rb +127 -127
  96. data/test/rack_test.rb +157 -157
  97. data/test/recursive_test.rb +215 -215
  98. data/test/singleton_test.rb +38 -38
  99. data/test/stack_printer_test.rb +77 -78
  100. data/test/stack_test.rb +138 -138
  101. data/test/start_stop_test.rb +112 -112
  102. data/test/test_helper.rb +267 -275
  103. data/test/thread_test.rb +187 -187
  104. data/test/unique_call_path_test.rb +202 -202
  105. data/test/yarv_test.rb +55 -55
  106. metadata +17 -96
  107. data/doc/LICENSE.html +0 -115
  108. data/doc/README_rdoc.html +0 -637
  109. data/doc/Rack.html +0 -96
  110. data/doc/Rack/RubyProf.html +0 -233
  111. data/doc/Rack/RubyProf/RackProfiler.html +0 -343
  112. data/doc/RubyProf.html +0 -974
  113. data/doc/RubyProf/AbstractPrinter.html +0 -625
  114. data/doc/RubyProf/AggregateCallInfo.html +0 -552
  115. data/doc/RubyProf/CallInfo.html +0 -579
  116. data/doc/RubyProf/CallInfoPrinter.html +0 -121
  117. data/doc/RubyProf/CallInfoVisitor.html +0 -199
  118. data/doc/RubyProf/CallStackPrinter.html +0 -1127
  119. data/doc/RubyProf/CallTreePrinter.html +0 -725
  120. data/doc/RubyProf/Cmd.html +0 -637
  121. data/doc/RubyProf/DeprecationWarnings.html +0 -148
  122. data/doc/RubyProf/DotPrinter.html +0 -258
  123. data/doc/RubyProf/FlatPrinter.html +0 -164
  124. data/doc/RubyProf/FlatPrinterWithLineNumbers.html +0 -210
  125. data/doc/RubyProf/GraphHtmlPrinter.html +0 -558
  126. data/doc/RubyProf/GraphPrinter.html +0 -140
  127. data/doc/RubyProf/MethodInfo.html +0 -676
  128. data/doc/RubyProf/MultiPrinter.html +0 -574
  129. data/doc/RubyProf/Profile.html +0 -908
  130. data/doc/RubyProf/Profile/ExcludeCommonMethods.html +0 -411
  131. data/doc/RubyProf/Profile/LegacyMethodElimination.html +0 -158
  132. data/doc/RubyProf/ProfileTask.html +0 -491
  133. data/doc/RubyProf/Thread.html +0 -275
  134. data/doc/created.rid +0 -33
  135. data/doc/css/fonts.css +0 -167
  136. data/doc/css/rdoc.css +0 -590
  137. data/doc/examples/flat_txt.html +0 -139
  138. data/doc/examples/graph_html.html +0 -910
  139. data/doc/examples/graph_txt.html +0 -248
  140. data/doc/fonts/Lato-Light.ttf +0 -0
  141. data/doc/fonts/Lato-LightItalic.ttf +0 -0
  142. data/doc/fonts/Lato-Regular.ttf +0 -0
  143. data/doc/fonts/Lato-RegularItalic.ttf +0 -0
  144. data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
  145. data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
  146. data/doc/images/add.png +0 -0
  147. data/doc/images/arrow_up.png +0 -0
  148. data/doc/images/brick.png +0 -0
  149. data/doc/images/brick_link.png +0 -0
  150. data/doc/images/bug.png +0 -0
  151. data/doc/images/bullet_black.png +0 -0
  152. data/doc/images/bullet_toggle_minus.png +0 -0
  153. data/doc/images/bullet_toggle_plus.png +0 -0
  154. data/doc/images/date.png +0 -0
  155. data/doc/images/delete.png +0 -0
  156. data/doc/images/find.png +0 -0
  157. data/doc/images/loadingAnimation.gif +0 -0
  158. data/doc/images/macFFBgHack.png +0 -0
  159. data/doc/images/package.png +0 -0
  160. data/doc/images/page_green.png +0 -0
  161. data/doc/images/page_white_text.png +0 -0
  162. data/doc/images/page_white_width.png +0 -0
  163. data/doc/images/plugin.png +0 -0
  164. data/doc/images/ruby.png +0 -0
  165. data/doc/images/tag_blue.png +0 -0
  166. data/doc/images/tag_green.png +0 -0
  167. data/doc/images/transparent.png +0 -0
  168. data/doc/images/wrench.png +0 -0
  169. data/doc/images/wrench_orange.png +0 -0
  170. data/doc/images/zoom.png +0 -0
  171. data/doc/index.html +0 -666
  172. data/doc/js/darkfish.js +0 -161
  173. data/doc/js/jquery.js +0 -4
  174. data/doc/js/navigation.js +0 -142
  175. data/doc/js/navigation.js.gz +0 -0
  176. data/doc/js/search.js +0 -109
  177. data/doc/js/search_index.js +0 -1
  178. data/doc/js/search_index.js.gz +0 -0
  179. data/doc/js/searcher.js +0 -229
  180. data/doc/js/searcher.js.gz +0 -0
  181. data/doc/table_of_contents.html +0 -1052
  182. data/examples/cachegrind.out.1 +0 -114
  183. data/examples/cachegrind.out.1.32313213 +0 -114
  184. data/ext/ruby_prof/vc/ruby_prof_18.vcxproj +0 -108
  185. data/ext/ruby_prof/vc/ruby_prof_19.vcxproj +0 -110
@@ -1,116 +1,116 @@
1
- # encoding: utf-8
2
-
3
- module RubyProf
4
- # Generates graph[link:files/examples/graph_txt.html] profile reports as text.
5
- # To use the graph printer:
6
- #
7
- # result = RubyProf.profile do
8
- # [code to profile]
9
- # end
10
- #
11
- # printer = RubyProf::GraphPrinter.new(result)
12
- # printer.print(STDOUT, {})
13
- #
14
- # The constructor takes two arguments. See the README
15
-
16
- class GraphPrinter < AbstractPrinter
17
- PERCENTAGE_WIDTH = 8
18
- TIME_WIDTH = 11
19
- CALL_WIDTH = 17
20
-
21
- private
22
-
23
- def print_header(thread)
24
- @output << "Measure Mode: %s\n" % RubyProf.measure_mode_string
25
- @output << "Thread ID: #{thread.id}\n"
26
- @output << "Fiber ID: #{thread.fiber_id}\n" unless thread.id == thread.fiber_id
27
- @output << "Total Time: #{thread.total_time}\n"
28
- @output << "Sort by: #{sort_method}\n"
29
- @output << "\n"
30
-
31
- # 1 is for % sign
32
- @output << sprintf("%#{PERCENTAGE_WIDTH}s", "%total")
33
- @output << sprintf("%#{PERCENTAGE_WIDTH}s", "%self")
34
- @output << sprintf("%#{TIME_WIDTH}s", "total")
35
- @output << sprintf("%#{TIME_WIDTH}s", "self")
36
- @output << sprintf("%#{TIME_WIDTH}s", "wait")
37
- @output << sprintf("%#{TIME_WIDTH}s", "child")
38
- @output << sprintf("%#{CALL_WIDTH}s", "calls")
39
- @output << " name"
40
- @output << "\n"
41
- end
42
-
43
- def print_methods(thread)
44
- total_time = thread.total_time
45
- # Sort methods from longest to shortest total time
46
- methods = thread.methods.sort_by(&sort_method)
47
-
48
- # Print each method in total time order
49
- methods.reverse_each do |method|
50
- total_percentage = (method.total_time/total_time) * 100
51
- next if total_percentage < min_percent
52
-
53
- self_percentage = (method.self_time/total_time) * 100
54
-
55
- @output << "-" * 80 << "\n"
56
- print_parents(thread, method)
57
-
58
- # 1 is for % sign
59
- @output << sprintf("%#{PERCENTAGE_WIDTH-1}.2f%%", total_percentage)
60
- @output << sprintf("%#{PERCENTAGE_WIDTH-1}.2f%%", self_percentage)
61
- @output << sprintf("%#{TIME_WIDTH}.3f", method.total_time)
62
- @output << sprintf("%#{TIME_WIDTH}.3f", method.self_time)
63
- @output << sprintf("%#{TIME_WIDTH}.3f", method.wait_time)
64
- @output << sprintf("%#{TIME_WIDTH}.3f", method.children_time)
65
- @output << sprintf("%#{CALL_WIDTH}i", method.called)
66
- @output << sprintf(" %s", method.recursive? ? "*" : " ")
67
- @output << sprintf("%s", method_name(method))
68
- if print_file
69
- @output << sprintf(" %s:%s", method.source_file, method.line)
70
- end
71
- @output << "\n"
72
-
73
- print_children(method)
74
- end
75
- end
76
-
77
- def print_parents(thread, method)
78
- method.aggregate_parents.sort_by(&:total_time).each do |caller|
79
- next unless caller.parent
80
- @output << " " * 2 * PERCENTAGE_WIDTH
81
- @output << sprintf("%#{TIME_WIDTH}.3f", caller.total_time)
82
- @output << sprintf("%#{TIME_WIDTH}.3f", caller.self_time)
83
- @output << sprintf("%#{TIME_WIDTH}.3f", caller.wait_time)
84
- @output << sprintf("%#{TIME_WIDTH}.3f", caller.children_time)
85
-
86
- call_called = "#{caller.called}/#{method.called}"
87
- @output << sprintf("%#{CALL_WIDTH}s", call_called)
88
- @output << sprintf(" %s", caller.parent.target.full_name)
89
- @output << "\n"
90
- end
91
- end
92
-
93
- def print_children(method)
94
- method.aggregate_children.sort_by(&:total_time).reverse.each do |child|
95
- # Get children method
96
-
97
- @output << " " * 2 * PERCENTAGE_WIDTH
98
-
99
- @output << sprintf("%#{TIME_WIDTH}.3f", child.total_time)
100
- @output << sprintf("%#{TIME_WIDTH}.3f", child.self_time)
101
- @output << sprintf("%#{TIME_WIDTH}.3f", child.wait_time)
102
- @output << sprintf("%#{TIME_WIDTH}.3f", child.children_time)
103
-
104
- call_called = "#{child.called}/#{child.target.called}"
105
- @output << sprintf("%#{CALL_WIDTH}s", call_called)
106
- @output << sprintf(" %s", child.target.full_name)
107
- @output << "\n"
108
- end
109
- end
110
-
111
- def print_footer(thread)
112
- @output << "\n"
113
- @output << "* indicates recursively called methods\n"
114
- end
115
- end
116
- end
1
+ # encoding: utf-8
2
+
3
+ module RubyProf
4
+ # Generates graph[link:files/examples/graph_txt.html] profile reports as text.
5
+ # To use the graph printer:
6
+ #
7
+ # result = RubyProf.profile do
8
+ # [code to profile]
9
+ # end
10
+ #
11
+ # printer = RubyProf::GraphPrinter.new(result)
12
+ # printer.print(STDOUT, {})
13
+ #
14
+ # The constructor takes two arguments. See the README
15
+
16
+ class GraphPrinter < AbstractPrinter
17
+ PERCENTAGE_WIDTH = 8
18
+ TIME_WIDTH = 11
19
+ CALL_WIDTH = 17
20
+
21
+ private
22
+
23
+ def print_header(thread)
24
+ @output << "Measure Mode: %s\n" % RubyProf.measure_mode_string
25
+ @output << "Thread ID: #{thread.id}\n"
26
+ @output << "Fiber ID: #{thread.fiber_id}\n" unless thread.id == thread.fiber_id
27
+ @output << "Total Time: #{thread.total_time}\n"
28
+ @output << "Sort by: #{sort_method}\n"
29
+ @output << "\n"
30
+
31
+ # 1 is for % sign
32
+ @output << sprintf("%#{PERCENTAGE_WIDTH}s", "%total")
33
+ @output << sprintf("%#{PERCENTAGE_WIDTH}s", "%self")
34
+ @output << sprintf("%#{TIME_WIDTH}s", "total")
35
+ @output << sprintf("%#{TIME_WIDTH}s", "self")
36
+ @output << sprintf("%#{TIME_WIDTH}s", "wait")
37
+ @output << sprintf("%#{TIME_WIDTH}s", "child")
38
+ @output << sprintf("%#{CALL_WIDTH}s", "calls")
39
+ @output << " name"
40
+ @output << "\n"
41
+ end
42
+
43
+ def print_methods(thread)
44
+ total_time = thread.total_time
45
+ # Sort methods from longest to shortest total time
46
+ methods = thread.methods.sort_by(&sort_method)
47
+
48
+ # Print each method in total time order
49
+ methods.reverse_each do |method|
50
+ total_percentage = (method.total_time/total_time) * 100
51
+ next if total_percentage < min_percent
52
+
53
+ self_percentage = (method.self_time/total_time) * 100
54
+
55
+ @output << "-" * 80 << "\n"
56
+ print_parents(thread, method)
57
+
58
+ # 1 is for % sign
59
+ @output << sprintf("%#{PERCENTAGE_WIDTH-1}.2f%%", total_percentage)
60
+ @output << sprintf("%#{PERCENTAGE_WIDTH-1}.2f%%", self_percentage)
61
+ @output << sprintf("%#{TIME_WIDTH}.3f", method.total_time)
62
+ @output << sprintf("%#{TIME_WIDTH}.3f", method.self_time)
63
+ @output << sprintf("%#{TIME_WIDTH}.3f", method.wait_time)
64
+ @output << sprintf("%#{TIME_WIDTH}.3f", method.children_time)
65
+ @output << sprintf("%#{CALL_WIDTH}i", method.called)
66
+ @output << sprintf(" %s", method.recursive? ? "*" : " ")
67
+ @output << sprintf("%s", method_name(method))
68
+ if print_file
69
+ @output << sprintf(" %s:%s", method.source_file, method.line)
70
+ end
71
+ @output << "\n"
72
+
73
+ print_children(method)
74
+ end
75
+ end
76
+
77
+ def print_parents(thread, method)
78
+ method.aggregate_parents.sort_by(&:total_time).each do |caller|
79
+ next unless caller.parent
80
+ @output << " " * 2 * PERCENTAGE_WIDTH
81
+ @output << sprintf("%#{TIME_WIDTH}.3f", caller.total_time)
82
+ @output << sprintf("%#{TIME_WIDTH}.3f", caller.self_time)
83
+ @output << sprintf("%#{TIME_WIDTH}.3f", caller.wait_time)
84
+ @output << sprintf("%#{TIME_WIDTH}.3f", caller.children_time)
85
+
86
+ call_called = "#{caller.called}/#{method.called}"
87
+ @output << sprintf("%#{CALL_WIDTH}s", call_called)
88
+ @output << sprintf(" %s", caller.parent.target.full_name)
89
+ @output << "\n"
90
+ end
91
+ end
92
+
93
+ def print_children(method)
94
+ method.aggregate_children.sort_by(&:total_time).reverse.each do |child|
95
+ # Get children method
96
+
97
+ @output << " " * 2 * PERCENTAGE_WIDTH
98
+
99
+ @output << sprintf("%#{TIME_WIDTH}.3f", child.total_time)
100
+ @output << sprintf("%#{TIME_WIDTH}.3f", child.self_time)
101
+ @output << sprintf("%#{TIME_WIDTH}.3f", child.wait_time)
102
+ @output << sprintf("%#{TIME_WIDTH}.3f", child.children_time)
103
+
104
+ call_called = "#{child.called}/#{child.target.called}"
105
+ @output << sprintf("%#{CALL_WIDTH}s", call_called)
106
+ @output << sprintf(" %s", child.target.full_name)
107
+ @output << "\n"
108
+ end
109
+ end
110
+
111
+ def print_footer(thread)
112
+ @output << "\n"
113
+ @output << "* indicates recursively called methods\n"
114
+ end
115
+ end
116
+ end
@@ -1,84 +1,84 @@
1
- # encoding: utf-8
2
-
3
- module RubyProf
4
- # Helper class to simplify printing profiles of several types from
5
- # one profiling run. Currently prints a flat profile, a callgrind
6
- # profile, a call stack profile and a graph profile.
7
- class MultiPrinter
8
- def initialize(result, printers = [:stack, :graph, :tree, :flat])
9
- @stack_printer = CallStackPrinter.new(result) if printers.include?(:stack)
10
- @graph_printer = GraphHtmlPrinter.new(result) if printers.include?(:graph)
11
- @tree_printer = CallTreePrinter.new(result) if printers.include?(:tree)
12
- @flat_printer = FlatPrinter.new(result) if printers.include?(:flat)
13
- end
14
-
15
- def self.needs_dir?
16
- true
17
- end
18
-
19
- # create profile files under options[:path] or the current
20
- # directory. options[:profile] is used as the base name for the
21
- # pofile file, defaults to "profile".
22
- def print(options)
23
- validate_print_params(options)
24
-
25
- @profile = options.delete(:profile) || "profile"
26
- @directory = options.delete(:path) || File.expand_path(".")
27
-
28
- print_to_stack(options) if @stack_printer
29
- print_to_graph(options) if @graph_printer
30
- print_to_tree(options) if @tree_printer
31
- print_to_flat(options) if @flat_printer
32
- end
33
-
34
- # the name of the call stack profile file
35
- def stack_profile
36
- "#{@directory}/#{@profile}.stack.html"
37
- end
38
-
39
- # the name of the graph profile file
40
- def graph_profile
41
- "#{@directory}/#{@profile}.graph.html"
42
- end
43
-
44
- # the name of the callgrind profile file
45
- def tree_profile
46
- "#{@directory}/#{@profile}.callgrind.out.#{$$}"
47
- end
48
-
49
- # the name of the flat profile file
50
- def flat_profile
51
- "#{@directory}/#{@profile}.flat.txt"
52
- end
53
-
54
- def print_to_stack(options)
55
- File.open(stack_profile, "w") do |f|
56
- @stack_printer.print(f, options.merge(:graph => "#{@profile}.graph.html"))
57
- end
58
- end
59
-
60
- def print_to_graph(options)
61
- File.open(graph_profile, "w") do |f|
62
- @graph_printer.print(f, options)
63
- end
64
- end
65
-
66
- def print_to_tree(options)
67
- @tree_printer.print(options.merge(:path => @directory, :profile => @profile))
68
- end
69
-
70
- def print_to_flat(options)
71
- File.open(flat_profile, "w") do |f|
72
- @flat_printer.print(f, options)
73
- end
74
- end
75
-
76
- def validate_print_params(options)
77
- if options.is_a?(IO)
78
- raise ArgumentError, "#{self.class.name}#print cannot print to IO objects"
79
- elsif !options.is_a?(Hash)
80
- raise ArgumentError, "#{self.class.name}#print requires an options hash"
81
- end
82
- end
83
- end
84
- end
1
+ # encoding: utf-8
2
+
3
+ module RubyProf
4
+ # Helper class to simplify printing profiles of several types from
5
+ # one profiling run. Currently prints a flat profile, a callgrind
6
+ # profile, a call stack profile and a graph profile.
7
+ class MultiPrinter
8
+ def initialize(result, printers = [:stack, :graph, :tree, :flat])
9
+ @stack_printer = CallStackPrinter.new(result) if printers.include?(:stack)
10
+ @graph_printer = GraphHtmlPrinter.new(result) if printers.include?(:graph)
11
+ @tree_printer = CallTreePrinter.new(result) if printers.include?(:tree)
12
+ @flat_printer = FlatPrinter.new(result) if printers.include?(:flat)
13
+ end
14
+
15
+ def self.needs_dir?
16
+ true
17
+ end
18
+
19
+ # create profile files under options[:path] or the current
20
+ # directory. options[:profile] is used as the base name for the
21
+ # pofile file, defaults to "profile".
22
+ def print(options)
23
+ validate_print_params(options)
24
+
25
+ @profile = options.delete(:profile) || "profile"
26
+ @directory = options.delete(:path) || File.expand_path(".")
27
+
28
+ print_to_stack(options) if @stack_printer
29
+ print_to_graph(options) if @graph_printer
30
+ print_to_tree(options) if @tree_printer
31
+ print_to_flat(options) if @flat_printer
32
+ end
33
+
34
+ # the name of the call stack profile file
35
+ def stack_profile
36
+ "#{@directory}/#{@profile}.stack.html"
37
+ end
38
+
39
+ # the name of the graph profile file
40
+ def graph_profile
41
+ "#{@directory}/#{@profile}.graph.html"
42
+ end
43
+
44
+ # the name of the callgrind profile file
45
+ def tree_profile
46
+ "#{@directory}/#{@profile}.callgrind.out.#{$$}"
47
+ end
48
+
49
+ # the name of the flat profile file
50
+ def flat_profile
51
+ "#{@directory}/#{@profile}.flat.txt"
52
+ end
53
+
54
+ def print_to_stack(options)
55
+ File.open(stack_profile, "w") do |f|
56
+ @stack_printer.print(f, options.merge(:graph => "#{@profile}.graph.html"))
57
+ end
58
+ end
59
+
60
+ def print_to_graph(options)
61
+ File.open(graph_profile, "w") do |f|
62
+ @graph_printer.print(f, options)
63
+ end
64
+ end
65
+
66
+ def print_to_tree(options)
67
+ @tree_printer.print(options.merge(:path => @directory, :profile => @profile))
68
+ end
69
+
70
+ def print_to_flat(options)
71
+ File.open(flat_profile, "w") do |f|
72
+ @flat_printer.print(f, options)
73
+ end
74
+ end
75
+
76
+ def validate_print_params(options)
77
+ if options.is_a?(IO)
78
+ raise ArgumentError, "#{self.class.name}#print cannot print to IO objects"
79
+ elsif !options.is_a?(Hash)
80
+ raise ArgumentError, "#{self.class.name}#print requires an options hash"
81
+ end
82
+ end
83
+ end
84
+ end
@@ -1,26 +1,26 @@
1
- # encoding: utf-8
2
-
3
- require 'ruby-prof/profile/exclude_common_methods'
4
- require 'ruby-prof/profile/legacy_method_elimination'
5
-
6
- module RubyProf
7
- class Profile
8
- include LegacyMethodElimination
9
-
10
- # Hides methods that, when represented as a call graph, have
11
- # extremely large in and out degrees and make navigation impossible.
12
- def exclude_common_methods!
13
- ExcludeCommonMethods.apply!(self)
14
- end
15
-
16
- def exclude_methods!(mod, *method_or_methods)
17
- [method_or_methods].flatten.each do |name|
18
- exclude_method!(mod, name)
19
- end
20
- end
21
-
22
- def exclude_singleton_methods!(mod, *method_or_methods)
23
- exclude_methods!(mod.singleton_class, *method_or_methods)
24
- end
25
- end
26
- end
1
+ # encoding: utf-8
2
+
3
+ require 'ruby-prof/profile/exclude_common_methods'
4
+ require 'ruby-prof/profile/legacy_method_elimination'
5
+
6
+ module RubyProf
7
+ class Profile
8
+ include LegacyMethodElimination
9
+
10
+ # Hides methods that, when represented as a call graph, have
11
+ # extremely large in and out degrees and make navigation impossible.
12
+ def exclude_common_methods!
13
+ ExcludeCommonMethods.apply!(self)
14
+ end
15
+
16
+ def exclude_methods!(mod, *method_or_methods)
17
+ [method_or_methods].flatten.each do |name|
18
+ exclude_method!(mod, name)
19
+ end
20
+ end
21
+
22
+ def exclude_singleton_methods!(mod, *method_or_methods)
23
+ exclude_methods!(mod.singleton_class, *method_or_methods)
24
+ end
25
+ end
26
+ end