test-prof 0.1.0.beta4 → 0.1.0.pre2

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.
Files changed (81) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +10 -0
  3. data/.rspec +2 -0
  4. data/.rubocop.yml +69 -0
  5. data/.travis.yml +5 -0
  6. data/Gemfile +4 -0
  7. data/README.md +2 -16
  8. data/Rakefile +8 -0
  9. data/bin/setup +8 -0
  10. data/circle.yml +11 -0
  11. data/guides/any_fixture.md +1 -1
  12. data/guides/ruby_prof.md +0 -2
  13. data/guides/stack_prof.md +1 -5
  14. data/lib/test_prof.rb +6 -31
  15. data/lib/test_prof/event_prof.rb +4 -2
  16. data/lib/test_prof/event_prof/custom_events.rb +3 -3
  17. data/lib/test_prof/event_prof/custom_events/factory_create.rb +9 -11
  18. data/lib/test_prof/event_prof/custom_events/sidekiq_inline.rb +9 -11
  19. data/lib/test_prof/event_prof/custom_events/sidekiq_jobs.rb +11 -13
  20. data/lib/test_prof/event_prof/rspec.rb +1 -5
  21. data/lib/test_prof/factory_doctor.rb +9 -11
  22. data/lib/test_prof/factory_doctor/rspec.rb +3 -5
  23. data/lib/test_prof/ruby_prof.rb +12 -6
  24. data/lib/test_prof/stack_prof.rb +7 -14
  25. data/lib/test_prof/version.rb +1 -1
  26. data/spec/integrations/any_fixture_spec.rb +11 -0
  27. data/spec/integrations/before_all_spec.rb +11 -0
  28. data/spec/integrations/event_prof_spec.rb +100 -0
  29. data/spec/integrations/factory_doctor_spec.rb +20 -0
  30. data/spec/integrations/fixtures/rspec/any_fixture_fixture.rb +37 -0
  31. data/spec/integrations/fixtures/rspec/before_all_fixture.rb +32 -0
  32. data/spec/integrations/fixtures/rspec/event_prof_factory_create_fixture.rb +23 -0
  33. data/spec/integrations/fixtures/rspec/event_prof_fixture.rb +51 -0
  34. data/spec/integrations/fixtures/rspec/event_prof_sidekiq_fixture.rb +54 -0
  35. data/spec/integrations/fixtures/rspec/factory_doctor_fixture.rb +33 -0
  36. data/spec/spec_helper.rb +38 -0
  37. data/spec/support/ar_models.rb +43 -0
  38. data/spec/support/instrumenter_stub.rb +19 -0
  39. data/spec/support/integration_helpers.rb +13 -0
  40. data/spec/support/transactional_context.rb +11 -0
  41. data/spec/test_prof/any_fixture_spec.rb +66 -0
  42. data/spec/test_prof/event_prof_spec.rb +138 -0
  43. data/spec/test_prof/ext/float_duration_spec.rb +12 -0
  44. data/spec/test_prof/factory_doctor_spec.rb +84 -0
  45. data/spec/test_prof/ruby_prof_spec.rb +109 -0
  46. data/spec/test_prof/stack_prof_spec.rb +73 -0
  47. data/spec/test_prof_spec.rb +23 -0
  48. data/test-prof.gemspec +35 -0
  49. metadata +34 -49
  50. data/CHANGELOG.md +0 -7
  51. data/assets/flamegraph.demo.html +0 -173
  52. data/assets/flamegraph.template.html +0 -196
  53. data/assets/src/d3-tip.js +0 -352
  54. data/assets/src/d3-tip.min.js +0 -1
  55. data/assets/src/d3.flameGraph.css +0 -92
  56. data/assets/src/d3.flameGraph.js +0 -459
  57. data/assets/src/d3.flameGraph.min.css +0 -1
  58. data/assets/src/d3.flameGraph.min.js +0 -1
  59. data/assets/src/d3.v4.min.js +0 -8
  60. data/guides/factory_default.md +0 -109
  61. data/guides/factory_prof.md +0 -85
  62. data/guides/rspec_stamp.md +0 -53
  63. data/guides/rubocop.md +0 -48
  64. data/guides/tag_prof.md +0 -52
  65. data/guides/tests_sampling.md +0 -24
  66. data/lib/test_prof/cops/rspec/aggregate_failures.rb +0 -140
  67. data/lib/test_prof/factory_default.rb +0 -58
  68. data/lib/test_prof/factory_default/factory_girl_patch.rb +0 -22
  69. data/lib/test_prof/factory_prof.rb +0 -140
  70. data/lib/test_prof/factory_prof/factory_girl_patch.rb +0 -12
  71. data/lib/test_prof/factory_prof/printers/flamegraph.rb +0 -71
  72. data/lib/test_prof/factory_prof/printers/simple.rb +0 -28
  73. data/lib/test_prof/recipes/minitest/sample.rb +0 -29
  74. data/lib/test_prof/recipes/rspec/factory_default.rb +0 -9
  75. data/lib/test_prof/recipes/rspec/sample.rb +0 -13
  76. data/lib/test_prof/rspec_stamp.rb +0 -135
  77. data/lib/test_prof/rspec_stamp/parser.rb +0 -103
  78. data/lib/test_prof/rspec_stamp/rspec.rb +0 -95
  79. data/lib/test_prof/rubocop.rb +0 -3
  80. data/lib/test_prof/tag_prof.rb +0 -8
  81. data/lib/test_prof/tag_prof/rspec.rb +0 -84
