Source code

Revision control

Copy as Markdown

Other Tools

/* 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/. */
var LogController = {}; //create the logger object
LogController.counter = 0; //current log message number
LogController.listeners = [];
LogController.logLevel = {
FATAL: 50,
ERROR: 40,
WARNING: 30,
INFO: 20,
DEBUG: 10,
};
/* set minimum logging level */
LogController.logLevelAtLeast = function (minLevel) {
if (typeof minLevel == "string") {
minLevel = LogController.logLevel[minLevel];
}
return function (msg) {
var msgLevel = msg.level;
if (typeof msgLevel == "string") {
msgLevel = LogController.logLevel[msgLevel];
}
return msgLevel >= minLevel;
};
};
/* creates the log message with the given level and info */
LogController.createLogMessage = function (level, info) {
var msg = {};
msg.num = LogController.counter;
msg.level = level;
msg.info = info;
msg.timestamp = new Date();
return msg;
};
/* helper method to return a sub-array */
LogController.extend = function (args, skip) {
var ret = [];
for (var i = skip; i < args.length; i++) {
ret.push(args[i]);
}
return ret;
};
/* logs message with given level. Currently used locally by log() and error() */
LogController.logWithLevel = function (level /*, ...*/) {
var msg = LogController.createLogMessage(
level,
LogController.extend(arguments, 1)
);
LogController.dispatchListeners(msg);
LogController.counter += 1;
};
/* log with level INFO */
LogController.log = function (message /*, ...*/) {
LogController.logWithLevel("INFO", message);
};
/* log with level ERROR */
LogController.error = function (message /*, ...*/) {
LogController.logWithLevel("ERROR", message);
};
/* send log message to listeners */
LogController.dispatchListeners = function (msg) {
for (var k in LogController.listeners) {
var pair = LogController.listeners[k];
if (pair.ident != k || (pair[0] && !pair[0](msg))) {
continue;
}
pair[1](msg);
}
};
/* add a listener to this log given an identifier, a filter (can be null) and the listener object */
LogController.addListener = function (ident, filter, listener) {
if (typeof filter == "string") {
filter = LogController.logLevelAtLeast(filter);
} else if (filter !== null && typeof filter !== "function") {
throw new Error("Filter must be a string, a function, or null");
}
var entry = [filter, listener];
entry.ident = ident;
LogController.listeners[ident] = entry;
};
/* remove a listener from this log */
LogController.removeListener = function (ident) {
delete LogController.listeners[ident];
};