// Load up loggers + formatters
if (typeof require === 'function') {
// Formatters
- Cobalt.Formatter.Simple = require('./formatters/simple.js').Simple;
- Cobalt.Formatter.Ansi = require('./formatters/ansi.js').Ansi;
Cobalt.Formatter.Token = require('./formatters/token.js').Token;
// Loggers
}
Cobalt.now = function () {
- if (typeof performance !== 'undefined') {
+ if (typeof performance !== 'undefined' && performance.timing) {
return performance.timing.navigationStart + performance.now();
}
return Date.now();
}
+ // Stringify with circular dereference.
+ Cobalt.stringify = function (object) {
+ var cache = [], stringified;
+ stringified = JSON.stringify(object, function (key, value) {
+ if (typeof value === 'object' && value !== null) {
+ if (cache.indexOf(value) !== -1) {
+ return "[Circular]";
+ }
+ cache.push(value);
+ }
+ return value;
+ });
+ cache = null;
+
+ return stringified;
+ }
+
Cobalt.Console = Class(Cobalt, 'Console')({
prototype : {
from : "Generic Cobalt Logger",
// Builds a Cobalt Log Object
buildLog : function (item, level) {
- var co = this, oldItem;
+ var co = this, oldItem, logObject = {};
+
+ if (typeof item === "undefined" || item === null || !item._cobaltLog) {
+ logObject.message = item;
+ logObject._cobaltLog = true;
+ logObject._from = co.from;
+ logObject._level = level || 6;
+ logObject._levelString = co._levelString(logObject._level);
+ logObject._version = co.version;
+ logObject._timestamp = co.now();
+ logObject._indentLevel = co.currentIndent;
+ logObject._color = co.currentColor;
+ logObject._separator = false;
+ return logObject;
+ }
- if (!item._cobaltLog) {
- if (typeof item !== "object") {
- item = {message : item.toString() };
- } else {
- item.message = JSON.stringify(item);
- }
+ return item;
+ },
+
+ extendLog : function (extendingObject) {
+ var co = this, logObject,
+ property;
- item._cobaltLog = true;
- item._from = co.from;
- item._level = item._level || level || 7;
- item._levelString = co._levelString(item._level);
- item._version = co.version;
- item._timestamp = co.now();
- item._indentLevel = co.currentIndent;
- item._color = co.currentColor;
+ logObject = co.buildLog(undefined, 6);
+ extendingObject = extendingObject || {};
+
+ for (property in extendingObject) {
+ if (extendingObject.hasOwnProperty(property)) {
+ logObject[property] = extendingObject[property];
+ }
}
- return item;
+ return logObject;
},
buildSeparator : function (type) {
// Returns the current time in microseconds.
now : function () {
- if (typeof performance !== 'undefined') {
+ if (typeof performance !== 'undefined' && performance.timing) {
return performance.timing.navigationStart + performance.now();
}
global.Formatter = Cobalt.Formatter;
global.Logger = Cobalt.Logger;
global.Console = Cobalt.Console;
+ global.now = Cobalt.now;
+ global.stringify = Cobalt.stringify;
} else {
global.Cobalt = Cobalt;
}