mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-26 11:45:37 +00:00
99e91ded27
MozReview-Commit-ID: 44oBXPP88Lc --HG-- extra : rebase_source : 6625ac73eca1fa63d474eda3d1146baf910eac8c
43 lines
1.0 KiB
JavaScript
43 lines
1.0 KiB
JavaScript
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
this.EXPORTED_SYMBOLS = ["TelemetryLog"];
|
|
|
|
const Cc = Components.classes;
|
|
const Ci = Components.interfaces;
|
|
const Cu = Components.utils;
|
|
|
|
Cu.import("resource://gre/modules/Services.jsm");
|
|
|
|
const LOG_ENTRY_MAX_COUNT = 1000;
|
|
|
|
var gLogEntries = [];
|
|
|
|
this.TelemetryLog = Object.freeze({
|
|
log(id, data) {
|
|
if (gLogEntries.length >= LOG_ENTRY_MAX_COUNT) {
|
|
return;
|
|
}
|
|
id = String(id);
|
|
var ts;
|
|
try {
|
|
ts = Math.floor(Services.telemetry.msSinceProcessStart());
|
|
} catch (e) {
|
|
// If timestamp is screwed up, we just give up instead of making up
|
|
// data.
|
|
return;
|
|
}
|
|
|
|
var entry = [id, ts];
|
|
if (data !== undefined) {
|
|
entry = entry.concat(Array.prototype.map.call(data, String));
|
|
}
|
|
gLogEntries.push(entry);
|
|
},
|
|
|
|
entries() {
|
|
return gLogEntries;
|
|
}
|
|
});
|