Spaces:
Sleeping
Sleeping
| ; | |
| const colors = require('./utils/colors'); | |
| const chalk = require('chalk'); | |
| const stringWidth = require('string-width'); | |
| const readline = require('readline'); | |
| const stripAnsi = require('strip-ansi'); | |
| class Debugger { | |
| constructor () { | |
| this.enabled = true; | |
| this.capturing = false; | |
| this.capturedMessages = []; | |
| } | |
| enable () { | |
| this.enabled = true; | |
| } | |
| capture () { | |
| this.enabled = true; | |
| this.capturing = true; | |
| } | |
| endCapture () { | |
| this.enabled = false; | |
| this.capturing = false; | |
| this.capturedMessages = []; | |
| } | |
| log () { | |
| if (this.enabled) { | |
| this.captureConsole(Array.from(arguments), console.log); | |
| } | |
| } | |
| info (message) { | |
| if (this.enabled) { | |
| const titleFormatted = colors.formatTitle('info', 'I'); | |
| this.log(titleFormatted, message); | |
| } | |
| } | |
| note (message) { | |
| if (this.enabled) { | |
| const titleFormatted = colors.formatTitle('note', 'N'); | |
| this.log(titleFormatted, message); | |
| } | |
| } | |
| title (severity, title, subtitle) { | |
| if (this.enabled) { | |
| const date = new Date(); | |
| const dateString = chalk.grey(date.toLocaleTimeString()); | |
| const titleFormatted = colors.formatTitle(severity, title); | |
| const subTitleFormatted = colors.formatText(severity, subtitle); | |
| const message = `${titleFormatted} ${subTitleFormatted}` | |
| // In test environment we don't include timestamp | |
| if(process.env.NODE_ENV === 'test') { | |
| this.log(message); | |
| this.log(); | |
| return; | |
| } | |
| // Make timestamp appear at the end of the line | |
| let logSpace = process.stdout.columns - stringWidth(message) - stringWidth(dateString) | |
| if (logSpace <= 0) { | |
| logSpace = 10 | |
| } | |
| this.log(`${message}${' '.repeat(logSpace)}${dateString}`); | |
| this.log(); | |
| } | |
| } | |
| clearConsole () { | |
| if (!process.env.CI && !this.capturing && this.enabled && process.stdout.isTTY) { | |
| // Fill screen with blank lines. Then move to 0 (beginning of visible part) and clear it | |
| const blank = '\n'.repeat(process.stdout.rows) | |
| console.log(blank) | |
| readline.cursorTo(process.stdout, 0, 0) | |
| readline.clearScreenDown(process.stdout) | |
| } | |
| } | |
| captureLogs (fun) { | |
| try { | |
| this.capture(); | |
| fun.call(); | |
| return this.capturedMessages; | |
| } finally { | |
| this.endCapture(); | |
| } | |
| } | |
| captureConsole (args, method) { | |
| if (this.capturing) { | |
| this.capturedMessages.push(stripAnsi(args.join(' ')).trim()); | |
| } else { | |
| method.apply(console, args); | |
| } | |
| } | |
| } | |
| function capitalizeFirstLetter (string) { | |
| return string.charAt(0).toUpperCase() + string.slice(1); | |
| } | |
| module.exports = new Debugger(); | |