@meteor-it/logger
Advanced tools
Comparing version 2.3.15 to 2.3.16
{ | ||
"name": "@meteor-it/logger", | ||
"version": "2.3.15", | ||
"version": "2.3.16", | ||
"description": "Most powerfull logger for node.js", | ||
@@ -19,3 +19,3 @@ "main": "index.js", | ||
}, | ||
"gitHead": "3d10baec01cd8de8e7af988796764d2fcf4087f7" | ||
"gitHead": "c0af336e7277978a0c0b2e366dcb53dbbcfc65db" | ||
} |
@@ -90,5 +90,5 @@ "use strict"; | ||
const strings = data.string.split('\n'); | ||
let ret = ` \u001B[40m${stringifyName(nameLimit, provider.nameLimit, data.name, escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${strings.shift()}`; | ||
let ret = `\u001B[40m${stringifyName(nameLimit, provider.nameLimit, data.name, escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${strings.shift()}`; | ||
for (let string of strings) { | ||
ret += ` \n\u001B[40m${stringifyName(nameLimit, provider.nameLimit, ' |', escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${string}`; | ||
ret += `\n\u001B[40m${stringifyName(nameLimit, provider.nameLimit, ' |', escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${string}`; | ||
//`${stringifyIdent(data.identationLength)}${stringifyName(provider.nameLimit,'|',escapeCode)} ${string}\n`; | ||
@@ -99,12 +99,12 @@ } | ||
function writeLogData(nameLimit, provider, data) { | ||
terminal_1.writeStdout('\n' + stringifyCommonData(nameLimit, '34m', provider, data)); | ||
terminal_1.writeStdout(stringifyCommonData(nameLimit, '34m', provider, data) + '\n'); | ||
} | ||
function writeErrorData(nameLimit, provider, data) { | ||
terminal_1.writeStdout('\n' + stringifyCommonData(nameLimit, '31m', provider, data)); | ||
terminal_1.writeStdout(stringifyCommonData(nameLimit, '31m', provider, data) + '\n'); | ||
} | ||
function writeWarningData(nameLimit, provider, data) { | ||
terminal_1.writeStdout('\n' + stringifyCommonData(nameLimit, '33m', provider, data)); | ||
terminal_1.writeStdout(stringifyCommonData(nameLimit, '33m', provider, data) + '\n'); | ||
} | ||
function writeDebugData(nameLimit, provider, data) { | ||
terminal_1.writeStdout('\n' + stringifyCommonData(nameLimit, '90m', provider, data)); | ||
terminal_1.writeStdout(stringifyCommonData(nameLimit, '90m', provider, data) + '\n'); | ||
} | ||
@@ -168,6 +168,6 @@ const progresses = {}; | ||
case __1.LOGGER_ACTIONS.IDENT: | ||
terminal_1.writeStdout('\n' + stringifyIdentData(nameLimit, this, data)); | ||
terminal_1.writeStdout(stringifyIdentData(nameLimit, this, data) + '\n'); | ||
break; | ||
case __1.LOGGER_ACTIONS.DEENT: | ||
terminal_1.writeStdout('\n' + stringifyDeentData(nameLimit, this, data)); | ||
terminal_1.writeStdout(stringifyDeentData(nameLimit, this, data) + '\n'); | ||
break; | ||
@@ -187,6 +187,6 @@ case __1.LOGGER_ACTIONS.LOG: | ||
case __1.LOGGER_ACTIONS.TIME_START: | ||
terminal_1.writeStdout('\n' + stringifyTimeStartData(nameLimit, this, data)); | ||
terminal_1.writeStdout(stringifyTimeStartData(nameLimit, this, data) + '\n'); | ||
break; | ||
case __1.LOGGER_ACTIONS.TIME_END: | ||
terminal_1.writeStdout('\n' + stringifyTimeEndData(nameLimit, this, data)); | ||
terminal_1.writeStdout(stringifyTimeEndData(nameLimit, this, data) + '\n'); | ||
break; | ||
@@ -231,2 +231,2 @@ case __1.LOGGER_ACTIONS.PROGRESS_START: | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["logger/receivers/node.ts"],"names":[],"mappings":"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","file":"logger/receivers/node.js","sourcesContent":["import {format} from 'util';\nimport Logger,{LOGGER_ACTIONS,BasicReceiver} from '../';\nimport {writeStdout,\n    moveCursor, clearLine, save, restore, startBuffering, flushBuffer} from '@meteor-it/terminal';\n\nconst ansiColors:{[key:string]:number[]} = {\n\treset: [0, 0],\n\n\tbold: [1, 22],\n\tdim: [2, 22],\n\titalic: [3, 23],\n\tunderline: [4, 24],\n\tinverse: [7, 27],\n\thidden: [8, 28],\n\tstrikethrough: [9, 29],\n\n\tblack: [30, 39],\n\tred: [31, 39],\n\tgreen: [32, 39],\n\tyellow: [33, 39],\n\tblue: [34, 39],\n\tmagenta: [35, 39],\n\tcyan: [36, 39],\n\twhite: [37, 39],\n\tgray: [90, 39],\n\n\tbgBlack: [40, 49],\n\tbgRed: [41, 49],\n\tbgGreen: [42, 49],\n\tbgYellow: [43, 49],\n\tbgBlue: [44, 49],\n\tbgMagenta: [45, 49],\n\tbgCyan: [46, 49],\n\tbgWhite: [47, 49]\n};\n\nfunction stringifyIdent(nameLimit:number, count:number, symbolNeeded:string = undefined) {\n\treturn `${'  '.repeat(count)}${symbolNeeded ? symbolNeeded : ' '}`;\n}\n// function writeDate(date) {\n// \t// writeEscape('36m');\n// \t// writeStdout((new Date(date)).toLocaleTimeString());\n// \t// writeEscape('0m');\n// }\nfunction stringifyName(nameLimit:number, limit:number, name:string, escapeCode = '44m') {\n\treturn `\\u001B[${escapeCode}\\u001B[1m${nameLimit===0?'':name.toString().padStart(nameLimit,' ')}\\u001B[0m`;\n}\n// function writeRepeats(count, none = false) {\n// \t// if(process.env.NO_COLLAPSE)none=true;\n// \t// if (none) {\n// \t// \twriteStdout('      ');\n// \t// } else {\n// \t// \tcount += 1;\n// \t// \tif (count >= 20) writeEscape('31m'); else if (count >= 5) writeEscape('33m'); else if (count >= 2) writeEscape('32m'); else\n// \t// \t\twriteEscape('90m');\n// \t// \tif (count >= 999) writeStdout('x999+ '); else if (count === 1) writeStdout('      '); else\n// \t// \t\twriteStdout('x' + fixLength(count.toString(10), 3, false, ' ') + '  ');\n// \t// \twriteEscape('0m');\n// \t// }\n// }\nfunction stringifyIdentData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` ${stringifyName(nameLimit, provider.nameLimit,data.name)} \\u001B[35m${stringifyIdent(nameLimit, data.identationLength-1,'>')}\\u001B[1m ${data.identName}\\u001B[0m`;\n}\nfunction stringifyDeentData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` ${stringifyName(nameLimit, provider.nameLimit,data.name)} \\u001B[35m${stringifyIdent(nameLimit, data.identationLength,'<')}\\u001B[1m ${data.identName}\\u001B[22m (Done in ${data.identTime}ms)\\u001B[0m`;\n}\nfunction stringifyTimeStartData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` \\u001B[35m${stringifyName(nameLimit, provider.nameLimit,data.name,'1m')}\\u001B[33m${stringifyIdent(nameLimit, data.identationLength)} T Started ${data.timeName}`;\n}\nfunction stringifyTimeEndData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` \\u001B[35m${stringifyName(nameLimit, provider.nameLimit,data.name,'1m')}\\u001B[34m${stringifyIdent(nameLimit, data.identationLength)} T Finished ${data.timeName}\\u001B[1m in ${data.timeTime}ms\\u001B[0m`;\n}\nfunction stringifyData(nameLimit:number, data:any) {\n\tlet uncolored = format(data.line, ...data.params || []);\n\treturn uncolored.replace(/{(\\/?)([^}]+)}/g, (...d:any[]) => {\n\t\tif (!ansiColors[d[2]])return d[0];\n\t\treturn '\\u001B[' + ansiColors[d[2]][d[1] === '/' ? 1 : 0] + 'm';\n\t});\n}\n// const STRIPPED_DATE=(new Date()).toLocaleTimeString().replace(/./g, ' ');\nfunction stringifyCommonData(nameLimit:number, escapeCode:string, provider:NodeConsoleReceiver, data:any) {\n\t// writeRepeats(data.repeats, false);\n\t// writeDate(data.time);\n\tconst strings = data.string.split('\\n');\n\tlet ret = ` \\u001B[40m${stringifyName(nameLimit, provider.nameLimit, data.name, escapeCode)}\\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${strings.shift()}`;\n\tfor(let string of strings){\n\t\tret += ` \\n\\u001B[40m${stringifyName(nameLimit, provider.nameLimit, ' |', escapeCode)}\\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${string}`;\n\t\t//`${stringifyIdent(data.identationLength)}${stringifyName(provider.nameLimit,'|',escapeCode)} ${string}\\n`;\n\t}\n\treturn ret;\n}\nfunction writeLogData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\twriteStdout('\\n'+stringifyCommonData(nameLimit, '34m',provider,data));\n}\nfunction writeErrorData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\twriteStdout('\\n'+stringifyCommonData(nameLimit, '31m',provider,data));\n}\nfunction writeWarningData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\twriteStdout('\\n'+stringifyCommonData(nameLimit, '33m',provider,data));\n}\nfunction writeDebugData(nameLimit:number, provider:NodeConsoleReceiver, data:any) {\n\twriteStdout('\\n'+stringifyCommonData(nameLimit, '90m',provider,data));\n}\n\ninterface IProgressItem {\n\tname: string,\n\tprogress: number,\n    time:number\n}\nconst progresses:{[key:string]:IProgressItem}={};\nfunction progressStart(nameLimit:number, provider:NodeConsoleReceiver,data:any){\n\tprogresses[data.name]={\n\t\tname:data.name,\n\t\tprogress:0,\n\t\ttime:data.time\n\t};\n}\nfunction progressEnd(nameLimit:number, provider:NodeConsoleReceiver,data:any){\n\tdelete progresses[data.name];\n}\nfunction progress(nameLimit:number, provider:NodeConsoleReceiver,data:any){\n\tif(!progresses[data.name])\n\t\treturn;\n    progresses[data.name].time=data.time;\n    progresses[data.name].progress=data.progress;\n}\nfunction renderProgress(nameLimit:number){\n\tsave();\n\tlet i=0;\n\tfor(let progress of Object.values(progresses)) {\n        moveCursor(i);\n        clearLine();\n        let percent=Math.ceil(progress.progress);\n        writeStdout(`\\u001B[34m${progress.name.padStart(nameLimit)} ${(percent + '%').padStart(4, ' ')} ${'|'.repeat(Math.ceil(((process.stdout as any).columns - 1 - 3 - 1 - 1 - nameLimit) / 100 * percent))}`);\n        // writeEscape('34m');\n        // writeStdout((<IProgressItem>progress).name.padStart(18,' '));\n        // writeStdout(' ');\n        // writeDate(progress.time);\n        // writeStdout(' ');\n        // writeStdout((percent+'%').padStart(4,' '));\n        // writeStdout(' ');\n        // writeStdout('|'.repeat(Math.ceil(((<any>process.stdout).columns-1-3-1-8-1-18)/100*percent)));\n        i++;\n    }\n\n\trestore();\n}\n\nexport default class NodeConsoleReceiver extends BasicReceiver {\n\tnameLimit:number;\n\n\tconstructor(nameLimit = 18) {\n\t\tsuper();\n\t\tthis.nameLimit = nameLimit;\n\t}\n\n\twrite(data:any) {\n\t\tlet {nameLimit} = this;\n        if(Object.values(progresses).length!==0) {\n            startBuffering();\n        }\n\t\tdata.string = stringifyData(nameLimit, data);\n\t\t// if (data.repeated) {\n\t\t// \tif(!process.env.NO_COLLAPSE){\n\t\t// \t\tsave();\n\t\t// \t\twriteEscape(data.string.split('\\n').length + 'A');\n\t\t// \t\t//data.repeats\n\t\t// \t}\n\t\t// }\n\t\tswitch (data.type) {\n\t\t\tcase LOGGER_ACTIONS.IDENT:\n\t\t\t\twriteStdout('\\n'+stringifyIdentData(nameLimit, this, data));\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.DEENT:\n\t\t\t\twriteStdout('\\n'+stringifyDeentData(nameLimit, this, data));\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.LOG:\n\t\t\t\twriteLogData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.ERROR:\n\t\t\t\twriteErrorData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.WARNING:\n\t\t\t\twriteWarningData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.DEBUG:\n\t\t\t\twriteDebugData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.TIME_START:\n\t\t\t\twriteStdout('\\n'+stringifyTimeStartData(nameLimit, this, data));\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.TIME_END:\n\t\t\t\twriteStdout('\\n'+stringifyTimeEndData(nameLimit, this, data));\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.PROGRESS_START:\n\t\t\t\tprogressStart(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.PROGRESS_END:\n\t\t\t\tprogressEnd(nameLimit, this,data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.PROGRESS:\n\t\t\t\tprogress(nameLimit, this,data);\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tconsole._log(data);\n\t\t}\n\t\t// if (data.repeated) {\n\t\t// \tif(!process.env.NO_COLLAPSE)restore();\n\t\t// }\n        // TODO: Support for non-tty terminals\n        if(Object.values(progresses).length!==0) {\n            renderProgress(nameLimit);\n            flushBuffer();\n        }\n\t}\n}\n\nlet terminalLogger=new Logger('terminal');\n\nprocess.on('uncaughtException', e => {\n\tterminalLogger.err('UncaughtException:');\n\tterminalLogger.err(e.stack);\n\t// process.exit(0);\n});\n\nprocess.on('unhandledRejection', e => {\n\tterminalLogger.err('UnhandledRejection:');\n\tterminalLogger.err(e.stack);\n\t// process.exit(0);\n});\n\n// process.on('warning', e => {\n// \tterminalLogger.warn(e.stack);\n// });"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["logger/receivers/node.ts"],"names":[],"mappings":"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","file":"logger/receivers/node.js","sourcesContent":["import { format } from 'util';\nimport Logger, { LOGGER_ACTIONS, BasicReceiver } from '../';\nimport {\n\twriteStdout,\n\tmoveCursor, clearLine, save, restore, startBuffering, flushBuffer\n} from '@meteor-it/terminal';\n\nconst ansiColors: { [key: string]: number[] } = {\n\treset: [0, 0],\n\n\tbold: [1, 22],\n\tdim: [2, 22],\n\titalic: [3, 23],\n\tunderline: [4, 24],\n\tinverse: [7, 27],\n\thidden: [8, 28],\n\tstrikethrough: [9, 29],\n\n\tblack: [30, 39],\n\tred: [31, 39],\n\tgreen: [32, 39],\n\tyellow: [33, 39],\n\tblue: [34, 39],\n\tmagenta: [35, 39],\n\tcyan: [36, 39],\n\twhite: [37, 39],\n\tgray: [90, 39],\n\n\tbgBlack: [40, 49],\n\tbgRed: [41, 49],\n\tbgGreen: [42, 49],\n\tbgYellow: [43, 49],\n\tbgBlue: [44, 49],\n\tbgMagenta: [45, 49],\n\tbgCyan: [46, 49],\n\tbgWhite: [47, 49]\n};\n\nfunction stringifyIdent(nameLimit: number, count: number, symbolNeeded: string = undefined) {\n\treturn `${'  '.repeat(count)}${symbolNeeded ? symbolNeeded : ' '}`;\n}\n// function writeDate(date) {\n// \t// writeEscape('36m');\n// \t// writeStdout((new Date(date)).toLocaleTimeString());\n// \t// writeEscape('0m');\n// }\nfunction stringifyName(nameLimit: number, limit: number, name: string, escapeCode = '44m') {\n\treturn `\\u001B[${escapeCode}\\u001B[1m${nameLimit === 0 ? '' : name.toString().padStart(nameLimit, ' ')}\\u001B[0m`;\n}\n// function writeRepeats(count, none = false) {\n// \t// if(process.env.NO_COLLAPSE)none=true;\n// \t// if (none) {\n// \t// \twriteStdout('      ');\n// \t// } else {\n// \t// \tcount += 1;\n// \t// \tif (count >= 20) writeEscape('31m'); else if (count >= 5) writeEscape('33m'); else if (count >= 2) writeEscape('32m'); else\n// \t// \t\twriteEscape('90m');\n// \t// \tif (count >= 999) writeStdout('x999+ '); else if (count === 1) writeStdout('      '); else\n// \t// \t\twriteStdout('x' + fixLength(count.toString(10), 3, false, ' ') + '  ');\n// \t// \twriteEscape('0m');\n// \t// }\n// }\nfunction stringifyIdentData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` ${stringifyName(nameLimit, provider.nameLimit, data.name)} \\u001B[35m${stringifyIdent(nameLimit, data.identationLength - 1, '>')}\\u001B[1m ${data.identName}\\u001B[0m`;\n}\nfunction stringifyDeentData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` ${stringifyName(nameLimit, provider.nameLimit, data.name)} \\u001B[35m${stringifyIdent(nameLimit, data.identationLength, '<')}\\u001B[1m ${data.identName}\\u001B[22m (Done in ${data.identTime}ms)\\u001B[0m`;\n}\nfunction stringifyTimeStartData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` \\u001B[35m${stringifyName(nameLimit, provider.nameLimit, data.name, '1m')}\\u001B[33m${stringifyIdent(nameLimit, data.identationLength)} T Started ${data.timeName}`;\n}\nfunction stringifyTimeEndData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\t// writeRepeats(0, true);\n\t// writeDate(data.time);\n\treturn ` \\u001B[35m${stringifyName(nameLimit, provider.nameLimit, data.name, '1m')}\\u001B[34m${stringifyIdent(nameLimit, data.identationLength)} T Finished ${data.timeName}\\u001B[1m in ${data.timeTime}ms\\u001B[0m`;\n}\nfunction stringifyData(nameLimit: number, data: any) {\n\tlet uncolored = format(data.line, ...data.params || []);\n\treturn uncolored.replace(/{(\\/?)([^}]+)}/g, (...d: any[]) => {\n\t\tif (!ansiColors[d[2]]) return d[0];\n\t\treturn '\\u001B[' + ansiColors[d[2]][d[1] === '/' ? 1 : 0] + 'm';\n\t});\n}\n// const STRIPPED_DATE=(new Date()).toLocaleTimeString().replace(/./g, ' ');\nfunction stringifyCommonData(nameLimit: number, escapeCode: string, provider: NodeConsoleReceiver, data: any) {\n\t// writeRepeats(data.repeats, false);\n\t// writeDate(data.time);\n\tconst strings = data.string.split('\\n');\n\tlet ret = `\\u001B[40m${stringifyName(nameLimit, provider.nameLimit, data.name, escapeCode)}\\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${strings.shift()}`;\n\tfor (let string of strings) {\n\t\tret += `\\n\\u001B[40m${stringifyName(nameLimit, provider.nameLimit, ' |', escapeCode)}\\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${string}`;\n\t\t//`${stringifyIdent(data.identationLength)}${stringifyName(provider.nameLimit,'|',escapeCode)} ${string}\\n`;\n\t}\n\treturn ret;\n}\nfunction writeLogData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\twriteStdout(stringifyCommonData(nameLimit, '34m', provider, data) + '\\n');\n}\nfunction writeErrorData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\twriteStdout(stringifyCommonData(nameLimit, '31m', provider, data) + '\\n');\n}\nfunction writeWarningData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\twriteStdout(stringifyCommonData(nameLimit, '33m', provider, data) + '\\n');\n}\nfunction writeDebugData(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\twriteStdout(stringifyCommonData(nameLimit, '90m', provider, data) + '\\n');\n}\n\ninterface IProgressItem {\n\tname: string,\n\tprogress: number,\n\ttime: number\n}\nconst progresses: { [key: string]: IProgressItem } = {};\nfunction progressStart(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\tprogresses[data.name] = {\n\t\tname: data.name,\n\t\tprogress: 0,\n\t\ttime: data.time\n\t};\n}\nfunction progressEnd(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\tdelete progresses[data.name];\n}\nfunction progress(nameLimit: number, provider: NodeConsoleReceiver, data: any) {\n\tif (!progresses[data.name])\n\t\treturn;\n\tprogresses[data.name].time = data.time;\n\tprogresses[data.name].progress = data.progress;\n}\nfunction renderProgress(nameLimit: number) {\n\tsave();\n\tlet i = 0;\n\tfor (let progress of Object.values(progresses)) {\n\t\tmoveCursor(i);\n\t\tclearLine();\n\t\tlet percent = Math.ceil(progress.progress);\n\t\twriteStdout(`\\u001B[34m${progress.name.padStart(nameLimit)} ${(percent + '%').padStart(4, ' ')} ${'|'.repeat(Math.ceil(((process.stdout as any).columns - 1 - 3 - 1 - 1 - nameLimit) / 100 * percent))}`);\n\t\t// writeEscape('34m');\n\t\t// writeStdout((<IProgressItem>progress).name.padStart(18,' '));\n\t\t// writeStdout(' ');\n\t\t// writeDate(progress.time);\n\t\t// writeStdout(' ');\n\t\t// writeStdout((percent+'%').padStart(4,' '));\n\t\t// writeStdout(' ');\n\t\t// writeStdout('|'.repeat(Math.ceil(((<any>process.stdout).columns-1-3-1-8-1-18)/100*percent)));\n\t\ti++;\n\t}\n\n\trestore();\n}\n\nexport default class NodeConsoleReceiver extends BasicReceiver {\n\tnameLimit: number;\n\n\tconstructor(nameLimit = 18) {\n\t\tsuper();\n\t\tthis.nameLimit = nameLimit;\n\t}\n\n\twrite(data: any) {\n\t\tlet { nameLimit } = this;\n\t\tif (Object.values(progresses).length !== 0) {\n\t\t\tstartBuffering();\n\t\t}\n\t\tdata.string = stringifyData(nameLimit, data);\n\t\t// if (data.repeated) {\n\t\t// \tif(!process.env.NO_COLLAPSE){\n\t\t// \t\tsave();\n\t\t// \t\twriteEscape(data.string.split('\\n').length + 'A');\n\t\t// \t\t//data.repeats\n\t\t// \t}\n\t\t// }\n\t\tswitch (data.type) {\n\t\t\tcase LOGGER_ACTIONS.IDENT:\n\t\t\t\twriteStdout(stringifyIdentData(nameLimit, this, data) + '\\n');\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.DEENT:\n\t\t\t\twriteStdout(stringifyDeentData(nameLimit, this, data) + '\\n');\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.LOG:\n\t\t\t\twriteLogData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.ERROR:\n\t\t\t\twriteErrorData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.WARNING:\n\t\t\t\twriteWarningData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.DEBUG:\n\t\t\t\twriteDebugData(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.TIME_START:\n\t\t\t\twriteStdout(stringifyTimeStartData(nameLimit, this, data) + '\\n');\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.TIME_END:\n\t\t\t\twriteStdout(stringifyTimeEndData(nameLimit, this, data) + '\\n');\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.PROGRESS_START:\n\t\t\t\tprogressStart(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.PROGRESS_END:\n\t\t\t\tprogressEnd(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tcase LOGGER_ACTIONS.PROGRESS:\n\t\t\t\tprogress(nameLimit, this, data);\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tconsole._log(data);\n\t\t}\n\t\t// if (data.repeated) {\n\t\t// \tif(!process.env.NO_COLLAPSE)restore();\n\t\t// }\n\t\t// TODO: Support for non-tty terminals\n\t\tif (Object.values(progresses).length !== 0) {\n\t\t\trenderProgress(nameLimit);\n\t\t\tflushBuffer();\n\t\t}\n\t}\n}\n\nlet terminalLogger = new Logger('terminal');\n\nprocess.on('uncaughtException', e => {\n\tterminalLogger.err('UncaughtException:');\n\tterminalLogger.err(e.stack);\n\t// process.exit(0);\n});\n\nprocess.on('unhandledRejection', e => {\n\tterminalLogger.err('UnhandledRejection:');\n\tterminalLogger.err(e.stack);\n\t// process.exit(0);\n});\n\n// process.on('warning', e => {\n// \tterminalLogger.warn(e.stack);\n// });"]} |
@@ -1,7 +0,9 @@ | ||
import {format} from 'util'; | ||
import Logger,{LOGGER_ACTIONS,BasicReceiver} from '../'; | ||
import {writeStdout, | ||
moveCursor, clearLine, save, restore, startBuffering, flushBuffer} from '@meteor-it/terminal'; | ||
import { format } from 'util'; | ||
import Logger, { LOGGER_ACTIONS, BasicReceiver } from '../'; | ||
import { | ||
writeStdout, | ||
moveCursor, clearLine, save, restore, startBuffering, flushBuffer | ||
} from '@meteor-it/terminal'; | ||
const ansiColors:{[key:string]:number[]} = { | ||
const ansiColors: { [key: string]: number[] } = { | ||
reset: [0, 0], | ||
@@ -37,3 +39,3 @@ | ||
function stringifyIdent(nameLimit:number, count:number, symbolNeeded:string = undefined) { | ||
function stringifyIdent(nameLimit: number, count: number, symbolNeeded: string = undefined) { | ||
return `${' '.repeat(count)}${symbolNeeded ? symbolNeeded : ' '}`; | ||
@@ -46,4 +48,4 @@ } | ||
// } | ||
function stringifyName(nameLimit:number, limit:number, name:string, escapeCode = '44m') { | ||
return `\u001B[${escapeCode}\u001B[1m${nameLimit===0?'':name.toString().padStart(nameLimit,' ')}\u001B[0m`; | ||
function stringifyName(nameLimit: number, limit: number, name: string, escapeCode = '44m') { | ||
return `\u001B[${escapeCode}\u001B[1m${nameLimit === 0 ? '' : name.toString().padStart(nameLimit, ' ')}\u001B[0m`; | ||
} | ||
@@ -63,26 +65,26 @@ // function writeRepeats(count, none = false) { | ||
// } | ||
function stringifyIdentData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
function stringifyIdentData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
// writeRepeats(0, true); | ||
// writeDate(data.time); | ||
return ` ${stringifyName(nameLimit, provider.nameLimit,data.name)} \u001B[35m${stringifyIdent(nameLimit, data.identationLength-1,'>')}\u001B[1m ${data.identName}\u001B[0m`; | ||
return ` ${stringifyName(nameLimit, provider.nameLimit, data.name)} \u001B[35m${stringifyIdent(nameLimit, data.identationLength - 1, '>')}\u001B[1m ${data.identName}\u001B[0m`; | ||
} | ||
function stringifyDeentData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
function stringifyDeentData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
// writeRepeats(0, true); | ||
// writeDate(data.time); | ||
return ` ${stringifyName(nameLimit, provider.nameLimit,data.name)} \u001B[35m${stringifyIdent(nameLimit, data.identationLength,'<')}\u001B[1m ${data.identName}\u001B[22m (Done in ${data.identTime}ms)\u001B[0m`; | ||
return ` ${stringifyName(nameLimit, provider.nameLimit, data.name)} \u001B[35m${stringifyIdent(nameLimit, data.identationLength, '<')}\u001B[1m ${data.identName}\u001B[22m (Done in ${data.identTime}ms)\u001B[0m`; | ||
} | ||
function stringifyTimeStartData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
function stringifyTimeStartData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
// writeRepeats(0, true); | ||
// writeDate(data.time); | ||
return ` \u001B[35m${stringifyName(nameLimit, provider.nameLimit,data.name,'1m')}\u001B[33m${stringifyIdent(nameLimit, data.identationLength)} T Started ${data.timeName}`; | ||
return ` \u001B[35m${stringifyName(nameLimit, provider.nameLimit, data.name, '1m')}\u001B[33m${stringifyIdent(nameLimit, data.identationLength)} T Started ${data.timeName}`; | ||
} | ||
function stringifyTimeEndData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
function stringifyTimeEndData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
// writeRepeats(0, true); | ||
// writeDate(data.time); | ||
return ` \u001B[35m${stringifyName(nameLimit, provider.nameLimit,data.name,'1m')}\u001B[34m${stringifyIdent(nameLimit, data.identationLength)} T Finished ${data.timeName}\u001B[1m in ${data.timeTime}ms\u001B[0m`; | ||
return ` \u001B[35m${stringifyName(nameLimit, provider.nameLimit, data.name, '1m')}\u001B[34m${stringifyIdent(nameLimit, data.identationLength)} T Finished ${data.timeName}\u001B[1m in ${data.timeTime}ms\u001B[0m`; | ||
} | ||
function stringifyData(nameLimit:number, data:any) { | ||
function stringifyData(nameLimit: number, data: any) { | ||
let uncolored = format(data.line, ...data.params || []); | ||
return uncolored.replace(/{(\/?)([^}]+)}/g, (...d:any[]) => { | ||
if (!ansiColors[d[2]])return d[0]; | ||
return uncolored.replace(/{(\/?)([^}]+)}/g, (...d: any[]) => { | ||
if (!ansiColors[d[2]]) return d[0]; | ||
return '\u001B[' + ansiColors[d[2]][d[1] === '/' ? 1 : 0] + 'm'; | ||
@@ -92,9 +94,9 @@ }); | ||
// const STRIPPED_DATE=(new Date()).toLocaleTimeString().replace(/./g, ' '); | ||
function stringifyCommonData(nameLimit:number, escapeCode:string, provider:NodeConsoleReceiver, data:any) { | ||
function stringifyCommonData(nameLimit: number, escapeCode: string, provider: NodeConsoleReceiver, data: any) { | ||
// writeRepeats(data.repeats, false); | ||
// writeDate(data.time); | ||
const strings = data.string.split('\n'); | ||
let ret = ` \u001B[40m${stringifyName(nameLimit, provider.nameLimit, data.name, escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${strings.shift()}`; | ||
for(let string of strings){ | ||
ret += ` \n\u001B[40m${stringifyName(nameLimit, provider.nameLimit, ' |', escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${string}`; | ||
let ret = `\u001B[40m${stringifyName(nameLimit, provider.nameLimit, data.name, escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${strings.shift()}`; | ||
for (let string of strings) { | ||
ret += `\n\u001B[40m${stringifyName(nameLimit, provider.nameLimit, ' |', escapeCode)}\u001B[0m${stringifyIdent(nameLimit, data.identationLength)}${string}`; | ||
//`${stringifyIdent(data.identationLength)}${stringifyName(provider.nameLimit,'|',escapeCode)} ${string}\n`; | ||
@@ -104,13 +106,13 @@ } | ||
} | ||
function writeLogData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
writeStdout('\n'+stringifyCommonData(nameLimit, '34m',provider,data)); | ||
function writeLogData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
writeStdout(stringifyCommonData(nameLimit, '34m', provider, data) + '\n'); | ||
} | ||
function writeErrorData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
writeStdout('\n'+stringifyCommonData(nameLimit, '31m',provider,data)); | ||
function writeErrorData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
writeStdout(stringifyCommonData(nameLimit, '31m', provider, data) + '\n'); | ||
} | ||
function writeWarningData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
writeStdout('\n'+stringifyCommonData(nameLimit, '33m',provider,data)); | ||
function writeWarningData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
writeStdout(stringifyCommonData(nameLimit, '33m', provider, data) + '\n'); | ||
} | ||
function writeDebugData(nameLimit:number, provider:NodeConsoleReceiver, data:any) { | ||
writeStdout('\n'+stringifyCommonData(nameLimit, '90m',provider,data)); | ||
function writeDebugData(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
writeStdout(stringifyCommonData(nameLimit, '90m', provider, data) + '\n'); | ||
} | ||
@@ -121,39 +123,39 @@ | ||
progress: number, | ||
time:number | ||
time: number | ||
} | ||
const progresses:{[key:string]:IProgressItem}={}; | ||
function progressStart(nameLimit:number, provider:NodeConsoleReceiver,data:any){ | ||
progresses[data.name]={ | ||
name:data.name, | ||
progress:0, | ||
time:data.time | ||
const progresses: { [key: string]: IProgressItem } = {}; | ||
function progressStart(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
progresses[data.name] = { | ||
name: data.name, | ||
progress: 0, | ||
time: data.time | ||
}; | ||
} | ||
function progressEnd(nameLimit:number, provider:NodeConsoleReceiver,data:any){ | ||
function progressEnd(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
delete progresses[data.name]; | ||
} | ||
function progress(nameLimit:number, provider:NodeConsoleReceiver,data:any){ | ||
if(!progresses[data.name]) | ||
function progress(nameLimit: number, provider: NodeConsoleReceiver, data: any) { | ||
if (!progresses[data.name]) | ||
return; | ||
progresses[data.name].time=data.time; | ||
progresses[data.name].progress=data.progress; | ||
progresses[data.name].time = data.time; | ||
progresses[data.name].progress = data.progress; | ||
} | ||
function renderProgress(nameLimit:number){ | ||
function renderProgress(nameLimit: number) { | ||
save(); | ||
let i=0; | ||
for(let progress of Object.values(progresses)) { | ||
moveCursor(i); | ||
clearLine(); | ||
let percent=Math.ceil(progress.progress); | ||
writeStdout(`\u001B[34m${progress.name.padStart(nameLimit)} ${(percent + '%').padStart(4, ' ')} ${'|'.repeat(Math.ceil(((process.stdout as any).columns - 1 - 3 - 1 - 1 - nameLimit) / 100 * percent))}`); | ||
// writeEscape('34m'); | ||
// writeStdout((<IProgressItem>progress).name.padStart(18,' ')); | ||
// writeStdout(' '); | ||
// writeDate(progress.time); | ||
// writeStdout(' '); | ||
// writeStdout((percent+'%').padStart(4,' ')); | ||
// writeStdout(' '); | ||
// writeStdout('|'.repeat(Math.ceil(((<any>process.stdout).columns-1-3-1-8-1-18)/100*percent))); | ||
i++; | ||
} | ||
let i = 0; | ||
for (let progress of Object.values(progresses)) { | ||
moveCursor(i); | ||
clearLine(); | ||
let percent = Math.ceil(progress.progress); | ||
writeStdout(`\u001B[34m${progress.name.padStart(nameLimit)} ${(percent + '%').padStart(4, ' ')} ${'|'.repeat(Math.ceil(((process.stdout as any).columns - 1 - 3 - 1 - 1 - nameLimit) / 100 * percent))}`); | ||
// writeEscape('34m'); | ||
// writeStdout((<IProgressItem>progress).name.padStart(18,' ')); | ||
// writeStdout(' '); | ||
// writeDate(progress.time); | ||
// writeStdout(' '); | ||
// writeStdout((percent+'%').padStart(4,' ')); | ||
// writeStdout(' '); | ||
// writeStdout('|'.repeat(Math.ceil(((<any>process.stdout).columns-1-3-1-8-1-18)/100*percent))); | ||
i++; | ||
} | ||
@@ -164,3 +166,3 @@ restore(); | ||
export default class NodeConsoleReceiver extends BasicReceiver { | ||
nameLimit:number; | ||
nameLimit: number; | ||
@@ -172,7 +174,7 @@ constructor(nameLimit = 18) { | ||
write(data:any) { | ||
let {nameLimit} = this; | ||
if(Object.values(progresses).length!==0) { | ||
startBuffering(); | ||
} | ||
write(data: any) { | ||
let { nameLimit } = this; | ||
if (Object.values(progresses).length !== 0) { | ||
startBuffering(); | ||
} | ||
data.string = stringifyData(nameLimit, data); | ||
@@ -188,6 +190,6 @@ // if (data.repeated) { | ||
case LOGGER_ACTIONS.IDENT: | ||
writeStdout('\n'+stringifyIdentData(nameLimit, this, data)); | ||
writeStdout(stringifyIdentData(nameLimit, this, data) + '\n'); | ||
break; | ||
case LOGGER_ACTIONS.DEENT: | ||
writeStdout('\n'+stringifyDeentData(nameLimit, this, data)); | ||
writeStdout(stringifyDeentData(nameLimit, this, data) + '\n'); | ||
break; | ||
@@ -207,6 +209,6 @@ case LOGGER_ACTIONS.LOG: | ||
case LOGGER_ACTIONS.TIME_START: | ||
writeStdout('\n'+stringifyTimeStartData(nameLimit, this, data)); | ||
writeStdout(stringifyTimeStartData(nameLimit, this, data) + '\n'); | ||
break; | ||
case LOGGER_ACTIONS.TIME_END: | ||
writeStdout('\n'+stringifyTimeEndData(nameLimit, this, data)); | ||
writeStdout(stringifyTimeEndData(nameLimit, this, data) + '\n'); | ||
break; | ||
@@ -217,6 +219,6 @@ case LOGGER_ACTIONS.PROGRESS_START: | ||
case LOGGER_ACTIONS.PROGRESS_END: | ||
progressEnd(nameLimit, this,data); | ||
progressEnd(nameLimit, this, data); | ||
break; | ||
case LOGGER_ACTIONS.PROGRESS: | ||
progress(nameLimit, this,data); | ||
progress(nameLimit, this, data); | ||
break; | ||
@@ -229,11 +231,11 @@ default: | ||
// } | ||
// TODO: Support for non-tty terminals | ||
if(Object.values(progresses).length!==0) { | ||
renderProgress(nameLimit); | ||
flushBuffer(); | ||
} | ||
// TODO: Support for non-tty terminals | ||
if (Object.values(progresses).length !== 0) { | ||
renderProgress(nameLimit); | ||
flushBuffer(); | ||
} | ||
} | ||
} | ||
let terminalLogger=new Logger('terminal'); | ||
let terminalLogger = new Logger('terminal'); | ||
@@ -240,0 +242,0 @@ process.on('uncaughtException', e => { |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
98993
1551