mirror of
https://github.com/Sanae6/SmoOnlineServer.git
synced 2024-11-25 12:45:18 +00:00
42 lines
No EOL
1.3 KiB
C#
42 lines
No EOL
1.3 KiB
C#
using System.Text;
|
|
|
|
namespace Shared;
|
|
|
|
public class Logger {
|
|
public Logger(string name) {
|
|
Name = name;
|
|
}
|
|
|
|
public string Name { get; set; }
|
|
|
|
public void Info(string text) => Handler?.Invoke(Name, "Info", text, ConsoleColor.White);
|
|
|
|
public void Warn(string text) => Handler?.Invoke(Name, "Warn", text, ConsoleColor.Yellow);
|
|
|
|
public void Error(string text) => Handler?.Invoke(Name, "Error", text, ConsoleColor.Red);
|
|
|
|
public void Error(Exception error) => Error(error.ToString());
|
|
|
|
public static string PrefixNewLines(string text, string prefix) {
|
|
StringBuilder builder = new StringBuilder();
|
|
foreach (string str in text.Split('\n'))
|
|
builder
|
|
.Append(prefix)
|
|
.Append(' ')
|
|
.AppendLine(str);
|
|
return builder.ToString();
|
|
}
|
|
|
|
public delegate void LogHandler(string source, string level, string text, ConsoleColor color);
|
|
|
|
private static LogHandler? Handler;
|
|
public static void AddLogHandler(LogHandler handler) => Handler += handler;
|
|
|
|
static Logger() {
|
|
AddLogHandler((source, level, text, color) => {
|
|
DateTime logtime = DateTime.Now;
|
|
Console.ForegroundColor = color;
|
|
Console.Write(PrefixNewLines(text, $"{{{logtime}}} {level} [{source}]"));
|
|
});
|
|
}
|
|
} |