You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/** @typedef {"info" | "warning" | "error"} LogLevel */
/** @type {LogLevel} */ var logLevel = "info";
function dummy() {}
/** * @param {LogLevel} level log level * @returns {boolean} true, if should log */ function shouldLog(level) { var shouldLog = (logLevel === "info" && level === "info") || (["info", "warning"].indexOf(logLevel) >= 0 && level === "warning") || (["info", "warning", "error"].indexOf(logLevel) >= 0 && level === "error"); return shouldLog; }
/** * @param {(msg?: string) => void} logFn log function * @returns {(level: LogLevel, msg?: string) => void} function that logs when log level is sufficient */ function logGroup(logFn) { return function (level, msg) { if (shouldLog(level)) { logFn(msg); } }; }
/** * @param {LogLevel} level log level * @param {string|Error} msg message */ module.exports = function (level, msg) { if (shouldLog(level)) { if (level === "info") { console.log(msg); } else if (level === "warning") { console.warn(msg); } else if (level === "error") { console.error(msg); } } };
var group = console.group || dummy; var groupCollapsed = console.groupCollapsed || dummy; var groupEnd = console.groupEnd || dummy;
module.exports.group = logGroup(group);
module.exports.groupCollapsed = logGroup(groupCollapsed);
module.exports.groupEnd = logGroup(groupEnd);
/** * @param {LogLevel} level log level */ module.exports.setLogLevel = function (level) { logLevel = level; };
/** * @param {Error} err error * @returns {string} formatted error */ module.exports.formatError = function (err) { var message = err.message; var stack = err.stack; if (!stack) { return message; } else if (stack.indexOf(message) < 0) { return message + "\n" + stack; } return stack; };
|