mirror of
https://github.com/angular/angular-cli.git
synced 2025-05-18 11:44:05 +08:00
52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright Google Inc. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
import { filter } from 'rxjs/operators';
|
|
import { logging, terminal } from '../src';
|
|
|
|
export interface ProcessOutput {
|
|
write(buffer: string | Buffer): boolean;
|
|
}
|
|
|
|
/**
|
|
* A Logger that sends information to STDOUT and STDERR.
|
|
*/
|
|
export function createConsoleLogger(
|
|
verbose = false,
|
|
stdout: ProcessOutput = process.stdout,
|
|
stderr: ProcessOutput = process.stderr,
|
|
): logging.Logger {
|
|
const logger = new logging.IndentLogger('cling');
|
|
|
|
logger
|
|
.pipe(filter(entry => (entry.level != 'debug' || verbose)))
|
|
.subscribe(entry => {
|
|
let color: (s: string) => string = x => terminal.dim(terminal.white(x));
|
|
let output = stdout;
|
|
switch (entry.level) {
|
|
case 'info':
|
|
color = terminal.white;
|
|
break;
|
|
case 'warn':
|
|
color = terminal.yellow;
|
|
break;
|
|
case 'error':
|
|
color = terminal.red;
|
|
output = stderr;
|
|
break;
|
|
case 'fatal':
|
|
color = (x: string) => terminal.bold(terminal.red(x));
|
|
output = stderr;
|
|
break;
|
|
}
|
|
|
|
output.write(color(entry.message) + '\n');
|
|
});
|
|
|
|
return logger;
|
|
}
|