diff --git a/dist/es5/formatter.js b/dist/es5/formatter.js index 7e5b7ad..0eff6bf 100644 --- a/dist/es5/formatter.js +++ b/dist/es5/formatter.js @@ -116,6 +116,24 @@ var _formatLineNumber = function _formatLineNumber(logEvent) { ); }; +/** + * @function + * @memberOf formatter + * + * @param {LOG_EVENT} logEvent + * + * @return {string} + */ +var _formatColumn = function _formatColumn(logEvent) { + + if (!logEvent.column) { + _getFileDetails(logEvent); + } + + return (/*istanbul ignore next*/'' + logEvent.column + ); +}; + /** * @function * @memberOf formatter @@ -238,6 +256,7 @@ var _formatters = { 'F|file': _formatFile, 'K|map|MAP': _formatMapMessage, 'L|line': _formatLineNumber, + 'column': _formatColumn, 'm|msg|message': _formatLogMessage, 'M|method': _formatMethodName, 'n': _formatLineSeparator, @@ -454,7 +473,10 @@ var _getFileDetails = function _getFileDetails(logEvent) { if (typeof define !== 'undefined') { var path = require('path'); var appDir = path.dirname(require.main.filename); - logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\|\/)/, ''); + if (!fileParts[0].startsWith(appDir)) { + appDir = ''; + } + logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\|\/)/, ''); } else { logEvent.filename = fileParts.join(':'); } @@ -464,6 +486,7 @@ var _getFileDetails = function _getFileDetails(logEvent) { logEvent.filename = 'anonymous'; logEvent.lineNumber = '?'; } + logEvent.file = logEvent.filename; }; /** @@ -490,4 +513,4 @@ function preCompile(layout) { function format(layout, logEvent) { return _formatLogEvent(_getCompiledLayout(layout), logEvent); } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","column","pop","define","path","require","appDir","dirname","main","filename"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatColumn","column","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","pop","define","path","require","appDir","dirname","main","filename","startsWith"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatColumn = function (logEvent) {\n\n    if (!logEvent.column) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.column}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'column' : _formatColumn,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tif (!fileParts[0].startsWith(appDir)) {\n\t\t\t\tappDir = '';\n\t\t\t}\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\tlogEvent.file = logEvent.filename;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} \ No newline at end of file diff --git a/dist/es5/index.js b/dist/es5/index.js index 78bd3a9..9112dd3 100644 --- a/dist/es5/index.js +++ b/dist/es5/index.js @@ -296,15 +296,15 @@ function getLogger(context) { } // determine the context - if (typeof context != 'string') { + if (typeof context !== 'string') { - if (typeof context == 'function') { + if (typeof context === 'function') { context = utility.getFunctionName(context); - } else if ( /*istanbul ignore next*/(typeof context === 'undefined' ? 'undefined' : _typeof(context)) == 'object') { + } else if ( /*istanbul ignore next*/(typeof context === 'undefined' ? 'undefined' : _typeof(context)) === 'object') { context = utility.getFunctionName(context.constructor); - if (context == 'Object') { + if (context === 'Object') { context = 'anonymous'; } } else { @@ -328,7 +328,7 @@ function getLogger(context) { */ function setLogLevel(logLevel, logger) { - if (logLevel instanceof Number) { + if (Number.isInteger(logLevel)) { if (logger) { if (_loggers[logger]) { @@ -350,4 +350,4 @@ addAppender( /*istanbul ignore next*/_consoleAppender.ConsoleAppender); /*istanbul ignore next*/exports.LogLevel = _logLevel.LogLevel; /*istanbul ignore next*/exports.LogAppender = _appender.LogAppender; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context != 'string') {\n\n        if (typeof context == 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context == 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context == 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (logLevel instanceof Number) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","isInteger","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context !== 'string') {\n\n        if (typeof context === 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context === 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context === 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (Number.isInteger(logLevel)) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} \ No newline at end of file diff --git a/dist/es5/log4js2.js b/dist/es5/log4js2.js index 5b50a23..ed37a77 100644 --- a/dist/es5/log4js2.js +++ b/dist/es5/log4js2.js @@ -352,15 +352,15 @@ return /******/ (function(modules) { // webpackBootstrap } // determine the context - if (typeof context != 'string') { + if (typeof context !== 'string') { - if (typeof context == 'function') { + if (typeof context === 'function') { context = utility.getFunctionName(context); - } else if ( /*istanbul ignore next*/(typeof context === 'undefined' ? 'undefined' : _typeof(context)) == 'object') { + } else if ( /*istanbul ignore next*/(typeof context === 'undefined' ? 'undefined' : _typeof(context)) === 'object') { context = utility.getFunctionName(context.constructor); - if (context == 'Object') { + if (context === 'Object') { context = 'anonymous'; } } else { @@ -384,7 +384,7 @@ return /******/ (function(modules) { // webpackBootstrap */ function setLogLevel(logLevel, logger) { - if (logLevel instanceof Number) { + if (Number.isInteger(logLevel)) { if (logger) { if (_loggers[logger]) { @@ -406,7 +406,7 @@ return /******/ (function(modules) { // webpackBootstrap /*istanbul ignore next*/exports.LogLevel = _logLevel.LogLevel; /*istanbul ignore next*/exports.LogAppender = _appender.LogAppender; - //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context != 'string') {\n\n        if (typeof context == 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context == 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context == 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (logLevel instanceof Number) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} + //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","isInteger","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context !== 'string') {\n\n        if (typeof context === 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context === 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context === 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (Number.isInteger(logLevel)) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} /***/ }), /* 1 */ @@ -530,6 +530,24 @@ return /******/ (function(modules) { // webpackBootstrap ); }; + /** + * @function + * @memberOf formatter + * + * @param {LOG_EVENT} logEvent + * + * @return {string} + */ + var _formatColumn = function _formatColumn(logEvent) { + + if (!logEvent.column) { + _getFileDetails(logEvent); + } + + return (/*istanbul ignore next*/'' + logEvent.column + ); + }; + /** * @function * @memberOf formatter @@ -652,6 +670,7 @@ return /******/ (function(modules) { // webpackBootstrap 'F|file': _formatFile, 'K|map|MAP': _formatMapMessage, 'L|line': _formatLineNumber, + 'column': _formatColumn, 'm|msg|message': _formatLogMessage, 'M|method': _formatMethodName, 'n': _formatLineSeparator, @@ -868,7 +887,10 @@ return /******/ (function(modules) { // webpackBootstrap if (true) { var path = __webpack_require__(5); var appDir = path.dirname(__webpack_require__.c[0].filename); - logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\|\/)/, ''); + if (!fileParts[0].startsWith(appDir)) { + appDir = ''; + } + logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\|\/)/, ''); } else { logEvent.filename = fileParts.join(':'); } @@ -878,6 +900,7 @@ return /******/ (function(modules) { // webpackBootstrap logEvent.filename = 'anonymous'; logEvent.lineNumber = '?'; } + logEvent.file = logEvent.filename; }; /** @@ -904,7 +927,7 @@ return /******/ (function(modules) { // webpackBootstrap function format(layout, logEvent) { return _formatLogEvent(_getCompiledLayout(layout), logEvent); } - //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","column","pop","define","path","require","appDir","dirname","main","filename"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} + //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatColumn","column","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","pop","define","path","require","appDir","dirname","main","filename","startsWith"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatColumn = function (logEvent) {\n\n    if (!logEvent.column) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.column}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'column' : _formatColumn,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tif (!fileParts[0].startsWith(appDir)) {\n\t\t\t\tappDir = '';\n\t\t\t}\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\tlogEvent.file = logEvent.filename;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} /***/ }), /* 2 */ diff --git a/dist/es6/formatter.js b/dist/es6/formatter.js index a6561ee..641a13c 100644 --- a/dist/es6/formatter.js +++ b/dist/es6/formatter.js @@ -117,6 +117,23 @@ let _formatLineNumber = function (logEvent) { return `${logEvent.lineNumber}`; }; +/** + * @function + * @memberOf formatter + * + * @param {LOG_EVENT} logEvent + * + * @return {string} + */ +let _formatColumn = function (logEvent) { + + if (!logEvent.column) { + _getFileDetails(logEvent); + } + + return `${logEvent.column}`; +}; + /** * @function * @memberOf formatter @@ -239,6 +256,7 @@ let _formatters = { 'F|file': _formatFile, 'K|map|MAP': _formatMapMessage, 'L|line': _formatLineNumber, + 'column': _formatColumn, 'm|msg|message': _formatLogMessage, 'M|method': _formatMethodName, 'n': _formatLineSeparator, @@ -455,7 +473,10 @@ let _getFileDetails = function (logEvent) { if (typeof define !== 'undefined') { let path = require('path'); let appDir = path.dirname(require.main.filename); - logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\|\/)/, ''); + if (!fileParts[0].startsWith(appDir)) { + appDir = ''; + } + logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\|\/)/, ''); } else { logEvent.filename = fileParts.join(':'); } @@ -465,6 +486,7 @@ let _getFileDetails = function (logEvent) { logEvent.filename = 'anonymous'; logEvent.lineNumber = '?'; } + logEvent.file = logEvent.filename; }; /** @@ -491,4 +513,4 @@ function preCompile(layout) { function format(layout, logEvent) { return _formatLogEvent(_getCompiledLayout(layout), logEvent); } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","column","pop","define","path","require","appDir","dirname","main","filename"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatColumn","column","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","pop","define","path","require","appDir","dirname","main","filename","startsWith"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatColumn = function (logEvent) {\n\n    if (!logEvent.column) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.column}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'column' : _formatColumn,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tif (!fileParts[0].startsWith(appDir)) {\n\t\t\t\tappDir = '';\n\t\t\t}\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\tlogEvent.file = logEvent.filename;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} \ No newline at end of file diff --git a/dist/es6/index.js b/dist/es6/index.js index c27a7e9..842cdd9 100644 --- a/dist/es6/index.js +++ b/dist/es6/index.js @@ -295,15 +295,15 @@ function getLogger(context) { } // determine the context - if (typeof context != 'string') { + if (typeof context !== 'string') { - if (typeof context == 'function') { + if (typeof context === 'function') { context = utility.getFunctionName(context); - } else if (typeof context == 'object') { + } else if (typeof context === 'object') { context = utility.getFunctionName(context.constructor); - if (context == 'Object') { + if (context === 'Object') { context = 'anonymous'; } } else { @@ -327,7 +327,7 @@ function getLogger(context) { */ function setLogLevel(logLevel, logger) { - if (logLevel instanceof Number) { + if (Number.isInteger(logLevel)) { if (logger) { if (_loggers[logger]) { @@ -349,4 +349,4 @@ addAppender( /*istanbul ignore next*/_consoleAppender.ConsoleAppender); /*istanbul ignore next*/exports.LogLevel = _logLevel.LogLevel; /*istanbul ignore next*/exports.LogAppender = _appender.LogAppender; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context != 'string') {\n\n        if (typeof context == 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context == 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context == 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (logLevel instanceof Number) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","isInteger","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context !== 'string') {\n\n        if (typeof context === 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context === 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context === 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (Number.isInteger(logLevel)) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} \ No newline at end of file diff --git a/dist/es6/log4js2.js b/dist/es6/log4js2.js index 134d455..047fcaf 100644 --- a/dist/es6/log4js2.js +++ b/dist/es6/log4js2.js @@ -351,15 +351,15 @@ return /******/ (function(modules) { // webpackBootstrap } // determine the context - if (typeof context != 'string') { + if (typeof context !== 'string') { - if (typeof context == 'function') { + if (typeof context === 'function') { context = utility.getFunctionName(context); - } else if (typeof context == 'object') { + } else if (typeof context === 'object') { context = utility.getFunctionName(context.constructor); - if (context == 'Object') { + if (context === 'Object') { context = 'anonymous'; } } else { @@ -383,7 +383,7 @@ return /******/ (function(modules) { // webpackBootstrap */ function setLogLevel(logLevel, logger) { - if (logLevel instanceof Number) { + if (Number.isInteger(logLevel)) { if (logger) { if (_loggers[logger]) { @@ -405,7 +405,7 @@ return /******/ (function(modules) { // webpackBootstrap /*istanbul ignore next*/exports.LogLevel = _logLevel.LogLevel; /*istanbul ignore next*/exports.LogAppender = _appender.LogAppender; - //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context != 'string') {\n\n        if (typeof context == 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context == 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context == 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (logLevel instanceof Number) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} + //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["configure","addAppender","getLogger","setLogLevel","formatter","utility","APPENDER","CONFIG_PARAMS","_MAIN_LOGGER","_DEFAULT_APPENDERS","INFO","_DEFAULT_CONFIG","_APPENDER_METHODS","_appenders","_configuration","_finalized","_loggers","config","console","error","layout","_configureAppenders","appenders","_configureLoggers","loggers","Array","forEach","appender","Function","Error","logger","tag","logLevel","ERROR","_getAppendersForLogger","appenderList","Object","keys","key","prototype","setLayout","push","allowAppenderInjection","_validateAppender","name","appenderObj","element","undefined","_append","logEvent","isActive","level","append","context","getFunctionName","constructor","Number","isInteger","hasOwnProperty","LogLevel","LogAppender"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016 Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\n/**\n * Holds the definition for the appender closure\n *\n * @typedef {{ append : function (number, LOG_EVENT), isActive : function(),\n *          setLogLevel : function(number), setLayout : function(string) }}\n */\nlet APPENDER;\n\n/**\n * @typedef {{ allowAppenderInjection : boolean, appenders : Array.<APPENDER>,\n * \t\t\tapplication : Object, loggers : Array.<LogAppender>, layout : string }}\n */\nlet CONFIG_PARAMS;\n\nimport * as formatter from './formatter';\nimport * as utility from './utility';\nimport {LogAppender} from './appender/appender';\nimport {Logger} from './logger/logger';\nimport {LogLevel} from './const/logLevel';\nimport {ConsoleAppender} from './appender/consoleAppender';\n\n/**\n * The name of the main logger. We use this in case no logger is specified\n * @const\n */\nconst _MAIN_LOGGER = 'main';\n\n/**\n * The default appenders that should be included if no appenders are specified\n * @const\n */\nconst _DEFAULT_APPENDERS = [{\n    'appender' : ConsoleAppender,\n    'level' : LogLevel.INFO\n}];\n\n/**\n * The default configuration for log4js2. If no configuration is specified, then this\n * configuration will be injected\n * @const\n */\nconst _DEFAULT_CONFIG = {\n    'allowAppenderInjection' : true,\n    'appenders' : _DEFAULT_APPENDERS,\n    'loggers' : [{\n        'level' : LogLevel.INFO\n    }],\n    'layout' : '%d [%p] %c - %m'\n};\n\n/**\n * The methods that an appender must contain\n * @const\n */\nconst _APPENDER_METHODS = ['append', 'getName', 'isActive', 'setLogLevel', 'setLayout'];\n\n/** @type {Object} */\nlet _appenders = {};\n/** @type {?CONFIG_PARAMS} */\nlet _configuration = null;\n/** @type {boolean} */\nlet _finalized = false;\n/** @type {Object} */\nlet _loggers = {};\n\n/**\n * Configures the logger\n *\n * @function\n * @memberOf log4js\n *\n * @params {CONFIG_PARAMS} config\n */\nexport function configure(config) {\n\n\tif (_finalized) {\n\t\tconsole.error('Could not configure - already in use');\n\t\treturn;\n\t}\n\n\tif (!_configuration) {\n        _configuration = {};\n    }\n\n    // set the default layout\n    if (!config.layout && !_configuration.layout) {\n        _configuration.layout = _DEFAULT_CONFIG.layout;\n    } else if (config.layout) {\n        _configuration.layout = config.layout;\n    }\n\n\t// configure the appenders\n\t_configureAppenders(config.appenders);\n    // configure the loggers\n    _configureLoggers(config.loggers);\n\n}\n\n/**\n * Configures appenders\n *\n * @private\n * @function\n *\n * @param {Array.<LogAppender|function>} appenders\n */\nlet _configureAppenders = function (appenders) {\n\n    if (!(appenders instanceof Array)) {\n        appenders = _DEFAULT_APPENDERS;\n    }\n\n    appenders.forEach(appender => {\n        if (appender instanceof Function) {\n            addAppender(appender);\n        }\n    });\n\n};\n\n/**\n * Configures the loggers\n *\n * @private\n * @function\n *\n * @param {Array.<Object>} loggers\n */\nlet _configureLoggers = function (loggers) {\n\n\tif (!(loggers instanceof Array)) {\n\t\tthrow new Error('Invalid loggers');\n\t}\n\n    loggers.forEach(function (logger) {\n\n        if (!logger.layout || typeof logger.layout !== 'string') {\n            logger.layout = _configuration.layout;\n        }\n\n        logger.tag = logger.tag || _MAIN_LOGGER;\n        logger.logLevel = logger.logLevel || LogLevel.ERROR;\n\n        _loggers[logger.tag] = _getAppendersForLogger(logger.logLevel, logger.layout);\n\n    });\n\n};\n\n/**\n * Gets the appenders for the level and layout\n *\n * @private\n * @function\n *\n * @param {number} logLevel\n * @param {string} layout\n *\n * @returns {Array}\n */\nlet _getAppendersForLogger = function (logLevel, layout) {\n\n    let logger;\n    let appenderList = [];\n\n    Object.keys(_appenders).forEach(function (key) {\n\n        logger = (_appenders[key].prototype instanceof LogAppender) ? new _appenders[key]() : _appenders[key]();\n\n        logger.setLogLevel(logLevel);\n        logger.setLayout(layout);\n\n        appenderList.push(logger);\n\n    });\n\n\treturn appenderList;\n\n};\n\n/**\n * Adds an appender to the appender queue. If the stack is finalized, and\n * the allowAppenderInjection is set to false, then the event will not be\n * appended\n *\n * @function\n * @memberOf log4js\n *\n * @params {LogAppender} appender\n */\nexport function addAppender(appender) {\n\n\tif (_finalized && !_configuration.allowAppenderInjection) {\n\t\tconsole.error('Cannot add appender when configuration finalized');\n\t\treturn;\n\t}\n\n    _validateAppender(appender);\n\n    // only put the appender into the set if it doesn't exist already\n    if (!_appenders[appender.name]) {\n        _appenders[appender.name] = appender;\n    }\n\n}\n\n/**\n * Validates that the appender\n *\n * @private\n * @function\n *\n * @params {APPENDER} appender\n * @throws {Error} if the appender is invalid\n */\nlet _validateAppender = function (appender) {\n\n    // if we are running ES6, we can make sure it extends LogAppender\n    // otherwise, it must be a function\n    if (appender.prototype instanceof LogAppender) {\n        return;\n    } else if (!(appender instanceof Function)) {\n\t\tthrow new Error('Invalid appender: not a function or class LogAppender');\n\t}\n\n\t// instantiate the appender function\n\tlet appenderObj = appender();\n\n    // ensure that the appender methods are present (and are functions)\n    _APPENDER_METHODS.forEach(function (element) {\n        if (appenderObj[element] == undefined || !(appenderObj[element] instanceof Function)) {\n            throw new Error(`Invalid appender: missing/invalid method: ${element}`);\n        }\n    });\n\n};\n\n/**\n * Appends the log event\n *\n * @private\n * @function\n *\n * @param {Object} logEvent\n */\nfunction _append(logEvent) {\n\n\t// finalize the configuration to make sure no other appender can be injected (if set)\n\t_finalized = true;\n\n    // cycle through each appender for the logger and append the logging event\n    (_loggers[logEvent.logger] || _loggers[_MAIN_LOGGER]).forEach(function (logger) {\n        if (logger.isActive(logEvent.level)) {\n            logger.append(logEvent);\n        }\n    });\n\n}\n\n/**\n * Handles creating the logger and returning it\n *\n * @function\n * @memberOf log4js\n *\n * @param {function|string=} context\n *\n * @return {Logger}\n */\nexport function getLogger(context) {\n\n\t// we need to initialize if we haven't\n\tif (!_configuration) {\n\t\tconfigure(_DEFAULT_CONFIG);\n\t}\n\n    // determine the context\n    if (typeof context !== 'string') {\n\n        if (typeof context === 'function') {\n            context = utility.getFunctionName(context);\n        } else if (typeof context === 'object') {\n\n            context = utility.getFunctionName(context.constructor);\n\n            if (context === 'Object') {\n                context = 'anonymous';\n            }\n\n        } else {\n            context = _MAIN_LOGGER;\n        }\n\n    }\n\n\treturn new Logger(context, {\n\t\t'append' : _append\n\t});\n\n}\n\n\n\n/**\n * Sets the log level for all appenders of a logger, or specified logger\n *\n * @function\n * @memberOf log4js\n *\n * @param {number} logLevel\n * @param {string=} logger\n */\nexport function setLogLevel(logLevel, logger) {\n\n    if (Number.isInteger(logLevel)) {\n\n        if (logger) {\n            if (_loggers[logger]) {\n                _loggers[logger].setLogLevel(logLevel);\n            }\n        } else {\n            for (let key in _loggers) {\n                if (_loggers.hasOwnProperty(key)) {\n                    _loggers[key].forEach(function (appender) {\n                        appender.setLogLevel(logLevel);\n                    });\n                }\n            }\n        }\n\n    }\n\n}\n\naddAppender(ConsoleAppender);\n\nexport { LogLevel };\nexport { LogAppender };\n"]} /***/ }), /* 1 */ @@ -530,6 +530,23 @@ return /******/ (function(modules) { // webpackBootstrap return `${logEvent.lineNumber}`; }; + /** + * @function + * @memberOf formatter + * + * @param {LOG_EVENT} logEvent + * + * @return {string} + */ + let _formatColumn = function (logEvent) { + + if (!logEvent.column) { + _getFileDetails(logEvent); + } + + return `${logEvent.column}`; + }; + /** * @function * @memberOf formatter @@ -652,6 +669,7 @@ return /******/ (function(modules) { // webpackBootstrap 'F|file': _formatFile, 'K|map|MAP': _formatMapMessage, 'L|line': _formatLineNumber, + 'column': _formatColumn, 'm|msg|message': _formatLogMessage, 'M|method': _formatMethodName, 'n': _formatLineSeparator, @@ -868,7 +886,10 @@ return /******/ (function(modules) { // webpackBootstrap if (true) { let path = __webpack_require__(5); let appDir = path.dirname(__webpack_require__.c[0].filename); - logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\|\/)/, ''); + if (!fileParts[0].startsWith(appDir)) { + appDir = ''; + } + logEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\|\/)/, ''); } else { logEvent.filename = fileParts.join(':'); } @@ -878,6 +899,7 @@ return /******/ (function(modules) { // webpackBootstrap logEvent.filename = 'anonymous'; logEvent.lineNumber = '?'; } + logEvent.file = logEvent.filename; }; /** @@ -904,7 +926,7 @@ return /******/ (function(modules) { // webpackBootstrap function format(layout, logEvent) { return _formatLogEvent(_getCompiledLayout(layout), logEvent); } - //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","column","pop","define","path","require","appDir","dirname","main","filename"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} + //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["formatter.js"],"names":["preCompile","format","utility","_COMMAND_REGEX","_compiledLayouts","_formatLogger","logEvent","logger","_formatDate","params","date","_formatException","message","error","stack","undefined","stacks","split","forEach","name","_formatFile","file","_getFileDetails","_formatLineNumber","lineNumber","_formatColumn","column","_formatMapMessage","properties","key","push","join","_formatLogMessage","_formatMethodName","getFunctionName","method","_formatLineSeparator","_formatLevel","level","FATAL","ERROR","WARN","INFO","DEBUG","TRACE","_formatRelative","relative","_formatSequenceNumber","sequence","_formatters","_getCompiledLayout","layout","_compileLayout","index","indexOf","currentFormatString","formatArray","substring","startIndex","endIndex","_getFormatterObject","formatString","result","exec","length","formatter","_getFormatterFunction","_getLayoutTagParams","after","lastIndexOf","command","regex","hasOwnProperty","RegExp","match","i","_formatLogEvent","response","count","Object","trim","logErrorStack","parts","replace","location","host","fileParts","pop","define","path","require","appDir","dirname","main","filename","startsWith"],"mappings":"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","file":"formatter.js","sourcesContent":["/**\n * log4js <https://github.com/anigenero/log4js>\n *\n * Copyright 2016-present Robin Schultz <http://anigenero.com>\n * Released under the MIT License\n */\n\nimport {dateFormat} from './dateFormatter';\nimport * as utility from './utility';\nimport {LogLevel} from './const/logLevel';\n\n/** @const */\nconst _COMMAND_REGEX = /%([a-z,A-Z]+)(?=\\{|)/;\n\n/** @type {Object} */\nlet _compiledLayouts = {};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogger = function (logEvent) {\n\treturn logEvent.logger;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatDate = function (logEvent, params) {\n\treturn dateFormat(logEvent.date, params[0]);\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatException = function (logEvent) {\n\n    let message = '';\n\n    if (logEvent.error != null) {\n\n\t\tif (logEvent.error.stack != undefined) {\n\t\t\tlet stacks = logEvent.error.stack.split(/\\n/g);\n            stacks.forEach(function (stack) {\n                message += `\\t${stack}\\n`;\n            });\n\t\t} else if (logEvent.error.message != null && logEvent.error.message != '') {\n\t\t\tmessage += `\\t${logEvent.error.name}: ${logEvent.error.message}\\n`;\n\t\t}\n\n\t}\n\n\treturn message;\n\n};\n\n/**\n * Formats the file (e.g. test.js) to the file\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _formatFile = function (logEvent) {\n\n    if (!logEvent.file) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn logEvent.file;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLineNumber = function (logEvent) {\n\n    if (!logEvent.lineNumber) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.lineNumber}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatColumn = function (logEvent) {\n\n    if (!logEvent.column) {\n\t\t_getFileDetails(logEvent);\n\t}\n\n\treturn `${logEvent.column}`;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n * @param {Array.<string>} params\n *\n * @return {string}\n */\nlet _formatMapMessage = function (logEvent, params) {\n\tlet message = null;\n\tif (logEvent.properties) {\n\n\t\tmessage = [];\n\t\tfor (let key in logEvent.properties) {\n\t\t\tif (params[0]) {\n\t\t\t\tif (params[0] == key) {\n\t\t\t\t\tmessage.push(logEvent.properties[key]);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmessage.push('{' + key + ',' + logEvent.properties[key] + '}');\n\t\t\t}\n\t\t}\n\n\t\treturn '{' + message.join(',') + '}';\n\n\t}\n\treturn message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogMessage = function (logEvent) {\n\treturn logEvent.message;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatMethodName = function (logEvent) {\n\treturn utility.getFunctionName(logEvent.method);\n};\n\n/**\n * @private\n * @function\n * @memberOf formatter\n */\nlet _formatLineSeparator = function () {\n\treturn '\\n';\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLevel = function (logEvent) {\n\n    switch (logEvent.level) {\n\n        case LogLevel.FATAL:\n            return 'FATAL';\n        case LogLevel.ERROR:\n            return 'ERROR';\n        case LogLevel.WARN:\n            return 'WARN';\n        case LogLevel.INFO:\n            return 'INFO';\n        case LogLevel.DEBUG:\n            return 'DEBUG';\n        case LogLevel.TRACE:\n        default:\n            return 'TRACE';\n\n    }\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatRelative = function (logEvent) {\n\treturn '' + logEvent.relative;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatSequenceNumber = function (logEvent) {\n\treturn '' + logEvent.sequence;\n};\n\nlet _formatters = {\n\t'c|logger' : _formatLogger,\n\t'd|date' : _formatDate,\n\t'ex|exception|throwable' : _formatException,\n\t'F|file' : _formatFile,\n\t'K|map|MAP' : _formatMapMessage,\n\t'L|line' : _formatLineNumber,\n\t'column' : _formatColumn,\n\t'm|msg|message' : _formatLogMessage,\n\t'M|method' : _formatMethodName,\n\t'n' : _formatLineSeparator,\n\t'p|level' : _formatLevel,\n\t'r|relative' : _formatRelative,\n\t'sn|sequenceNumber' : _formatSequenceNumber\n};\n\n/**\n * Get the compiled layout for the specified layout string. If the compiled layout does not\n * exist, then we want to create it.\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _getCompiledLayout = function (layout) {\n\n\tif (_compiledLayouts[layout]) {\n\t\treturn _compiledLayouts[layout];\n\t}\n\n\treturn _compileLayout(layout);\n\n};\n\n/**\n * Compiles a layout into an array. The array contains functions\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {Array.<string|function>}\n */\nlet _compileLayout = function (layout) {\n\n\tlet index = layout.indexOf('%');\n\tlet currentFormatString = '';\n\tlet formatArray = [];\n\n\tif (index != 0) {\n\t\tformatArray.push(layout.substring(0, index));\n\t}\n\n\tdo {\n\n\t\tlet startIndex = index;\n\t\tlet endIndex = index = layout.indexOf('%', index + 1);\n\n\t\tif (endIndex < 0) {\n\t\t\tcurrentFormatString = layout.substring(startIndex);\n\t\t} else {\n\t\t\tcurrentFormatString = layout.substring(startIndex, endIndex);\n\t\t}\n\n\t\tformatArray.push(_getFormatterObject(currentFormatString));\n\n\t} while (index > -1);\n\n    // set the format array to the specified compiled layout\n\t_compiledLayouts[layout] = formatArray;\n\n\treturn formatArray;\n\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} formatString\n *\n * @return {Object|string}\n */\nlet _getFormatterObject = function (formatString) {\n\n\tlet result = _COMMAND_REGEX.exec(formatString);\n\tif (result != null && result.length == 2) {\n\n\t\tlet formatter = _getFormatterFunction(result[1]);\n\t\tif (!formatter) {\n\t\t\treturn null;\n\t\t}\n\n\t\tlet params = _getLayoutTagParams(formatString);\n\n\t\tlet after = '';\n\t\tlet endIndex = formatString.lastIndexOf('}');\n\t\tif (endIndex != -1) {\n\t\t\tafter = formatString.substring(endIndex + 1);\n\t\t} else {\n\t\t\tafter = formatString.substring(result.index + result[1].length + 1);\n\t\t}\n\n\t\treturn {\n\t\t\t'formatter' : formatter,\n\t\t\t'params' : params,\n\t\t\t'after' : after\n\t\t};\n\n\t}\n\n\treturn formatString;\n\n};\n\n/**\n * Determines what formatter function has been configured\n *\n * @function\n * @memberOf formatter\n *\n * @param {string} command\n *\n * @return {?string}\n */\nlet _getFormatterFunction = function (command) {\n\n\tlet regex;\n\tfor (let key in _formatters) {\n        if (_formatters.hasOwnProperty(key)) {\n            regex = new RegExp('^(' + key + ')$');\n            if (regex.exec(command)) {\n                return _formatters[key];\n            }\n        }\n\t}\n\n\treturn null;\n\n};\n\n/**\n * Gets the layout tag params associated with the layout tag. So, for example, '%d{yyyy-MM-dd}`\n * would output an array of ['yyyy-MM-dd']\n *\n * @private\n * @function\n *\n * @param {string} command\n *\n * @return {Array.<string>}\n */\nlet _getLayoutTagParams = function (command) {\n\n\tlet params = [];\n\tlet result = command.match(/\\{([^}]*)(?=})/g);\n\tif (result != null) {\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tparams.push(result[i].substring(1));\n\t\t}\n\t}\n\n\treturn params;\n\n};\n\n/**\n * Handles formatting the log event using the specified formatter array\n *\n * @private\n * @function\n *\n * @param {Array.<function|string>} formatter\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nlet _formatLogEvent = function (formatter, logEvent) {\n\n\tlet response;\n\tlet message = '';\n\tlet count = formatter.length;\n\tfor (let i = 0; i < count; i++) {\n\t\tif (formatter[i] !== null) {\n\n\t\t\tif (formatter[i] instanceof Object) {\n\n\t\t\t\tresponse = formatter[i].formatter(logEvent, formatter[i].params);\n\t\t\t\tif (response != null) {\n\t\t\t\t\tmessage += response;\n\t\t\t\t}\n\t\t\t\tmessage += formatter[i].after;\n\n\t\t\t} else {\n\t\t\t\tmessage += formatter[i];\n\t\t\t}\n\n\t\t}\n\t}\n\n\treturn message.trim();\n\n};\n\n/**\n *\n * @private\n * @function\n * @memberOf formatter\n *\n * @param {LOG_EVENT} logEvent\n */\nlet _getFileDetails = function (logEvent) {\n\n\tif (logEvent.logErrorStack) {\n\n\t\tlet parts = logEvent.logErrorStack.stack.split(/\\n/g);\n\t\tlet file = parts[3];\n\t\tfile = file.replace(/at (.*\\(|)(file|http|https|)(:|)(\\/|)*/, '');\n\t\tfile = file.replace(')', '');\n\t\tfile = file.replace((typeof location !== 'undefined') ? location.host : '', '').trim();\n\n\t\tlet fileParts = file.split(/\\:/g);\n\n\t\tlogEvent.column = fileParts.pop();\n\t\tlogEvent.lineNumber = fileParts.pop();\n\n\t\tif (typeof define !== 'undefined') {\n\t\t\tlet path = require('path');\n\t\t\tlet appDir = path.dirname(require.main.filename);\n\t\t\tif (!fileParts[0].startsWith(appDir)) {\n\t\t\t\tappDir = '';\n\t\t\t}\n\t\t\tlogEvent.filename = fileParts.join(':').replace(appDir, '').replace(/^(\\\\|\\/)/, '');\n\t\t} else {\n\t\t\tlogEvent.filename = fileParts.join(':');\n\t\t}\n\n\t} else {\n\n\t\tlogEvent.column = '?';\n\t\tlogEvent.filename = 'anonymous';\n\t\tlogEvent.lineNumber = '?';\n\n\t}\n\tlogEvent.file = logEvent.filename;\n};\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n *\n * @return {string}\n */\nexport function preCompile(layout) {\n\t_getCompiledLayout(layout);\n}\n\n/**\n * @function\n * @memberOf formatter\n *\n * @param {string} layout\n * @param {LOG_EVENT} logEvent\n *\n * @return {string}\n */\nexport function format(layout, logEvent) {\n\treturn _formatLogEvent(_getCompiledLayout(layout), logEvent);\n}\n"]} /***/ }), /* 2 */ diff --git a/dist/log4js2.es5.min.js b/dist/log4js2.es5.min.js index ca81b33..7de89c1 100644 --- a/dist/log4js2.es5.min.js +++ b/dist/log4js2.es5.min.js @@ -1 +1 @@ -!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports.log4js=n():e.log4js=n()}(this,function(){return function(e){function n(r){if(t[r])return t[r].exports;var o=t[r]={exports:{},id:r,loaded:!1};return e[r].call(o.exports,o,o.exports,n),o.loaded=!0,o.exports}var t={};return n.m=e,n.c=t,n.p="",n(0)}([function(e,n,t){"use strict";function r(e){if(e&&e.__esModule)return e;var n={};if(null!=e)for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&(n[t]=e[t]);return n.default=e,n}function o(e){if(w)return void console.error("Could not configure - already in use");M||(M={}),e.layout||M.layout?e.layout&&(M.layout=e.layout):M.layout=L.layout,E(e.appenders),O(e.loggers)}function i(e){if(w&&!M.allowAppenderInjection)return void console.error("Cannot add appender when configuration finalized");R(e),A[e.name]||(A[e.name]=e)}function u(e){w=!0,(T[e.logger]||T[h]).forEach(function(n){n.isActive(e.level)&&n.append(e)})}function a(e){return M||o(L),"string"!=typeof e&&("function"==typeof e?e=p.getFunctionName(e):"object"==(void 0===e?"undefined":s(e))?"Object"==(e=p.getFunctionName(e.constructor))&&(e="anonymous"):e=h),new d.Logger(e,{append:u})}function l(e,n){if(e instanceof Number)if(n)T[n]&&T[n].setLogLevel(e);else for(var t in T)T.hasOwnProperty(t)&&T[t].forEach(function(n){n.setLogLevel(e)})}n.__esModule=!0,n.LogAppender=n.LogLevel=void 0;var s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};n.configure=o,n.addAppender=i,n.getLogger=a,n.setLogLevel=l;var c=t(1),f=(r(c),t(3)),p=r(f),g=t(7),d=t(8),v=t(4),y=t(9),h="main",m=[{appender:y.ConsoleAppender,level:v.LogLevel.INFO}],L={allowAppenderInjection:!0,appenders:m,loggers:[{level:v.LogLevel.INFO}],layout:"%d [%p] %c - %m"},b=["append","getName","isActive","setLogLevel","setLayout"],A={},M=null,w=!1,T={},E=function(e){e instanceof Array||(e=m),e.forEach(function(e){e instanceof Function&&i(e)})},O=function(e){if(!(e instanceof Array))throw new Error("Invalid loggers");e.forEach(function(e){e.layout&&"string"==typeof e.layout||(e.layout=M.layout),e.tag=e.tag||h,e.logLevel=e.logLevel||v.LogLevel.ERROR,T[e.tag]=S(e.logLevel,e.layout)})},S=function(e,n){var t=void 0,r=[];return Object.keys(A).forEach(function(o){t=A[o].prototype instanceof g.LogAppender?new A[o]:A[o](),t.setLogLevel(e),t.setLayout(n),r.push(t)}),r},R=function(e){if(!(e.prototype instanceof g.LogAppender)){if(!(e instanceof Function))throw new Error("Invalid appender: not a function or class LogAppender");var n=e();b.forEach(function(e){if(void 0==n[e]||!(n[e]instanceof Function))throw new Error("Invalid appender: missing/invalid method: "+e)})}};i(y.ConsoleAppender),n.LogLevel=v.LogLevel,n.LogAppender=g.LogAppender},function(e,n,t){"use strict";function r(e){T(e)}function o(e,n){return F(T(e),n)}n.__esModule=!0,n.preCompile=r,n.format=o;var i=t(2),u=t(3),a=function(e){if(e&&e.__esModule)return e;var n={};if(null!=e)for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&(n[t]=e[t]);return n.default=e,n}(u),l=t(4),s=/%([a-z,A-Z]+)(?=\{|)/,c={},f=function(e){return e.logger},p=function(e,n){return(0,i.dateFormat)(e.date,n[0])},g=function(e){var n="";if(null!=e.error)if(void 0!=e.error.stack){var t=e.error.stack.split(/\n/g);t.forEach(function(e){n+="\t"+e+"\n"})}else null!=e.error.message&&""!=e.error.message&&(n+="\t"+e.error.name+": "+e.error.message+"\n");return n},d=function(e){return e.file||j(e),e.file},v=function(e){return e.lineNumber||j(e),""+e.lineNumber},y=function(e,n){var t=null;if(e.properties){t=[];for(var r in e.properties)n[0]?n[0]==r&&t.push(e.properties[r]):t.push("{"+r+","+e.properties[r]+"}");return"{"+t.join(",")+"}"}return t},h=function(e){return e.message},m=function(e){return a.getFunctionName(e.method)},L=function(){return"\n"},b=function(e){switch(e.level){case l.LogLevel.FATAL:return"FATAL";case l.LogLevel.ERROR:return"ERROR";case l.LogLevel.WARN:return"WARN";case l.LogLevel.INFO:return"INFO";case l.LogLevel.DEBUG:return"DEBUG";case l.LogLevel.TRACE:default:return"TRACE"}},A=function(e){return""+e.relative},M=function(e){return""+e.sequence},w={"c|logger":f,"d|date":p,"ex|exception|throwable":g,"F|file":d,"K|map|MAP":y,"L|line":v,"m|msg|message":h,"M|method":m,n:L,"p|level":b,"r|relative":A,"sn|sequenceNumber":M},T=function(e){return c[e]?c[e]:E(e)},E=function(e){var n=e.indexOf("%"),t="",r=[];0!=n&&r.push(e.substring(0,n));do{var o=n,i=n=e.indexOf("%",n+1);t=i<0?e.substring(o):e.substring(o,i),r.push(O(t))}while(n>-1);return c[e]=r,r},O=function(e){var n=s.exec(e);if(null!=n&&2==n.length){var t=S(n[1]);if(!t)return null;var r=R(e),o="",i=e.lastIndexOf("}");return o=-1!=i?e.substring(i+1):e.substring(n.index+n[1].length+1),{formatter:t,params:r,after:o}}return e},S=function(e){var n=void 0;for(var t in w)if(w.hasOwnProperty(t)&&(n=new RegExp("^("+t+")$"),n.exec(e)))return w[t];return null},R=function(e){var n=[],t=e.match(/\{([^}]*)(?=})/g);if(null!=t)for(var r=0;r0?"-":"+")+t(100*Math.floor(Math.abs(h)/60)+Math.abs(h)%60,4)};return n.replace(i,function(e){return e in m?m[e]:e})}n.__esModule=!0,n.dateFormat=r;var o={d:["Sun","Mon","Tue","Wed","Thu","Fri","Sat","Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],m:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec","January","February","March","April","May","June","July","August","September","October","November","December"]},i=/d{1,4}|M{1,4}|yy(?:yy)?|([HhmsAa])\1?|[LloSZ]|'[^']*'|'[^']*'/g,u=/\b(?:[PMCEA][SDP]T|(?:Pacific|Mountain|Central|Eastern|Atlantic) (?:Standard|Daylight|Prevailing) Time|(?:GMT|UTC)(?:[-+]\d{4})?)\b/g,a=/[^-+\dA-Z]/g,l={DEFAULT:"yyyy-MM-dd HH:mm:ss,S",ABSOLUTE:"HH:MM:ss,S",COMPACT:"yyyyMMddHHmmssS",DATE:"dd MMM yyyy HH:mm:ss,S",ISO8601:"yyyy-MM-ddTHH:mm:ss,S",ISO8601_BASIC:"yyyyMMddTHHmmss,S"}},function(e,n){"use strict";function t(e){var n=e.toString().substring("function ".length);return n=n.substring(0,n.indexOf("(")),n&&n.trim()?n:"anonymous"}n.__esModule=!0,n.getFunctionName=t},function(e,n){"use strict";n.__esModule=!0;n.LogLevel={OFF:0,FATAL:100,ERROR:200,WARN:300,INFO:400,DEBUG:500,TRACE:600,ALL:2147483647}},function(e,n,t){(function(e){function t(e,n){for(var t=0,r=e.length-1;r>=0;r--){var o=e[r];"."===o?e.splice(r,1):".."===o?(e.splice(r,1),t++):t&&(e.splice(r,1),t--)}if(n)for(;t--;t)e.unshift("..");return e}function r(e,n){if(e.filter)return e.filter(n);for(var t=[],r=0;r=-1&&!o;i--){var u=i>=0?arguments[i]:e.cwd();if("string"!=typeof u)throw new TypeError("Arguments to path.resolve must be strings");u&&(n=u+"/"+n,o="/"===u.charAt(0))}return n=t(r(n.split("/"),function(e){return!!e}),!o).join("/"),(o?"/":"")+n||"."},n.normalize=function(e){var o=n.isAbsolute(e),i="/"===u(e,-1);return e=t(r(e.split("/"),function(e){return!!e}),!o).join("/"),e||o||(e="."),e&&i&&(e+="/"),(o?"/":"")+e},n.isAbsolute=function(e){return"/"===e.charAt(0)},n.join=function(){var e=Array.prototype.slice.call(arguments,0);return n.normalize(r(e,function(e,n){if("string"!=typeof e)throw new TypeError("Arguments to path.join must be strings");return e}).join("/"))},n.relative=function(e,t){function r(e){for(var n=0;n=0&&""===e[t];t--);return n>t?[]:e.slice(n,t-n+1)}e=n.resolve(e).substr(1),t=n.resolve(t).substr(1);for(var o=r(e.split("/")),i=r(t.split("/")),u=Math.min(o.length,i.length),a=u,l=0;l1)for(var t=1;t-1&&console.log(n)},u(n,null,[{key:"name",get:function(){return"console"}}]),n}(a.LogAppender)}])}); \ No newline at end of file +!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports.log4js=n():e.log4js=n()}(this,function(){return function(e){function n(r){if(t[r])return t[r].exports;var o=t[r]={exports:{},id:r,loaded:!1};return e[r].call(o.exports,o,o.exports,n),o.loaded=!0,o.exports}var t={};return n.m=e,n.c=t,n.p="",n(0)}([function(e,n,t){"use strict";function r(e){if(e&&e.__esModule)return e;var n={};if(null!=e)for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&(n[t]=e[t]);return n.default=e,n}function o(e){if(w)return void console.error("Could not configure - already in use");M||(M={}),e.layout||M.layout?e.layout&&(M.layout=e.layout):M.layout=L.layout,E(e.appenders),O(e.loggers)}function i(e){if(w&&!M.allowAppenderInjection)return void console.error("Cannot add appender when configuration finalized");R(e),A[e.name]||(A[e.name]=e)}function u(e){w=!0,(T[e.logger]||T[m]).forEach(function(n){n.isActive(e.level)&&n.append(e)})}function a(e){return M||o(L),"string"!=typeof e&&("function"==typeof e?e=p.getFunctionName(e):"object"===(void 0===e?"undefined":s(e))?"Object"===(e=p.getFunctionName(e.constructor))&&(e="anonymous"):e=m),new d.Logger(e,{append:u})}function l(e,n){if(Number.isInteger(e))if(n)T[n]&&T[n].setLogLevel(e);else for(var t in T)T.hasOwnProperty(t)&&T[t].forEach(function(n){n.setLogLevel(e)})}n.__esModule=!0,n.LogAppender=n.LogLevel=void 0;var s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};n.configure=o,n.addAppender=i,n.getLogger=a,n.setLogLevel=l;var c=t(1),f=(r(c),t(3)),p=r(f),g=t(7),d=t(8),v=t(4),y=t(9),m="main",h=[{appender:y.ConsoleAppender,level:v.LogLevel.INFO}],L={allowAppenderInjection:!0,appenders:h,loggers:[{level:v.LogLevel.INFO}],layout:"%d [%p] %c - %m"},b=["append","getName","isActive","setLogLevel","setLayout"],A={},M=null,w=!1,T={},E=function(e){e instanceof Array||(e=h),e.forEach(function(e){e instanceof Function&&i(e)})},O=function(e){if(!(e instanceof Array))throw new Error("Invalid loggers");e.forEach(function(e){e.layout&&"string"==typeof e.layout||(e.layout=M.layout),e.tag=e.tag||m,e.logLevel=e.logLevel||v.LogLevel.ERROR,T[e.tag]=S(e.logLevel,e.layout)})},S=function(e,n){var t=void 0,r=[];return Object.keys(A).forEach(function(o){t=A[o].prototype instanceof g.LogAppender?new A[o]:A[o](),t.setLogLevel(e),t.setLayout(n),r.push(t)}),r},R=function(e){if(!(e.prototype instanceof g.LogAppender)){if(!(e instanceof Function))throw new Error("Invalid appender: not a function or class LogAppender");var n=e();b.forEach(function(e){if(void 0==n[e]||!(n[e]instanceof Function))throw new Error("Invalid appender: missing/invalid method: "+e)})}};i(y.ConsoleAppender),n.LogLevel=v.LogLevel,n.LogAppender=g.LogAppender},function(e,n,t){"use strict";function r(e){E(e)}function o(e,n){return j(E(e),n)}n.__esModule=!0,n.preCompile=r,n.format=o;var i=t(2),u=t(3),a=function(e){if(e&&e.__esModule)return e;var n={};if(null!=e)for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&(n[t]=e[t]);return n.default=e,n}(u),l=t(4),s=/%([a-z,A-Z]+)(?=\{|)/,c={},f=function(e){return e.logger},p=function(e,n){return(0,i.dateFormat)(e.date,n[0])},g=function(e){var n="";if(null!=e.error)if(void 0!=e.error.stack){var t=e.error.stack.split(/\n/g);t.forEach(function(e){n+="\t"+e+"\n"})}else null!=e.error.message&&""!=e.error.message&&(n+="\t"+e.error.name+": "+e.error.message+"\n");return n},d=function(e){return e.file||_(e),e.file},v=function(e){return e.lineNumber||_(e),""+e.lineNumber},y=function(e){return e.column||_(e),""+e.column},m=function(e,n){var t=null;if(e.properties){t=[];for(var r in e.properties)n[0]?n[0]==r&&t.push(e.properties[r]):t.push("{"+r+","+e.properties[r]+"}");return"{"+t.join(",")+"}"}return t},h=function(e){return e.message},L=function(e){return a.getFunctionName(e.method)},b=function(){return"\n"},A=function(e){switch(e.level){case l.LogLevel.FATAL:return"FATAL";case l.LogLevel.ERROR:return"ERROR";case l.LogLevel.WARN:return"WARN";case l.LogLevel.INFO:return"INFO";case l.LogLevel.DEBUG:return"DEBUG";case l.LogLevel.TRACE:default:return"TRACE"}},M=function(e){return""+e.relative},w=function(e){return""+e.sequence},T={"c|logger":f,"d|date":p,"ex|exception|throwable":g,"F|file":d,"K|map|MAP":m,"L|line":v,column:y,"m|msg|message":h,"M|method":L,n:b,"p|level":A,"r|relative":M,"sn|sequenceNumber":w},E=function(e){return c[e]?c[e]:O(e)},O=function(e){var n=e.indexOf("%"),t="",r=[];0!=n&&r.push(e.substring(0,n));do{var o=n,i=n=e.indexOf("%",n+1);t=i<0?e.substring(o):e.substring(o,i),r.push(S(t))}while(n>-1);return c[e]=r,r},S=function(e){var n=s.exec(e);if(null!=n&&2==n.length){var t=R(n[1]);if(!t)return null;var r=F(e),o="",i=e.lastIndexOf("}");return o=-1!=i?e.substring(i+1):e.substring(n.index+n[1].length+1),{formatter:t,params:r,after:o}}return e},R=function(e){var n=void 0;for(var t in T)if(T.hasOwnProperty(t)&&(n=new RegExp("^("+t+")$"),n.exec(e)))return T[t];return null},F=function(e){var n=[],t=e.match(/\{([^}]*)(?=})/g);if(null!=t)for(var r=0;r0?"-":"+")+t(100*Math.floor(Math.abs(m)/60)+Math.abs(m)%60,4)};return n.replace(i,function(e){return e in h?h[e]:e})}n.__esModule=!0,n.dateFormat=r;var o={d:["Sun","Mon","Tue","Wed","Thu","Fri","Sat","Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],m:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec","January","February","March","April","May","June","July","August","September","October","November","December"]},i=/d{1,4}|M{1,4}|yy(?:yy)?|([HhmsAa])\1?|[LloSZ]|'[^']*'|'[^']*'/g,u=/\b(?:[PMCEA][SDP]T|(?:Pacific|Mountain|Central|Eastern|Atlantic) (?:Standard|Daylight|Prevailing) Time|(?:GMT|UTC)(?:[-+]\d{4})?)\b/g,a=/[^-+\dA-Z]/g,l={DEFAULT:"yyyy-MM-dd HH:mm:ss,S",ABSOLUTE:"HH:MM:ss,S",COMPACT:"yyyyMMddHHmmssS",DATE:"dd MMM yyyy HH:mm:ss,S",ISO8601:"yyyy-MM-ddTHH:mm:ss,S",ISO8601_BASIC:"yyyyMMddTHHmmss,S"}},function(e,n){"use strict";function t(e){var n=e.toString().substring("function ".length);return n=n.substring(0,n.indexOf("(")),n&&n.trim()?n:"anonymous"}n.__esModule=!0,n.getFunctionName=t},function(e,n){"use strict";n.__esModule=!0;n.LogLevel={OFF:0,FATAL:100,ERROR:200,WARN:300,INFO:400,DEBUG:500,TRACE:600,ALL:2147483647}},function(e,n,t){(function(e){function t(e,n){for(var t=0,r=e.length-1;r>=0;r--){var o=e[r];"."===o?e.splice(r,1):".."===o?(e.splice(r,1),t++):t&&(e.splice(r,1),t--)}if(n)for(;t--;t)e.unshift("..");return e}function r(e,n){if(e.filter)return e.filter(n);for(var t=[],r=0;r=-1&&!o;i--){var u=i>=0?arguments[i]:e.cwd();if("string"!=typeof u)throw new TypeError("Arguments to path.resolve must be strings");u&&(n=u+"/"+n,o="/"===u.charAt(0))}return n=t(r(n.split("/"),function(e){return!!e}),!o).join("/"),(o?"/":"")+n||"."},n.normalize=function(e){var o=n.isAbsolute(e),i="/"===u(e,-1);return e=t(r(e.split("/"),function(e){return!!e}),!o).join("/"),e||o||(e="."),e&&i&&(e+="/"),(o?"/":"")+e},n.isAbsolute=function(e){return"/"===e.charAt(0)},n.join=function(){var e=Array.prototype.slice.call(arguments,0);return n.normalize(r(e,function(e,n){if("string"!=typeof e)throw new TypeError("Arguments to path.join must be strings");return e}).join("/"))},n.relative=function(e,t){function r(e){for(var n=0;n=0&&""===e[t];t--);return n>t?[]:e.slice(n,t-n+1)}e=n.resolve(e).substr(1),t=n.resolve(t).substr(1);for(var o=r(e.split("/")),i=r(t.split("/")),u=Math.min(o.length,i.length),a=u,l=0;l1)for(var t=1;t-1&&console.log(n)},u(n,null,[{key:"name",get:function(){return"console"}}]),n}(a.LogAppender)}])}); \ No newline at end of file diff --git a/dist/log4js2.es6.min.js b/dist/log4js2.es6.min.js index f4efa52..b18edeb 100644 --- a/dist/log4js2.es6.min.js +++ b/dist/log4js2.es6.min.js @@ -2,22 +2,22 @@ exports.addAppender=addAppender;exports.getLogger=getLogger;exports.setLogLevel=setLogLevel;var _formatter=__webpack_require__(1);var formatter=_interopRequireWildcard(_formatter);var _utility=__webpack_require__(3);var utility=_interopRequireWildcard(_utility);var _appender=__webpack_require__(7);var _logger=__webpack_require__(8);var _logLevel=__webpack_require__(4);var _consoleAppender=__webpack_require__(9);function _interopRequireWildcard(obj){if(obj&&obj.__esModule){return obj}else{var newObj={};if(obj!=null){for(var key in obj){if(Object.prototype.hasOwnProperty.call(obj,key)){newObj[key]=obj[key]}}}newObj.default=obj;return newObj}}let APPENDER;let CONFIG_PARAMS;const _MAIN_LOGGER='main';const _DEFAULT_APPENDERS=[{'appender':_consoleAppender.ConsoleAppender,'level':_logLevel.LogLevel.INFO}];const _DEFAULT_CONFIG={'allowAppenderInjection':true,'appenders':_DEFAULT_APPENDERS,'loggers':[{'level':_logLevel.LogLevel.INFO}],'layout':'%d [%p] %c - %m'}; const _APPENDER_METHODS=['append','getName','isActive','setLogLevel','setLayout'];let _appenders={};let _configuration=null;let _finalized=false;let _loggers={};function configure(config){if(_finalized){console.error('Could not configure - already in use');return}if(!_configuration){_configuration={}}if(!config.layout&&!_configuration.layout){_configuration.layout=_DEFAULT_CONFIG.layout}else if(config.layout){_configuration.layout=config.layout}_configureAppenders(config.appenders);_configureLoggers(config.loggers)}let _configureAppenders=function(appenders){if(!(appenders instanceof Array)){appenders=_DEFAULT_APPENDERS}appenders.forEach(appender=>{if(appender instanceof Function){addAppender(appender)}})};let _configureLoggers=function(loggers){if(!(loggers instanceof Array)){throw new Error('Invalid loggers')}loggers.forEach(function(logger){if(!logger.layout||typeof logger.layout!=='string'){logger.layout=_configuration.layout}logger.tag=logger.tag||_MAIN_LOGGER;logger.logLevel=logger. logLevel||_logLevel.LogLevel.ERROR;_loggers[logger.tag]=_getAppendersForLogger(logger.logLevel,logger.layout)})};let _getAppendersForLogger=function(logLevel,layout){let logger;let appenderList=[];Object.keys(_appenders).forEach(function(key){logger=_appenders[key].prototype instanceof _appender.LogAppender?new _appenders[key]():_appenders[key]();logger.setLogLevel(logLevel);logger.setLayout(layout);appenderList.push(logger)});return appenderList};function addAppender(appender){if(_finalized&&!_configuration.allowAppenderInjection){console.error('Cannot add appender when configuration finalized');return}_validateAppender(appender);if(!_appenders[appender.name]){_appenders[appender.name]=appender}}let _validateAppender=function(appender){if(appender.prototype instanceof _appender.LogAppender){return}else if(!(appender instanceof Function)){throw new Error('Invalid appender: not a function or class LogAppender')}let appenderObj=appender(); -_APPENDER_METHODS.forEach(function(element){if(appenderObj[element]==undefined||!(appenderObj[element]instanceof Function)){throw new Error(`Invalid appender: missing/invalid method: ${ element }`)}})};function _append(logEvent){_finalized=true;(_loggers[logEvent.logger]||_loggers[_MAIN_LOGGER]).forEach(function(logger){if(logger.isActive(logEvent.level)){logger.append(logEvent)}})}function getLogger(context){if(!_configuration){configure(_DEFAULT_CONFIG)}if(typeof context!='string'){if(typeof context=='function'){context=utility.getFunctionName(context)}else if(typeof context=='object'){context=utility.getFunctionName(context.constructor);if(context=='Object'){context='anonymous'}}else{context=_MAIN_LOGGER}}return new _logger.Logger(context,{'append':_append})}function setLogLevel(logLevel,logger){if(logLevel instanceof Number){if(logger){if(_loggers[logger]){_loggers[logger].setLogLevel(logLevel)}}else{for(let key in _loggers){if(_loggers.hasOwnProperty(key)){_loggers[key].forEach(function( -appender){appender.setLogLevel(logLevel)})}}}}}addAppender(_consoleAppender.ConsoleAppender);exports.LogLevel=_logLevel.LogLevel;exports.LogAppender=_appender.LogAppender;}),(function(module,exports,__webpack_require__){'use strict';Object.defineProperty(exports,"__esModule",{value:true});exports.preCompile=preCompile;exports.format=format;var _dateFormatter=__webpack_require__(2);var _utility=__webpack_require__(3);var utility=_interopRequireWildcard(_utility);var _logLevel=__webpack_require__(4);function _interopRequireWildcard(obj){if(obj&&obj.__esModule){return obj}else{var newObj={};if(obj!=null){for(var key in obj){if(Object.prototype.hasOwnProperty.call(obj,key)){newObj[key]=obj[key]}}}newObj.default=obj;return newObj}}const _COMMAND_REGEX=/%([a-z,A-Z]+)(?=\{|)/;let _compiledLayouts={};let _formatLogger=function(logEvent){return logEvent.logger};let _formatDate=function(logEvent,params){return((0,_dateFormatter.dateFormat)(logEvent.date,params[0]))}; -let _formatException=function(logEvent){let message='';if(logEvent.error!=null){if(logEvent.error.stack!=undefined){let stacks=logEvent.error.stack.split(/\n/g);stacks.forEach(function(stack){message+=`\t${ stack }\n`})}else if(logEvent.error.message!=null&&logEvent.error.message!=''){message+=`\t${logEvent.error.name }: ${logEvent.error.message }\n`}}return message};let _formatFile=function(logEvent){if(!logEvent.file){_getFileDetails(logEvent)}return logEvent.file};let _formatLineNumber=function(logEvent){if(!logEvent.lineNumber){_getFileDetails(logEvent)}return `${logEvent.lineNumber }`};let _formatMapMessage=function(logEvent,params){let message=null;if(logEvent.properties){message=[];for(let key in logEvent.properties){if(params[0]){if(params[0]==key){message.push(logEvent.properties[key])}}else{message.push('{'+key+','+logEvent.properties[key]+'}')}}return '{'+message.join(',')+'}'}return message}; -let _formatLogMessage=function(logEvent){return logEvent.message};let _formatMethodName=function(logEvent){return utility.getFunctionName(logEvent.method)};let _formatLineSeparator=function(){return '\n'};let _formatLevel=function(logEvent){switch(logEvent.level){case _logLevel.LogLevel.FATAL:return 'FATAL';case _logLevel.LogLevel.ERROR:return 'ERROR';case _logLevel.LogLevel.WARN:return 'WARN';case _logLevel.LogLevel.INFO:return 'INFO';case _logLevel.LogLevel.DEBUG:return 'DEBUG';case _logLevel.LogLevel.TRACE:default:return 'TRACE'}};let _formatRelative=function(logEvent){return ''+logEvent.relative};let _formatSequenceNumber=function(logEvent){return ''+logEvent.sequence};let _formatters={'c|logger':_formatLogger,'d|date':_formatDate,'ex|exception|throwable':_formatException,'F|file':_formatFile,'K|map|MAP':_formatMapMessage,'L|line':_formatLineNumber,'m|msg|message':_formatLogMessage,'M|method':_formatMethodName,'n':_formatLineSeparator,'p|level':_formatLevel,'r|relative':_formatRelative, -'sn|sequenceNumber':_formatSequenceNumber};let _getCompiledLayout=function(layout){if(_compiledLayouts[layout]){return _compiledLayouts[layout]}return _compileLayout(layout)};let _compileLayout=function(layout){let index=layout.indexOf('%');let currentFormatString='';let formatArray=[];if(index!=0){formatArray.push(layout.substring(0,index))}do{let startIndex=index;let endIndex=index=layout.indexOf('%',index+1);if(endIndex<0){currentFormatString=layout.substring(startIndex)}else{currentFormatString=layout.substring(startIndex,endIndex)}formatArray.push(_getFormatterObject(currentFormatString))}while(index>-1);_compiledLayouts[layout]=formatArray;return formatArray};let _getFormatterObject=function(formatString){let result=_COMMAND_REGEX.exec(formatString);if(result!=null&&result.length==2){let formatter=_getFormatterFunction(result[1]);if(!formatter){return null}let params=_getLayoutTagParams(formatString);let after='';let endIndex=formatString.lastIndexOf('}');if(endIndex!=-1){after= -formatString.substring(endIndex+1)}else{after=formatString.substring(result.index+result[1].length+1)}return{'formatter':formatter,'params':params,'after':after}}return formatString};let _getFormatterFunction=function(command){let regex;for(let key in _formatters){if(_formatters.hasOwnProperty(key)){regex=new RegExp('^('+key+')$');if(regex.exec(command)){return _formatters[key]}}}return null};let _getLayoutTagParams=function(command){let params=[];let result=command.match(/\{([^}]*)(?=})/g);if(result!=null){for(let i=0;i0?'-':'+')+pad(Math.floor(Math.abs(offset)/ -60)*100+Math.abs(offset)%60,4)};return mask.replace(TOKEN,function($0){return $0 in flags?flags[$0]:$0})}}),(function(module,exports){'use strict';Object.defineProperty(exports,"__esModule",{value:true});exports.getFunctionName=getFunctionName;function getFunctionName(func){let name=func.toString().substring('function '.length);name=name.substring(0,name.indexOf('('));return name&&name.trim()?name:'anonymous'}}),(function(module,exports){'use strict';Object.defineProperty(exports,"__esModule",{value:true});const LogLevel=exports.LogLevel={'OFF':0,'FATAL':100,'ERROR':200,'WARN':300,'INFO':400,'DEBUG':500,'TRACE':600,'ALL':2147483647};}),(function(module,exports,__webpack_require__){(function(process){function normalizeArray(parts,allowAboveRoot){var up=0;for(var i=parts.length-1;i>=0;i-=1){var last=parts[i];if(last==='.'){parts.splice(i,1)}else if(last==='..'){parts.splice(i,1);up+=1}else if(up){parts.splice(i,1);up-=1}}if(allowAboveRoot){for(;up-=1;up){parts.unshift('..')}}return parts}var splitPathRe= -/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;var splitPath=function(filename){return splitPathRe.exec(filename).slice(1)};exports.resolve=function(){var resolvedPath='',resolvedAbsolute=false;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i-=1){var path=(i>=0)?arguments[i]:process.cwd();if(typeof path!=='string'){throw new TypeError('Arguments to path.resolve must be strings')}else if(!path){continue}resolvedPath=path+'/'+resolvedPath;resolvedAbsolute=path.charAt(0)==='/'}resolvedPath=normalizeArray(filter(resolvedPath.split('/'),function(p){return!!p}),!resolvedAbsolute).join('/');return((resolvedAbsolute?'/':'')+resolvedPath)||'.'};exports.normalize=function(path){var isAbsolute=exports.isAbsolute(path),trailingSlash=substr(path,-1)==='/';path=normalizeArray(filter(path.split('/'),function(p){return!!p}),!isAbsolute).join('/');if(!path&&!isAbsolute){path='.'}if(path&&trailingSlash){path+='/'}return(isAbsolute?'/':'')+path};exports.isAbsolute=function(path){ -return path.charAt(0)==='/'};exports.join=function(){var paths=Array.prototype.slice.call(arguments,0);return exports.normalize(filter(paths,function(p,index){if(typeof p!=='string'){throw new TypeError('Arguments to path.join must be strings')}return p}).join('/'))};exports.relative=function(from,to){from=exports.resolve(from).substr(1);to=exports.resolve(to).substr(1);function trim(arr){var start=0;for(;start=0;end-=1){if(arr[end]!==''){break}}if(start>end){return[]}return arr.slice(start,end-start+1)}var fromParts=trim(from.split('/'));var toParts=trim(to.split('/'));var length=Math.min(fromParts.length,toParts.length);var samePartsLength=length;for(var i=0;i1){for(var i=1;i-1){console.log(message)}}}exports.ConsoleAppender=ConsoleAppender;})])});; \ No newline at end of file +_APPENDER_METHODS.forEach(function(element){if(appenderObj[element]==undefined||!(appenderObj[element]instanceof Function)){throw new Error(`Invalid appender: missing/invalid method: ${ element }`)}})};function _append(logEvent){_finalized=true;(_loggers[logEvent.logger]||_loggers[_MAIN_LOGGER]).forEach(function(logger){if(logger.isActive(logEvent.level)){logger.append(logEvent)}})}function getLogger(context){if(!_configuration){configure(_DEFAULT_CONFIG)}if(typeof context!=='string'){if(typeof context==='function'){context=utility.getFunctionName(context)}else if(typeof context==='object'){context=utility.getFunctionName(context.constructor);if(context==='Object'){context='anonymous'}}else{context=_MAIN_LOGGER}}return new _logger.Logger(context,{'append':_append})}function setLogLevel(logLevel,logger){if(Number.isInteger(logLevel)){if(logger){if(_loggers[logger]){_loggers[logger].setLogLevel(logLevel)}}else{for(let key in _loggers){if(_loggers.hasOwnProperty(key)){_loggers[key].forEach( +function(appender){appender.setLogLevel(logLevel)})}}}}}addAppender(_consoleAppender.ConsoleAppender);exports.LogLevel=_logLevel.LogLevel;exports.LogAppender=_appender.LogAppender;}),(function(module,exports,__webpack_require__){'use strict';Object.defineProperty(exports,"__esModule",{value:true});exports.preCompile=preCompile;exports.format=format;var _dateFormatter=__webpack_require__(2);var _utility=__webpack_require__(3);var utility=_interopRequireWildcard(_utility);var _logLevel=__webpack_require__(4);function _interopRequireWildcard(obj){if(obj&&obj.__esModule){return obj}else{var newObj={};if(obj!=null){for(var key in obj){if(Object.prototype.hasOwnProperty.call(obj,key)){newObj[key]=obj[key]}}}newObj.default=obj;return newObj}}const _COMMAND_REGEX=/%([a-z,A-Z]+)(?=\{|)/;let _compiledLayouts={};let _formatLogger=function(logEvent){return logEvent.logger}; +let _formatDate=function(logEvent,params){return((0,_dateFormatter.dateFormat)(logEvent.date,params[0]))};let _formatException=function(logEvent){let message='';if(logEvent.error!=null){if(logEvent.error.stack!=undefined){let stacks=logEvent.error.stack.split(/\n/g);stacks.forEach(function(stack){message+=`\t${ stack }\n`})}else if(logEvent.error.message!=null&&logEvent.error.message!=''){message+=`\t${logEvent.error.name }: ${logEvent.error.message }\n`}}return message};let _formatFile=function(logEvent){if(!logEvent.file){_getFileDetails(logEvent)}return logEvent.file};let _formatLineNumber=function(logEvent){if(!logEvent.lineNumber){_getFileDetails(logEvent)}return `${logEvent.lineNumber }`};let _formatColumn=function(logEvent){if(!logEvent.column){_getFileDetails(logEvent)}return `${logEvent.column }`};let _formatMapMessage=function(logEvent,params){let message=null;if(logEvent.properties){message=[];for(let key in logEvent.properties){if(params[0]){if(params[0]==key){message.push(logEvent. +properties[key])}}else{message.push('{'+key+','+logEvent.properties[key]+'}')}}return '{'+message.join(',')+'}'}return message};let _formatLogMessage=function(logEvent){return logEvent.message};let _formatMethodName=function(logEvent){return utility.getFunctionName(logEvent.method)};let _formatLineSeparator=function(){return '\n'};let _formatLevel=function(logEvent){switch(logEvent.level){case _logLevel.LogLevel.FATAL:return 'FATAL';case _logLevel.LogLevel.ERROR:return 'ERROR';case _logLevel.LogLevel.WARN:return 'WARN';case _logLevel.LogLevel.INFO:return 'INFO';case _logLevel.LogLevel.DEBUG:return 'DEBUG';case _logLevel.LogLevel.TRACE:default:return 'TRACE'}};let _formatRelative=function(logEvent){return ''+logEvent.relative};let _formatSequenceNumber=function(logEvent){return ''+logEvent.sequence};let _formatters={'c|logger':_formatLogger,'d|date':_formatDate,'ex|exception|throwable':_formatException,'F|file':_formatFile,'K|map|MAP':_formatMapMessage,'L|line':_formatLineNumber,'column':_formatColumn, +'m|msg|message':_formatLogMessage,'M|method':_formatMethodName,'n':_formatLineSeparator,'p|level':_formatLevel,'r|relative':_formatRelative,'sn|sequenceNumber':_formatSequenceNumber};let _getCompiledLayout=function(layout){if(_compiledLayouts[layout]){return _compiledLayouts[layout]}return _compileLayout(layout)};let _compileLayout=function(layout){let index=layout.indexOf('%');let currentFormatString='';let formatArray=[];if(index!=0){formatArray.push(layout.substring(0,index))}do{let startIndex=index;let endIndex=index=layout.indexOf('%',index+1);if(endIndex<0){currentFormatString=layout.substring(startIndex)}else{currentFormatString=layout.substring(startIndex,endIndex)}formatArray.push(_getFormatterObject(currentFormatString))}while(index>-1);_compiledLayouts[layout]=formatArray;return formatArray};let _getFormatterObject=function(formatString){let result=_COMMAND_REGEX.exec(formatString);if(result!=null&&result.length==2){let formatter=_getFormatterFunction(result[1]);if(!formatter){ +return null}let params=_getLayoutTagParams(formatString);let after='';let endIndex=formatString.lastIndexOf('}');if(endIndex!=-1){after=formatString.substring(endIndex+1)}else{after=formatString.substring(result.index+result[1].length+1)}return{'formatter':formatter,'params':params,'after':after}}return formatString};let _getFormatterFunction=function(command){let regex;for(let key in _formatters){if(_formatters.hasOwnProperty(key)){regex=new RegExp('^('+key+')$');if(regex.exec(command)){return _formatters[key]}}}return null};let _getLayoutTagParams=function(command){let params=[];let result=command.match(/\{([^}]*)(?=})/g);if(result!=null){for(let i=0;i0?'-':'+')+pad(Math.floor(Math.abs(offset)/60)*100+Math.abs(offset)%60,4)};return mask.replace(TOKEN,function($0){return $0 in flags?flags[$0]:$0})}}),(function(module,exports){'use strict';Object.defineProperty(exports,"__esModule",{value:true});exports.getFunctionName=getFunctionName;function getFunctionName(func){let name=func.toString().substring('function '.length);name=name.substring(0,name.indexOf('('));return name&&name.trim()?name:'anonymous'}}),(function(module,exports){'use strict';Object.defineProperty(exports,"__esModule",{value:true});const LogLevel=exports.LogLevel={'OFF':0,'FATAL':100,'ERROR':200,'WARN':300,'INFO':400,'DEBUG':500,'TRACE':600,'ALL':2147483647};}),(function(module,exports,__webpack_require__){(function(process){function normalizeArray(parts,allowAboveRoot){ +var up=0;for(var i=parts.length-1;i>=0;i-=1){var last=parts[i];if(last==='.'){parts.splice(i,1)}else if(last==='..'){parts.splice(i,1);up+=1}else if(up){parts.splice(i,1);up-=1}}if(allowAboveRoot){for(;up-=1;up){parts.unshift('..')}}return parts}var splitPathRe=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;var splitPath=function(filename){return splitPathRe.exec(filename).slice(1)};exports.resolve=function(){var resolvedPath='',resolvedAbsolute=false;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i-=1){var path=(i>=0)?arguments[i]:process.cwd();if(typeof path!=='string'){throw new TypeError('Arguments to path.resolve must be strings')}else if(!path){continue}resolvedPath=path+'/'+resolvedPath;resolvedAbsolute=path.charAt(0)==='/'}resolvedPath=normalizeArray(filter(resolvedPath.split('/'),function(p){return!!p}),!resolvedAbsolute).join('/');return((resolvedAbsolute?'/':'')+resolvedPath)||'.'};exports.normalize=function(path){var isAbsolute=exports.isAbsolute(path), +trailingSlash=substr(path,-1)==='/';path=normalizeArray(filter(path.split('/'),function(p){return!!p}),!isAbsolute).join('/');if(!path&&!isAbsolute){path='.'}if(path&&trailingSlash){path+='/'}return(isAbsolute?'/':'')+path};exports.isAbsolute=function(path){return path.charAt(0)==='/'};exports.join=function(){var paths=Array.prototype.slice.call(arguments,0);return exports.normalize(filter(paths,function(p,index){if(typeof p!=='string'){throw new TypeError('Arguments to path.join must be strings')}return p}).join('/'))};exports.relative=function(from,to){from=exports.resolve(from).substr(1);to=exports.resolve(to).substr(1);function trim(arr){var start=0;for(;start=0;end-=1){if(arr[end]!==''){break}}if(start>end){return[]}return arr.slice(start,end-start+1)}var fromParts=trim(from.split('/'));var toParts=trim(to.split('/'));var length=Math.min(fromParts.length,toParts.length);var samePartsLength=length;for(var i= +0;i1){for(var i=1;i-1){console.log(message)}}}exports.ConsoleAppender=ConsoleAppender;})])});; \ No newline at end of file diff --git a/package.json b/package.json index 945642a..9a51d83 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "log4js2", - "version": "1.0.1", + "version": "1.0.2", "scripts": { "build": "gulp build", "test": "gulp test" diff --git a/src/formatter.js b/src/formatter.js index 2f49c0f..3bf9b93 100644 --- a/src/formatter.js +++ b/src/formatter.js @@ -248,7 +248,7 @@ let _formatters = { 'F|file' : _formatFile, 'K|map|MAP' : _formatMapMessage, 'L|line' : _formatLineNumber, - 'column': _formatColumn, + 'column' : _formatColumn, 'm|msg|message' : _formatLogMessage, 'M|method' : _formatMethodName, 'n' : _formatLineSeparator, @@ -471,7 +471,7 @@ let _getFileDetails = function (logEvent) { logEvent.column = fileParts.pop(); logEvent.lineNumber = fileParts.pop(); - + if (typeof define !== 'undefined') { let path = require('path'); let appDir = path.dirname(require.main.filename); diff --git a/src/index.js b/src/index.js index b17c34c..931379b 100644 --- a/src/index.js +++ b/src/index.js @@ -282,15 +282,15 @@ export function getLogger(context) { } // determine the context - if (typeof context != 'string') { + if (typeof context !== 'string') { - if (typeof context == 'function') { + if (typeof context === 'function') { context = utility.getFunctionName(context); - } else if (typeof context == 'object') { + } else if (typeof context === 'object') { context = utility.getFunctionName(context.constructor); - if (context == 'Object') { + if (context === 'Object') { context = 'anonymous'; }