Thu, 22 Jan 2015 13:21:57 +0100
Incorporate requested changes from Mozilla in review:
https://bugzilla.mozilla.org/show_bug.cgi?id=1123480#c6
1 /* This Source Code Form is subject to the terms of the Mozilla Public
2 * License, v. 2.0. If a copy of the MPL was not distributed with this
3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
5 this.EXPORTED_SYMBOLS = ["TelemetryLog"];
7 const Cc = Components.classes;
8 const Ci = Components.interfaces;
10 const Telemetry = Cc["@mozilla.org/base/telemetry;1"].getService(Ci.nsITelemetry);
11 var gLogEntries = [];
13 this.TelemetryLog = Object.freeze({
14 log: function(id, data) {
15 id = String(id);
16 var ts;
17 try {
18 ts = Math.floor(Telemetry.msSinceProcessStart());
19 } catch(e) {
20 // If timestamp is screwed up, we just give up instead of making up
21 // data.
22 return;
23 }
25 var entry = [id, ts];
26 if (data !== undefined) {
27 entry = entry.concat(Array.prototype.map.call(data, String));
28 }
29 gLogEntries.push(entry);
30 },
32 entries: function() {
33 return gLogEntries;
34 }
35 });