From 2030b6befe28fc052cefe98ad2029ccb429351b5 Mon Sep 17 00:00:00 2001 From: Jean Lauliac Date: Tue, 28 Feb 2017 06:41:12 -0800 Subject: [PATCH] packager: terminal: split status too big to fit in screen Reviewed By: cpojer Differential Revision: D4627512 fbshipit-source-id: 6e7b5f3a6e2d012a44373014f93ab17ef4f290a2 --- packager/src/lib/terminal.js | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/packager/src/lib/terminal.js b/packager/src/lib/terminal.js index facc56f28..3b34b09fb 100644 --- a/packager/src/lib/terminal.js +++ b/packager/src/lib/terminal.js @@ -31,6 +31,15 @@ function clearStringBackwards(stream: tty.WriteStream, str: string): void { } } +/** + * Cut a string into an array of string of the specific maximum size. A newline + * ends a chunk immediately (it's not included in the "." RexExp operator), and + * is not included in the result. + */ +function chunkString(str: string, size: number): Array { + return str.match(new RegExp(`.{1,${size}}`, 'g')) || []; +} + /** * We don't just print things to the console, sometimes we also want to show * and update progress. This utility just ensures the output stays neat: no @@ -78,6 +87,7 @@ class Terminal { const {_statusStr, _stream} = this; if (_statusStr !== str && _stream instanceof tty.WriteStream) { clearStringBackwards(_stream, _statusStr); + str = chunkString(str, _stream.columns).join('\n'); _stream.write(str); } this._statusStr = str;