toolkit/components/telemetry/TelemetryLog.jsm

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

     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