-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathLogger.cs
75 lines (69 loc) · 2.06 KB
/
Logger.cs
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
69
70
71
72
73
74
75
using System;
using System.IO;
namespace UDGB
{
internal class Logger
{
#if DEBUG
private static bool DEBUG = true;
#else
private static bool DEBUG = false;
#endif
private static bool ShouldLogToFile = true;
private static FileStream fs = null;
private static StreamWriter sr = null;
static Logger()
{
if (!ShouldLogToFile)
return;
if (File.Exists("output.log"))
File.Delete("output.log");
fs = File.OpenWrite("output.log");
sr = new StreamWriter(fs);
}
internal static void Msg(string str)
{
Console.WriteLine(str);
if (!ShouldLogToFile || (sr == null))
return;
sr.WriteLine(str);
sr.Flush();
}
internal static void Warning(string str)
{
var oldColor = Console.ForegroundColor;
Console.ForegroundColor = ConsoleColor.Yellow;
Console.WriteLine(str);
Console.ForegroundColor = oldColor;
if (!ShouldLogToFile || (sr == null))
return;
sr.WriteLine(str);
sr.Flush();
}
internal static void Error(string str)
{
var oldColor = Console.ForegroundColor;
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine(str);
Console.ForegroundColor = oldColor;
if (!ShouldLogToFile || (sr == null))
return;
sr.WriteLine(str);
sr.Flush();
}
internal static void DebugMsg(string str)
{
if (!DEBUG)
return;
var oldColor = Console.ForegroundColor;
Console.ForegroundColor = ConsoleColor.Blue;
str = $"[DEBUG] {str}";
Console.WriteLine(str);
Console.ForegroundColor = oldColor;
if (!ShouldLogToFile || (sr == null))
return;
sr.WriteLine(str);
sr.Flush();
}
}
}