forked from sin365/AxibugEmuOnline
81 lines
2.6 KiB
C#
81 lines
2.6 KiB
C#
#define TRACE
|
|
using System;
|
|
using Unity.IL2CPP.CompilerServices;
|
|
using UnityEngine;
|
|
|
|
namespace MyNes.Core
|
|
{
|
|
[Il2CppSetOption(Option.NullChecks, false)]
|
|
[Il2CppSetOption(Option.ArrayBoundsChecks, false)]
|
|
[Il2CppSetOption(Option.DivideByZeroChecks, false)]
|
|
public sealed class Tracer
|
|
{
|
|
public static event EventHandler<TracerEventArgs> EventRaised;
|
|
|
|
public static void WriteLine(string message)
|
|
{
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, TracerStatus.Normal));
|
|
//Debug.Log(message);
|
|
}
|
|
|
|
public static void WriteLine(string message, string category)
|
|
{
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", TracerStatus.Normal));
|
|
//Debug.Log(message);
|
|
}
|
|
|
|
public static void WriteLine(string message, TracerStatus status)
|
|
{
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, status));
|
|
switch (status)
|
|
{
|
|
case TracerStatus.Error: Debug.LogError(message); break;
|
|
case TracerStatus.Infromation:
|
|
case TracerStatus.Normal:
|
|
Debug.Log(message);
|
|
break;
|
|
case TracerStatus.Warning:
|
|
Debug.LogWarning(message);
|
|
break;
|
|
}
|
|
|
|
}
|
|
|
|
public static void WriteLine(string message, string category, TracerStatus status)
|
|
{
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", status));
|
|
WriteLine($"{category}:{message}", status);
|
|
}
|
|
|
|
public static void WriteError(string message)
|
|
{
|
|
WriteLine(message, TracerStatus.Error);
|
|
}
|
|
|
|
public static void WriteError(string message, string category)
|
|
{
|
|
WriteLine(message, category, TracerStatus.Error);
|
|
}
|
|
|
|
public static void WriteWarning(string message)
|
|
{
|
|
WriteLine(message, TracerStatus.Warning);
|
|
}
|
|
|
|
public static void WriteWarning(string message, string category)
|
|
{
|
|
WriteLine(message, category, TracerStatus.Warning);
|
|
}
|
|
|
|
public static void WriteInformation(string message)
|
|
{
|
|
WriteLine(message, TracerStatus.Infromation);
|
|
}
|
|
|
|
public static void WriteInformation(string message, string category)
|
|
{
|
|
WriteLine(message, category, TracerStatus.Infromation);
|
|
}
|
|
}
|
|
}
|