mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-10 17:30:26 +00:00
92 lines
2.2 KiB
JavaScript
92 lines
2.2 KiB
JavaScript
/*\
|
|
title: $:/core/modules/utils/performance.js
|
|
type: application/javascript
|
|
module-type: global
|
|
|
|
Performance measurement.
|
|
|
|
\*/
|
|
(function(){
|
|
|
|
/*jslint node: true, browser: true */
|
|
/*global $tw: false */
|
|
"use strict";
|
|
|
|
function Performance(enabled) {
|
|
this.enabled = !!enabled;
|
|
this.measures = {}; // Hashmap by measurement name of {time:, invocations:}
|
|
this.logger = new $tw.utils.Logger("performance");
|
|
this.showGreeting();
|
|
}
|
|
|
|
Performance.prototype.showGreeting = function() {
|
|
if($tw.browser) {
|
|
this.logger.log("Execute $tw.perf.log(); to see filter execution timings");
|
|
}
|
|
};
|
|
|
|
/*
|
|
Wrap performance reporting around a top level function
|
|
*/
|
|
Performance.prototype.report = function(name,fn) {
|
|
var self = this;
|
|
if(this.enabled) {
|
|
return function() {
|
|
var startTime = $tw.utils.timer(),
|
|
result = fn.apply(this,arguments);
|
|
self.logger.log(name + ": " + $tw.utils.timer(startTime).toFixed(2) + "ms");
|
|
return result;
|
|
};
|
|
} else {
|
|
return fn;
|
|
}
|
|
};
|
|
|
|
Performance.prototype.log = function() {
|
|
var self = this,
|
|
totalTime = 0,
|
|
orderedMeasures = Object.keys(this.measures).sort(function(a,b) {
|
|
if(self.measures[a].time > self.measures[b].time) {
|
|
return -1;
|
|
} else if (self.measures[a].time < self.measures[b].time) {
|
|
return + 1;
|
|
} else {
|
|
return 0;
|
|
}
|
|
});
|
|
$tw.utils.each(orderedMeasures,function(name) {
|
|
totalTime += self.measures[name].time;
|
|
});
|
|
var results = []
|
|
$tw.utils.each(orderedMeasures,function(name) {
|
|
var measure = self.measures[name];
|
|
results.push({name: name,invocations: measure.invocations, avgTime: measure.time / measure.invocations, totalTime: measure.time, percentTime: (measure.time / totalTime) * 100})
|
|
});
|
|
self.logger.table(results);
|
|
};
|
|
|
|
/*
|
|
Wrap performance measurements around a subfunction
|
|
*/
|
|
Performance.prototype.measure = function(name,fn) {
|
|
var self = this;
|
|
if(this.enabled) {
|
|
return function() {
|
|
var startTime = $tw.utils.timer(),
|
|
result = fn.apply(this,arguments);
|
|
if(!(name in self.measures)) {
|
|
self.measures[name] = {time: 0, invocations: 0};
|
|
}
|
|
self.measures[name].time += $tw.utils.timer(startTime);
|
|
self.measures[name].invocations++;
|
|
return result;
|
|
};
|
|
} else {
|
|
return fn;
|
|
}
|
|
};
|
|
|
|
exports.Performance = Performance;
|
|
|
|
})();
|