ololog
Version:
Platform-agnostic logging with colors in terminals & browsers / shows call locations / pretty prints objects and stacktraces / smart newline and indentation handling
287 lines (224 loc) • 26.3 kB
JavaScript
;
/* ------------------------------------------------------------------------ */
var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
function _defineEnumerableProperties(obj, descs) { for (var key in descs) { var desc = descs[key]; desc.configurable = desc.enumerable = true; if ("value" in desc) desc.writable = true; Object.defineProperty(obj, key, desc); } return obj; }
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
function _toArray(arr) { return Array.isArray(arr) ? arr : Array.from(arr); }
var O = Object,
StackTracey = require('stacktracey'),
ansi = require('ansicolor'),
bullet = require('string.bullet'),
pipez = require('pipez');
/* ------------------------------------------------------------------------ */
var _stringify = require('string.ify').configure({
formatter: function formatter(x) {
if (x instanceof Error && !(typeof Symbol !== 'undefined' && x[Symbol.for('String.ify')])) {
var why = _stringify.limit((x.message || '').replace(/\r|\n/g, '').trim(), 120),
stack = new StackTracey(x).pretty,
stackIndented = stack.split('\n').map(function (x) {
return ' ' + x;
}).join('\n');
return '[EXCEPTION] ' + why + '\n\n' + stackIndented + '\n';
}
}
});
/* ------------------------------------------------------------------------ */
var _require = require('printable-characters'),
isBlank = _require.isBlank,
blank = _require.blank,
changeLastNonemptyLine = function changeLastNonemptyLine(lines, fn) {
for (var i = lines.length - 1; i >= 0; i--) {
if (i === 0 || !isBlank(lines[i])) {
lines[i] = fn(lines[i]);
break;
}
}
return lines;
};
/* ------------------------------------------------------------------------ */
var log = pipez({
/* ------------------------------------------------------------------------ */
stringify: function stringify(args, cfg) {
var print = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _stringify.configure(cfg);
return args.map(function (arg) {
return typeof arg === 'string' ? arg : print(arg);
});
},
trim: function trim(tokens, _ref) {
var _ref$max = _ref.max,
max = _ref$max === undefined ? undefined : _ref$max;
return !max ? tokens : tokens.map(function (t) {
return _stringify.limit(t, max);
});
},
lines: function lines(tokens, _ref2) {
var _ref2$linebreak = _ref2.linebreak,
linebreak = _ref2$linebreak === undefined ? '\n' : _ref2$linebreak;
var lines = [[]];
var leftPad = [];
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = tokens[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var t = _step.value;
var _t$split = t.split(linebreak),
_t$split2 = _toArray(_t$split),
first = _t$split2[0],
rest = _t$split2.slice(1);
lines[lines.length - 1].push(first);
lines = [].concat(_toConsumableArray(lines), _toConsumableArray(rest.map(function (t) {
return t ? [].concat(leftPad, [t]) : [];
})));
var pad = blank(!rest.length ? t : rest[rest.length - 1]);
if (pad) {
leftPad.push(pad);
}
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
return lines;
},
concat: function concat(lines, _ref3) {
var _ref3$separator = _ref3.separator,
separator = _ref3$separator === undefined ? ' ' : _ref3$separator;
return lines.map(function (tokens) {
return tokens.join(separator);
});
},
indent: function indent(lines, _ref4) {
var _ref4$level = _ref4.level,
level = _ref4$level === undefined ? 0 : _ref4$level,
_ref4$pattern = _ref4.pattern,
pattern = _ref4$pattern === undefined ? '\t' : _ref4$pattern;
return lines.map(function (line) {
return pattern.repeat(level) + line;
});
},
time: function time(lines, _ref5) {
var _ref5$when = _ref5.when,
when = _ref5$when === undefined ? new Date() : _ref5$when,
_ref5$print = _ref5.print,
print = _ref5$print === undefined ? function (when) {
return ansi.dim(when.toISOString()) + '\t';
} : _ref5$print;
return bullet(print(when), lines);
},
locate: function locate(lines, _ref6) {
var _ref6$shift = _ref6.shift,
shift = _ref6$shift === undefined ? 0 : _ref6$shift,
_ref6$where = _ref6.where,
where = _ref6$where === undefined ? new StackTracey().clean.at(2 + shift) : _ref6$where,
_ref6$join = _ref6.join,
join = _ref6$join === undefined ? function (a, sep, b) {
return a && b ? a + sep + b : a || b;
} : _ref6$join,
_ref6$print = _ref6.print,
print = _ref6$print === undefined ? function (_ref7) {
var calleeShort = _ref7.calleeShort,
_ref7$fileName = _ref7.fileName,
fileName = _ref7$fileName === undefined ? [] : _ref7$fileName,
_ref7$line = _ref7.line,
line = _ref7$line === undefined ? [] : _ref7$line;
return ansi.dim('(' + join(calleeShort, ' @ ', join(fileName, ':', line)) + ')');
} : _ref6$print;
return changeLastNonemptyLine(lines, function (line) {
return join(line, ' ', print(where));
});
},
join: function join(lines, _ref8) {
var _ref8$linebreak = _ref8.linebreak,
linebreak = _ref8$linebreak === undefined ? '\n' : _ref8$linebreak;
return lines.join(linebreak);
},
render: function render(text, _ref9) {
var _ref9$engine = _ref9.engine,
engine = _ref9$engine === undefined ? typeof window !== 'undefined' && window.window === window && window.navigator ? navigator.userAgent.indexOf('Chrome') >= 0 ? 'chrome' : 'generic' : 'ansi' : _ref9$engine,
_ref9$engines = _ref9.engines,
engines = _ref9$engines === undefined ? {/* configurable */} : _ref9$engines,
_ref9$consoleMethod = _ref9.consoleMethod,
consoleMethod = _ref9$consoleMethod === undefined ? 'log' : _ref9$consoleMethod,
_ref9$defaults = _ref9.defaults,
defaults = _ref9$defaults === undefined ? {
ansi: function ansi(s) {
return console[consoleMethod](s);
},
chrome: function chrome(s) {
var _console;
return (_console = console)[consoleMethod].apply(_console, _toConsumableArray(ansi.parse(s).asChromeConsoleLogArguments));
},
generic: function generic(s) {
return console[consoleMethod](ansi.strip(s));
}
} : _ref9$defaults;
return text && O.assign(defaults, engines)[engine](text), text;
},
returnValue: function returnValue(__, _ref10) {
var _ref10$initialArgumen = _slicedToArray(_ref10.initialArguments, 1),
firstArgument = _ref10$initialArgumen[0];
return firstArgument;
}
/* ------------------------------------------------------------------------ */
}).configure({
time: false // disables 'time' step (until enabled back explicitly)
/* ------------------------------------------------------------------------ */
}).methods({
indent: function indent(level) {
return this.configure({ indent: { level: level } });
},
get error() {
return this.configure({ render: { consoleMethod: 'error' } });
},
get warn() {
return this.configure({ render: { consoleMethod: 'warn' } });
},
get info() {
return this.configure({ render: { consoleMethod: 'info' } });
},
maxArrayLength: function maxArrayLength(n) {
return this.configure({ stringify: { maxArrayLength: n } });
},
maxDepth: function maxDepth(n) {
return this.configure({ stringify: { maxDepth: n } });
},
get unlimited() {
return this.configure({ stringify: { maxArrayLength: Number.MAX_VALUE, maxDepth: Number.MAX_VALUE } });
},
get noPretty() {
return this.configure({ stringify: { pretty: false } });
},
get serialize() {
return this.before('render');
},
get deserialize() {
return this.from('render');
},
newline: function newline() {
return this.from('join')(['']);
}
});
/* ------------------------------------------------------------------------ */
ansi.names.forEach(function (color) {
var _log$methods, _mutatorMap;
log.methods((_log$methods = {}, _mutatorMap = {}, _mutatorMap[color] = _mutatorMap[color] || {}, _mutatorMap[color].get = function () {
return this.configure({ 'concat+': function concat(lines) {
return lines.map(ansi[color]);
} });
}, _defineEnumerableProperties(_log$methods, _mutatorMap), _log$methods));
});
/* ------------------------------------------------------------------------ */
module.exports = log;
/* ------------------------------------------------------------------------ */
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../ololog.js"],"names":[],"mappings":"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","file":"ololog.es5.js","sourcesContent":["\"use strict\";\n\n/*  ------------------------------------------------------------------------ */\n\nconst O                 = Object\n    , StackTracey       = require ('stacktracey')\n    , ansi              = require ('ansicolor')\n    , bullet            = require ('string.bullet')\n    , pipez             = require ('pipez')\n\n/*  ------------------------------------------------------------------------ */\n\nconst stringify = require ('string.ify').configure ({\n\n    formatter (x) {\n\n        if ((x instanceof Error) && !(typeof Symbol !== 'undefined' && x[Symbol.for ('String.ify')])) {\n\n            const why           = stringify.limit ((x.message || '').replace (/\\r|\\n/g, '').trim (), 120),\n                  stack         = new StackTracey (x).pretty,\n                  stackIndented = stack.split ('\\n').map (x => '    ' + x).join ('\\n')\n\n            return `[EXCEPTION] ${why}\\n\\n${stackIndented}\\n`\n        }\n    }\n})\n\n/*  ------------------------------------------------------------------------ */\n\nconst { isBlank, blank } = require ('printable-characters')\n\n    , changeLastNonemptyLine = (lines, fn) => {\n\n        for (let i = lines.length - 1; i >= 0; i--) {\n\n            if ((i === 0) || !isBlank (lines[i])) {\n\n                lines[i] = fn (lines[i])\n\n                break;\n            }\n        }\n\n        return lines\n    }\n\n/*  ------------------------------------------------------------------------ */\n\nconst log = pipez ({\n\n/*  ------------------------------------------------------------------------ */\n\n    stringify: (args, cfg, print = stringify.configure (cfg)) => args.map (arg => (typeof arg === 'string') ? arg : print (arg)),\n    \n    trim: (tokens, { max = undefined }) => !max ? tokens : tokens.map (t => stringify.limit (t, max)),\n\n    lines: (tokens, { linebreak = '\\n' }) => {\n\n        let lines = [[]]\n\n        let leftPad = []\n\n        for (const t of tokens) {\n\n            const [first, ...rest] = t.split (linebreak)\n\n            lines[lines.length - 1].push (first)\n            lines = [...lines, ...rest.map (t => t ? [...leftPad, t] : [])]\n\n            const pad = blank (!rest.length ? t : rest[rest.length - 1])\n            \n            if (pad) { leftPad.push (pad) }\n        }\n\n        return lines\n    },\n\n    concat: (lines, { separator = ' ' }) => lines.map (tokens => tokens.join (separator)),\n\n    indent: (lines, { level = 0, pattern = '\\t' }) => lines.map (line => pattern.repeat (level) + line),\n    \n    time: (lines, { when  = new Date (),\n                    print = when => ansi.dim (when.toISOString ()) + '\\t' }) => bullet (print (when), lines),\n\n    locate: (lines, {\n\n                    shift = 0,\n                    where = (new StackTracey ().clean.at (2 + shift)),\n                    join  = ((a, sep, b) => (a && b) ? (a + sep + b) : (a || b)),\n                    print = ({ calleeShort, fileName = [], line = [] }) => ansi.dim ('(' + join (calleeShort, ' @ ', join (fileName, ':', line)) + ')')\n\n                }) => changeLastNonemptyLine (lines, line => join (line, ' ', print (where))),\n\n    join: (lines, { linebreak = '\\n' }) => lines.join (linebreak),\n\n    render: (text, {\n\n        engine = ((typeof window !== 'undefined') && (window.window === window) && window.navigator)\n\n                            ? (navigator.userAgent.indexOf ('Chrome') >= 0)\n\n                                ? 'chrome'\n                                : 'generic'\n\n                            : 'ansi',\n\n        engines = { /* configurable */ },\n\n        consoleMethod = 'log',\n\n        defaults = {\n\n            ansi:    s => console[consoleMethod] (s),\n            chrome:  s => console[consoleMethod] (...ansi.parse (s).asChromeConsoleLogArguments),\n            generic: s => console[consoleMethod] (ansi.strip (s))\n        }\n\n    }) => ((text && O.assign (defaults, engines)[engine] (text), text)),\n\n    returnValue: (__, { initialArguments: [firstArgument] }) => firstArgument\n\n/*  ------------------------------------------------------------------------ */\n\n}).configure ({\n\n    time: false // disables 'time' step (until enabled back explicitly)\n\n/*  ------------------------------------------------------------------------ */\n\n}).methods ({\n\n    indent (level) { return this.configure ({ indent: { level: level }}) },\n\n    get error () { return this.configure ({ render: { consoleMethod: 'error' } }) },\n    get warn ()  { return this.configure ({ render: { consoleMethod: 'warn' } }) },\n    get info ()  { return this.configure ({ render: { consoleMethod: 'info' } }) },\n\n    maxArrayLength (n) { return this.configure ({ stringify: { maxArrayLength: n } }) },\n    maxDepth (n) { return this.configure ({ stringify: { maxDepth: n } }) },\n\n    get unlimited () { return this.configure ({ stringify: { maxArrayLength: Number.MAX_VALUE, maxDepth: Number.MAX_VALUE } }) },\n    get noPretty () { return this.configure ({ stringify: { pretty: false } }) },\n\n    get serialize () { return this.before ('render') },\n    get deserialize () { return this.from ('render') },\n\n    newline () { return this.from ('join')(['']) }\n})\n\n/*  ------------------------------------------------------------------------ */\n\nansi.names.forEach (color => {\n\n    log.methods ({\n\n        get [color] () { return this.configure ({ 'concat+': lines => lines.map (ansi[color]) }) }\n    })\n})\n\n/*  ------------------------------------------------------------------------ */\n\nmodule.exports = log\n\n/*  ------------------------------------------------------------------------ */\n\n\n"]}