@@ -1 +0,0 @@
1
- !function(t,e){if("function"==typeof define&&define.amd)define(["d3-collection","d3-selection"],e);else if("object"==typeof module&&module.exports){var n=require("d3-collection"),r=require("d3-selection");module.exports=e(n,r)}else{var o=t.d3;t.d3.tip=e(o,o)}}(this,function(t,e){return function(){function n(t){(C=m(t))&&(H=C.createSVGPoint(),b.appendChild(E))}function r(){return"n"}function o(){return[0,0]}function l(){return" "}function i(){var t=x();return{top:t.n.y-E.offsetHeight,left:t.n.x-E.offsetWidth/2}}function f(){var t=x();return{top:t.s.y,left:t.s.x-E.offsetWidth/2}}function u(){var t=x();return{top:t.e.y-E.offsetHeight/2,left:t.e.x}}function s(){var t=x();return{top:t.w.y-E.offsetHeight/2,left:t.w.x-E.offsetWidth}}function a(){var t=x();return{top:t.nw.y-E.offsetHeight,left:t.nw.x-E.offsetWidth}}function c(){var t=x();return{top:t.ne.y-E.offsetHeight,left:t.ne.x}}function p(){var t=x();return{top:t.sw.y,left:t.sw.x-E.offsetWidth}}function y(){var t=x();return{top:t.se.y,left:t.se.x}}function d(){var t=e.select(document.createElement("div"));return t.style("position","absolute").style("top",0).style("opacity",0).style("pointer-events","none").style("box-sizing","border-box"),t.node()}function m(t){var e=t.node();return e?"svg"===e.tagName.toLowerCase()?e:e.ownerSVGElement:null}function h(){return null==E&&(E=d(),b.appendChild(E)),e.select(E)}function x(){for(var t=S||e.event.target;null==t.getScreenCTM&&null==t.parentNode;)t=t.parentNode;var n={},r=t.getScreenCTM(),o=t.getBBox(),l=o.width,i=o.height,f=o.x,u=o.y;return H.x=f,H.y=u,n.nw=H.matrixTransform(r),H.x+=l,n.ne=H.matrixTransform(r),H.y+=i,n.se=H.matrixTransform(r),H.x-=l,n.sw=H.matrixTransform(r),H.y-=i/2,n.w=H.matrixTransform(r),H.x+=l,n.e=H.matrixTransform(r),H.x-=l/2,H.y-=i/2,n.n=H.matrixTransform(r),H.y+=i,n.s=H.matrixTransform(r),n}function v(t){return"function"==typeof t?t:function(){return t}}var g=r,w=o,T=l,b=document.body,E=d(),C=null,H=null,S=null;n.show=function(){var t=Array.prototype.slice.call(arguments);t[t.length-1]instanceof SVGElement&&(S=t.pop());var e,r=T.apply(this,t),o=w.apply(this,t),l=g.apply(this,t),i=h(),f=A.length,u=document.documentElement.scrollTop||b.scrollTop,s=document.documentElement.scrollLeft||b.scrollLeft;for(i.html(r).style("opacity",1).style("pointer-events","all");f--;)i.classed(A[f],!1);return e=W.get(l).apply(this),i.classed(l,!0).style("top",e.top+o[0]+u+"px").style("left",e.left+o[1]+s+"px"),n},n.hide=function(){return h().style("opacity",0).style("pointer-events","none"),n},n.attr=function(t,r){if(arguments.length<2&&"string"==typeof t)return h().attr(t);var o=Array.prototype.slice.call(arguments);return e.selection.prototype.attr.apply(h(),o),n},n.style=function(t,r){if(arguments.length<2&&"string"==typeof t)return h().style(t);var o=Array.prototype.slice.call(arguments);return e.selection.prototype.style.apply(h(),o),n},n.direction=function(t){return arguments.length?(g=null==t?t:v(t),n):g},n.offset=function(t){return arguments.length?(w=null==t?t:v(t),n):w},n.html=function(t){return arguments.length?(T=null==t?t:v(t),n):T},n.rootElement=function(t){return arguments.length?(b=null==t?t:v(t),n):b},n.destroy=function(){return E&&(h().remove(),E=null),n};var W=t.map({n:i,s:f,e:u,w:s,nw:a,ne:c,sw:p,se:y}),A=W.keys();return n}});
@@ -1,92 +0,0 @@
1
- .d3-flame-graph rect {
2
- stroke: #EEEEEE;
3
- fill-opacity: .8;
4
- }
5
-
6
- .d3-flame-graph rect:hover {
7
- stroke: #474747;
8
- stroke-width: 0.5;
9
- cursor: pointer;
10
- }
11
-
12
- .d3-flame-graph .label {
13
- pointer-events: none;
14
- white-space: nowrap;
15
- text-overflow: ellipsis;
16
- overflow: hidden;
17
- font-size: 12px;
18
- font-family: Verdana;
19
- margin-left: 4px;
20
- margin-right: 4px;
21
- line-height: 1.5;
22
- padding: 0 0 0;
23
- font-weight: 400;
24
- color: black;
25
- text-align: left;
26
- }
27
-
28
- .d3-flame-graph .fade {
29
- opacity: 0.6 !important;
30
- }
31
-
32
- .d3-flame-graph .title {
33
- font-size: 20px;
34
- font-family: Verdana;
35
- }
36
-
37
- .d3-flame-graph-tip {
38
- line-height: 1;
39
- font-family: Verdana;
40
- font-size: 12px;
41
- padding: 12px;
42
- background: rgba(0, 0, 0, 0.8);
43
- color: #fff;
44
- border-radius: 2px;
45
- pointer-events: none;
46
- }
47
-
48
- /* Creates a small triangle extender for the tooltip */
49
- .d3-flame-graph-tip:after {
50
- box-sizing: border-box;
51
- display: inline;
52
- font-size: 10px;
53
- width: 100%;
54
- line-height: 1;
55
- color: rgba(0, 0, 0, 0.8);
56
- position: absolute;
57
- pointer-events: none;
58
- }
59
-
60
- /* Northward tooltips */
61
- .d3-flame-graph-tip.n:after {
62
- content: "\25BC";
63
- margin: -1px 0 0 0;
64
- top: 100%;
65
- left: 0;
66
- text-align: center;
67
- }
68
-
69
- /* Eastward tooltips */
70
- .d3-flame-graph-tip.e:after {
71
- content: "\25C0";
72
- margin: -4px 0 0 0;
73
- top: 50%;
74
- left: -8px;
75
- }
76
-
77
- /* Southward tooltips */
78
- .d3-flame-graph-tip.s:after {
79
- content: "\25B2";
80
- margin: 0 0 1px 0;
81
- top: -8px;
82
- left: 0;
83
- text-align: center;
84
- }
85
-
86
- /* Westward tooltips */
87
- .d3-flame-graph-tip.w:after {
88
- content: "\25B6";
89
- margin: -4px 0 0 -1px;
90
- top: 50%;
91
- left: 100%;
92
- }
@@ -1,459 +0,0 @@
1
- (function() {
2
- 'use strict';
3
-
4
- function flameGraph() {
5
-
6
- var w = 960, // graph width
7
- h = 540, // graph height
8
- c = 18, // cell height
9
- selection = null, // selection
10
- tooltip = true, // enable tooltip
11
- title = "", // graph title
12
- transitionDuration = 750,
13
- transitionEase = d3.easeCubic, // tooltip offset
14
- sort = true,
15
- reversed = false, // reverse the graph direction
16
- clickHandler = null;
17
-
18
- var tip = d3.tip()
19
- .direction("s")
20
- .offset([8, 0])
21
- .attr('class', 'd3-flame-graph-tip')
22
- .html(function(d) { return label(d); });
23
-
24
- var svg;
25
-
26
- var label = function(d) {
27
- return d.data.name + " (" + d3.format(".3f")(100 * (d.x1 - d.x0), 3) + "%, " + d.data.value + " samples)";
28
- };
29
-
30
- function setDetails(t) {
31
- var details = document.getElementById("details");
32
- if (details)
33
- details.innerHTML = t;
34
- }
35
-
36
- function name(d) {
37
- return d.data.name;
38
- }
39
-
40
- var colorMapper = function(d) {
41
- return d.highlight ? "#E600E6" : colorHash(d.data);
42
- };
43
-
44
- function generateHash(name) {
45
- // Return a vector (0.0->1.0) that is a hash of the input string.
46
- // The hash is computed to favor early characters over later ones, so
47
- // that strings with similar starts have similar vectors. Only the first
48
- // 6 characters are considered.
49
- var hash = 0, weight = 1, max_hash = 0, mod = 10, max_char = 6;
50
- if (name) {
51
- for (var i = 0; i < name.length; i++) {
52
- if (i > max_char) { break; }
53
- hash += weight * (name.charCodeAt(i) % mod);
54
- max_hash += weight * (mod - 1);
55
- weight *= 0.70;
56
- }
57
- if (max_hash > 0) { hash = hash / max_hash; }
58
- }
59
- return hash;
60
- }
61
-
62
- function colorHash(data) {
63
- var name = data.name;
64
-
65
- if (data.color) {
66
- return data.color;
67
- }
68
- // Return an rgb() color string that is a hash of the provided name,
69
- // and with a warm palette.
70
- var vector = 0;
71
- if (name) {
72
- name = name.replace(/.*`/, ""); // drop module name if present
73
- name = name.replace(/\(.*/, ""); // drop extra info
74
- vector = generateHash(name);
75
- }
76
- var r = 200 + Math.round(55 * vector);
77
- var g = 0 + Math.round(230 * vector);
78
- var b = 0 + Math.round(55 * vector);
79
- data.color = "rgb(" + r + "," + g + "," + b + ")";
80
- return data.color;
81
- }
82
-
83
- function hide(d) {
84
- if(!d.data.original) {
85
- d.data.original = d.data.value;
86
- }
87
- d.data.value = 0;
88
- if(d.children) {
89
- d.children.forEach(hide);
90
- }
91
- }
92
-
93
- function show(d) {
94
- d.data.fade = false;
95
- if(d.data.original) {
96
- d.data.value = d.data.original;
97
- }
98
- if(d.children) {
99
- d.children.forEach(show);
100
- }
101
- }
102
-
103
- function getSiblings(d) {
104
- var siblings = [];
105
- if (d.parent) {
106
- var me = d.parent.children.indexOf(d);
107
- siblings = d.parent.children.slice(0);
108
- siblings.splice(me, 1);
109
- }
110
- return siblings;
111
- }
112
-
113
- function hideSiblings(d) {
114
- var siblings = getSiblings(d);
115
- siblings.forEach(function(s) {
116
- hide(s);
117
- });
118
- if(d.parent) {
119
- hideSiblings(d.parent);
120
- }
121
- }
122
-
123
- function fadeAncestors(d) {
124
- if(d.parent) {
125
- d.parent.data.fade = true;
126
- fadeAncestors(d.parent);
127
- }
128
- }
129
-
130
- function getRoot(d) {
131
- if(d.parent) {
132
- return getRoot(d.parent);
133
- }
134
- return d;
135
- }
136
-
137
- function zoom(d) {
138
- tip.hide(d);
139
- hideSiblings(d);
140
- show(d);
141
- fadeAncestors(d);
142
- update();
143
- if (typeof clickHandler === 'function') {
144
- clickHandler(d);
145
- }
146
- }
147
-
148
- function searchTree(d, term) {
149
- var re = new RegExp(term),
150
- searchResults = [];
151
-
152
- function searchInner(d) {
153
- var label = d.data.name;
154
-
155
- if (d.children) {
156
- d.children.forEach(function (child) {
157
- searchInner(child);
158
- });
159
- }
160
-
161
- if (label.match(re)) {
162
- d.highlight = true;
163
- searchResults.push(d);
164
- } else {
165
- d.highlight = false;
166
- }
167
- }
168
-
169
- searchInner(d);
170
- return searchResults;
171
- }
172
-
173
- function clear(d) {
174
- d.highlight = false;
175
- if(d.children) {
176
- d.children.forEach(function(child) {
177
- clear(child);
178
- });
179
- }
180
- }
181
-
182
- function doSort(a, b) {
183
- if (typeof sort === 'function') {
184
- return sort(a, b);
185
- } else if (sort) {
186
- return d3.ascending(a.data.name, b.data.name);
187
- } else {
188
- return 0;
189
- }
190
- }
191
-
192
- var partition = d3.partition();
193
-
194
- function update() {
195
-
196
- selection.each(function(root) {
197
- var x = d3.scaleLinear().range([0, w]),
198
- y = d3.scaleLinear().range([0, c]);
199
-
200
- root.sort(doSort);
201
- root.sum(function(d) {
202
- if (d.fade) {
203
- return 0;
204
- }
205
- // The node's self value is its total value minus all children.
206
- var v = d.v || d.value || 0;
207
- if (d.children) {
208
- for (var i = 0; i < d.children.length; i++) {
209
- v -= d.children[i].value;
210
- }
211
- }
212
- return v;
213
- });
214
- partition(root);
215
-
216
- var kx = w / (root.x1 - root.x0);
217
- function width(d) { return (d.x1 - d.x0) * kx; }
218
-
219
- var g = d3.select(this).select("svg").selectAll("g").data(root.descendants());
220
-
221
- g.transition()
222
- .duration(transitionDuration)
223
- .ease(transitionEase)
224
- .attr("transform", function(d) { return "translate(" + x(d.x0) + ","
225
- + (reversed ? y(d.depth) : (h - y(d.depth) - c)) + ")"; });
226
-
227
- g.select("rect").transition()
228
- .duration(transitionDuration)
229
- .ease(transitionEase)
230
- .attr("width", width);
231
-
232
- var node = g.enter()
233
- .append("svg:g")
234
- .attr("transform", function(d) { return "translate(" + x(d.x0) + ","
235
- + (reversed ? y(d.depth) : (h - y(d.depth) - c)) + ")"; });
236
-
237
- node.append("svg:rect").attr("width", width);
238
-
239
- if (!tooltip)
240
- node.append("svg:title");
241
-
242
- node.append("foreignObject")
243
- .append("xhtml:div");
244
-
245
- // Now we have to re-select to see the new elements (why?).
246
- g = d3.select(this).select("svg").selectAll("g").data(root.descendants());
247
-
248
- g.attr("width", width)
249
- .attr("height", function(d) { return c; })
250
- .attr("name", function(d) { return d.data.name; })
251
- .attr("class", function(d) { return d.data.fade ? "frame fade" : "frame"; });
252
-
253
- g.select("rect")
254
- .attr("height", function(d) { return c; })
255
- .attr("fill", function(d) { return colorMapper(d); });
256
-
257
- if (!tooltip)
258
- g.select("title")
259
- .text(label);
260
-
261
- g.select("foreignObject")
262
- .attr("width", width)
263
- .attr("height", function(d) { return c; })
264
- .select("div")
265
- .attr("class", "label")
266
- .style("display", function(d) { return (width(d) < 35) ? "none" : "block";})
267
- .text(name);
268
-
269
- g.on('click', zoom);
270
-
271
- g.exit().remove();
272
-
273
- g.on('mouseover', function(d) {
274
- if (tooltip) tip.show(d);
275
- setDetails(label(d));
276
- }).on('mouseout', function(d) {
277
- if (tooltip) tip.hide(d);
278
- setDetails("");
279
- });
280
- });
281
- }
282
-
283
- function merge(data, samples) {
284
- samples.forEach(function (sample) {
285
- var node = _.find(data, function (element) {
286
- return element.name === sample.name;
287
- });
288
-
289
- if (node) {
290
- if (node.original) {
291
- node.original += sample.value;
292
- } else {
293
- node.value += sample.value;
294
- }
295
- if (sample.children) {
296
- if (!node.children) {
297
- node.children = [];
298
- }
299
- merge(node.children, sample.children)
300
- }
301
- } else {
302
- data.push(sample);
303
- }
304
- });
305
- }
306
-
307
- function chart(s) {
308
- var root = d3.hierarchy(s.datum(), function(d) { return d.c || d.children; });
309
- selection = s.datum(root);
310
-
311
- if (!arguments.length) return chart;
312
-
313
- selection.each(function(data) {
314
-
315
- if (!svg) {
316
- svg = d3.select(this)
317
- .append("svg:svg")
318
- .attr("width", w)
319
- .attr("height", h)
320
- .attr("class", "partition d3-flame-graph")
321
- .call(tip);
322
-
323
- svg.append("svg:text")
324
- .attr("class", "title")
325
- .attr("text-anchor", "middle")
326
- .attr("y", "25")
327
- .attr("x", w/2)
328
- .attr("fill", "#808080")
329
- .text(title);
330
- }
331
- });
332
-
333
- // first draw
334
- update();
335
- }
336
-
337
- chart.height = function (_) {
338
- if (!arguments.length) { return h; }
339
- h = _;
340
- return chart;
341
- };
342
-
343
- chart.width = function (_) {
344
- if (!arguments.length) { return w; }
345
- w = _;
346
- return chart;
347
- };
348
-
349
- chart.cellHeight = function (_) {
350
- if (!arguments.length) { return c; }
351
- c = _;
352
- return chart;
353
- };
354
-
355
- chart.tooltip = function (_) {
356
- if (!arguments.length) { return tooltip; }
357
- if (typeof _ === "function") {
358
- tip = _;
359
- }
360
- tooltip = true;
361
- return chart;
362
- };
363
-
364
- chart.title = function (_) {
365
- if (!arguments.length) { return title; }
366
- title = _;
367
- return chart;
368
- };
369
-
370
- chart.transitionDuration = function (_) {
371
- if (!arguments.length) { return transitionDuration; }
372
- transitionDuration = _;
373
- return chart;
374
- };
375
-
376
- chart.transitionEase = function (_) {
377
- if (!arguments.length) { return transitionEase; }
378
- transitionEase = _;
379
- return chart;
380
- };
381
-
382
- chart.sort = function (_) {
383
- if (!arguments.length) { return sort; }
384
- sort = _;
385
- return chart;
386
- };
387
-
388
- chart.reversed = function (_) {
389
- if (!arguments.length) { return reversed; }
390
- reversed = _;
391
- return chart;
392
- };
393
-
394
- chart.label = function(_) {
395
- if (!arguments.length) { return label; }
396
- label = _;
397
- return chart;
398
- };
399
-
400
- chart.search = function(term) {
401
- var searchResults = [];
402
- selection.each(function(data) {
403
- searchResults = searchTree(data, term);
404
- update();
405
- });
406
- return searchResults;
407
- };
408
-
409
- chart.clear = function() {
410
- selection.each(function(data) {
411
- clear(data);
412
- update();
413
- });
414
- };
415
-
416
- chart.zoomTo = function(d) {
417
- zoom(d);
418
- };
419
-
420
- chart.resetZoom = function() {
421
- selection.each(function (data) {
422
- zoom(data); // zoom to root
423
- });
424
- };
425
-
426
- chart.onClick = function(_) {
427
- if (!arguments.length) {
428
- return clickHandler;
429
- }
430
- clickHandler = _;
431
- return chart;
432
- };
433
-
434
- chart.merge = function(samples) {
435
- var newRoot; // Need to re-create hierarchy after data changes.
436
- selection.each(function (root) {
437
- merge([root.data], [samples]);
438
- newRoot = d3.hierarchy(root.data, function(d) { return d.c || d.children; });
439
- });
440
- selection = selection.datum(newRoot);
441
- update();
442
- }
443
-
444
- chart.color = function(_) {
445
- if (!arguments.length) { return colorMapper; }
446
- colorMapper = _;
447
- return chart;
448
- };
449
-
450
- return chart;
451
- }
452
-
453
- if (typeof module !== 'undefined' && module.exports){
454
- module.exports = flameGraph;
455
- }
456
- else {
457
- d3.flameGraph = flameGraph;
458
- }
459
- })();