'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _ansiEscapes = require('ansi-escapes'); var _ansiEscapes2 = _interopRequireDefault(_ansiEscapes); var _wrapAnsi = require('wrap-ansi'); var _wrapAnsi2 = _interopRequireDefault(_wrapAnsi); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } // Based on https://github.com/sindresorhus/log-update/blob/master/index.js const originalWrite = Symbol('webpackbarWrite'); class LogUpdate { constructor() { this.prevLineCount = 0; this.listening = false; this.extraLines = ''; this._onData = this._onData.bind(this); this._streams = [process.stdout, process.stderr]; } render(lines) { this.listen(); const wrappedLines = (0, _wrapAnsi2.default)(lines, this.columns, { trim: false, hard: true, wordWrap: false }); const data = _ansiEscapes2.default.eraseLines(this.prevLineCount) + wrappedLines + '\n' + this.extraLines; this.write(data); this.prevLineCount = data.split('\n').length; } get columns() { return (process.stderr.columns || 80) - 2; } write(data) { const stream = process.stderr; if (stream.write[originalWrite]) { stream.write[originalWrite].call(stream, data, 'utf-8'); } else { stream.write(data, 'utf-8'); } } clear() { this.done(); this.write(_ansiEscapes2.default.eraseLines(this.prevLineCount)); } done() { this.stopListen(); this.prevLineCount = 0; this.extraLines = ''; } _onData(data) { const str = String(data); const lines = str.split('\n').length - 1; if (lines > 0) { this.prevLineCount += lines; this.extraLines += data; } } listen() { // Prevent listening more than once if (this.listening) { return; } // Spy on all streams for (const stream of this._streams) { // Prevent overriding more than once if (stream.write[originalWrite]) { continue; } // Create a wrapper fn const write = (data, ...args) => { if (!stream.write[originalWrite]) { return stream.write(data, ...args); } this._onData(data); return stream.write[originalWrite].call(stream, data, ...args); }; // Backup original write fn write[originalWrite] = stream.write; // Override write fn stream.write = write; } this.listening = true; } stopListen() { // Restore original write fns for (const stream of this._streams) { if (stream.write[originalWrite]) { stream.write = stream.write[originalWrite]; } } this.listening = false; } } exports.default = LogUpdate;