-
-
Notifications
You must be signed in to change notification settings - Fork 6.6k
Expand file tree
/
Copy pathConsole.js
More file actions
60 lines (48 loc) · 1.38 KB
/
Console.js
File metadata and controls
60 lines (48 loc) · 1.38 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/**
* Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @flow
*/
/* global stream$Writable */
import type {LogType, LogMessage} from 'types/Console';
import {format} from 'util';
import {Console} from 'console';
import clearLine from './clear_line';
type Formatter = (type: LogType, message: LogMessage) => string;
export default class CustomConsole extends Console {
_stdout: stream$Writable;
_formatBuffer: Formatter;
constructor(
stdout: stream$Writable,
stderr: stream$Writable,
formatBuffer: ?Formatter,
) {
super(stdout, stderr);
this._formatBuffer = formatBuffer || ((type, message) => message);
}
_log(type: LogType, message: string) {
clearLine(this._stdout);
super.log(this._formatBuffer(type, message));
}
debug(...args: Array<mixed>) {
this._log('debug', format.apply(null, arguments));
}
log(...args: Array<mixed>) {
this._log('log', format.apply(null, arguments));
}
info(...args: Array<mixed>) {
this._log('info', format.apply(null, arguments));
}
warn(...args: Array<mixed>) {
this._log('warn', format.apply(null, arguments));
}
error(...args: Array<mixed>) {
this._log('error', format.apply(null, arguments));
}
getBuffer() {
return null;
}
}