HISP/HorseIsleServer/LibHISP/Server/Logger.cs
2022-11-20 15:33:36 +13:00

58 lines
1.7 KiB
C#
Executable file

using System;
namespace HISP.Server
{
public class Logger
{
private static void defaultCallbackFunc(bool error, string type, string text)
{
return;
}
private static Action<bool, string, string> logFunction = defaultCallbackFunc;
private void log(bool error, string type, string text)
{
string[] msgs = text.Replace("\r", "").Split("\n");
foreach(string msg in msgs)
{
logFunction(error, type, msg);
}
}
public static void SetCallback(Action<bool, string, string> callback)
{
logFunction = callback;
}
public static void ErrorPrint(string text)
{
if (ConfigReader.LogLevel >= 1)
logFunction(true, "ERROR", text);
}
public static void WarnPrint(string text)
{
if (ConfigReader.LogLevel >= 2)
logFunction(false, "WARN", text);
}
public static void HackerPrint(string text)
{
if (ConfigReader.LogLevel >= 3)
logFunction(false, "HACK", text);
}
public static void InfoPrint(string text)
{
if (ConfigReader.LogLevel >= 4)
logFunction(false, "INFO", text);
}
public static void DebugPrint(string text)
{
if (ConfigReader.LogLevel >= 5)
logFunction(false, "DEBUG", text);
}
public static void CrashPrint(string text)
{
logFunction(true, "CRASH", text);
}
}
}