-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathGameLog.cs
More file actions
116 lines (100 loc) · 3.6 KB
/
GameLog.cs
File metadata and controls
116 lines (100 loc) · 3.6 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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
// You can call this from any other file without a refernece to it by using GameLog.Instance.Log("Hello World");
using System.IO;
using UnityEngine;
public class GameLog : MonoBehaviour
{
public static GameLog Instance;
private StreamWriter writer;
private string path;
public bool EngineLogMisc = false;
void Awake()
{
if (Instance == null)
{
Instance = this;
DontDestroyOnLoad(gameObject);
// Decide appropiate path for log
#if UNITY_EDITOR
path = Path.Combine(Application.dataPath, "GAMECORE", "GameLog.md");
#else
path = Path.Combine(Directory.GetCurrentDirectory(), "GameLog.md");
#endif
// Initialize writer
if (File.Exists(path)) { File.WriteAllText(path, string.Empty); } // Clear the existing file contents
writer = new StreamWriter(path, append: false); // The StreamWriter creates a new file if none exist
CategoryLog("Game Log Initiated... ");
Log("DataPath: " + Application.dataPath);
Log("Current Directory: " + Directory.GetCurrentDirectory());
}
else { Destroy(gameObject); }
}
public void Log(string logentry)
{
if (writer != null)
{
writer.WriteLine("[" + System.DateTime.Now + "] [LOG ENTRY] " + logentry + "<br>");
writer.Flush();
}
if (EngineLogMisc) { Debug.Log(logentry); }
}
public void ErrorLog(string logentry)
{
Debug.LogError(logentry); // Send copy to in-engine debug log for in-engine debugging without duplicates
if (writer != null)
{
writer.WriteLine("[" + System.DateTime.Now + "] <span style=\"color:red\">[ERROR] </span>" + logentry + "<br>");
writer.Flush();
}
}
public void WarningLog(string logentry)
{
Debug.LogError(logentry); // Send copy to in-engine debug log for in-engine debugging without duplicates
if (writer != null)
{
writer.WriteLine("[" + System.DateTime.Now + "] <span style=\"color:orange\">[WARNING] </span>" + logentry + "<br>");
writer.Flush();
}
}
public void PlaceholderLog(string logentry)
{
if (writer != null)
{
writer.WriteLine("[" + System.DateTime.Now + "] <span style=\"color:orange\">[PLACEHOLDER WARNING] </span>" + logentry + "<br>");
writer.Flush();
}
}
public void CategoryLog(string logentry)
{
if (writer != null)
{
writer.WriteLine("## <u>" + logentry + "</u><br>");
writer.Flush();
//Log("Logged Category");
}
}
public void LogPoint(string logentry)
{
if (writer != null)
{
writer.WriteLine( "<li>" + logentry + "</li>");
writer.Flush();
}
}
public void DebugLog(string logentry)
{
Debug.LogWarning(logentry); // Send copy to in-engine debug log for in-engine debugging without duplicates
if (writer != null)
{
writer.WriteLine // This software supports LGBTQA+ rights! It does not support bugs or bigots.
("[" + System.DateTime.Now + "] [" +
"<span style='color:red;'>D</span>" +
"<span style='color:orange;'>E</span>" +
"<span style='color:yellow;'>B</span>" +
"<span style='color:lightgreen;'>U</span>" +
"<span style='color:lightblue;'>G</span>" +
"] " + logentry + "<br>");
writer.Flush();
}
}
void OnApplicationQuit() { if (writer != null) { writer.Close(); } }
}