toolkit/components/telemetry/TelemetryLog.jsm

Thu, 22 Jan 2015 13:21:57 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 22 Jan 2015 13:21:57 +0100
branch
TOR_BUG_9701
changeset 15
b8a032363ba2
permissions
-rw-r--r--

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 });

mercurial