-
Notifications
You must be signed in to change notification settings - Fork 0
/
debugger.ts
68 lines (65 loc) · 2.37 KB
/
debugger.ts
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
61
62
63
64
65
66
67
68
//Types
import { DebugLevel } from "../@types/enums";
//Imports
import fs from 'fs';
/**
* This is the Debugger class, it is responsible for logging output
*/
export default class Debugger {
public static level: DebugLevel = DebugLevel.warn;
public static log_file: undefined | string;
// File to log messages to
public static log(level: DebugLevel, title: string, string?: any) {
if (level >= this.level) {
if (this.log_file) {
title = '['+new Date().toLocaleString()+'] '+title;
fs.appendFileSync(this.log_file, title+" "+JSON.stringify(string,null,4)+"\n");
} else {
switch(level) {
case DebugLevel.debug:
if (string)
console.debug(`\x1b[1m\x1b[90m${title}\x1b[0m`, string);
else
console.debug(title);
break;
case DebugLevel.error:
if (string)
console.error(`\x1b[1m\x1b[31m${title}\x1b[0m`, string);
else
console.error(title);
break;
case DebugLevel.warn:
if (string)
console.warn(`\x1b[1m\x1b[33m${title}\x1b[0m`, string);
else
console.warn(title);
break;
case DebugLevel.info:
if (string)
console.info(`\x1b[1m\x1b[34m${title}\x1b[0m`, string);
else
console.info(title);
break;
default:
if (string)
console.log(`\x1b[1m${title}\x1b[0m`, string);
else
console.log(title);
break;
}
}
}
}
public static debug(title: string, string?: any) {
this.log(DebugLevel.debug, title, string);
}
public static info(title: string, string?: any) {
this.log(DebugLevel.info, title, string);
}
public static warn(title: string, string?: any) {
this.log(DebugLevel.warn, title, string);
}
public static error(title: string, string?: any) {
this.log(DebugLevel.error, title, string);
}
}