-
Notifications
You must be signed in to change notification settings - Fork 56
Expand file tree
/
Copy pathlogger.ts
More file actions
42 lines (40 loc) · 1.31 KB
/
logger.ts
File metadata and controls
42 lines (40 loc) · 1.31 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
interface LoggerOptions {
silent: boolean;
debug: boolean;
prefix: string;
}
export type Logger = {
info(message: string, ...params: unknown[]): void;
warn(message: string, ...params: unknown[]): void;
error(message: string, ...params: unknown[]): void;
debug(message: string, ...params: unknown[]): void;
};
// Logging everything to stderr not to interfere with stdout
export function createLogger(options: LoggerOptions): Logger {
return {
info(message: string, ...params: unknown[]) {
if (!options.silent) {
// eslint-disable-next-line no-console
console.info(`${options.prefix} Info: ${message}`, ...params);
}
},
warn(message: string, ...params: unknown[]) {
if (!options.silent) {
// eslint-disable-next-line no-console
console.warn(`${options.prefix} Warning: ${message}`, ...params);
}
},
error(message: string, ...params: unknown[]) {
if (!options.silent) {
// eslint-disable-next-line no-console
console.error(`${options.prefix} Error: ${message}`, ...params);
}
},
debug(message: string, ...params: unknown[]) {
if (!options.silent && options.debug) {
// eslint-disable-next-line no-console
console.debug(`${options.prefix} Debug: ${message}`, ...params);
}
},
};
}