MyNes_src/Core/MyNes.Core/Tracer.cs
2024-07-03 18:15:19 +08:00

65 lines
1.6 KiB
C#

#define TRACE
using System;
using System.Diagnostics;
namespace MyNes.Core;
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));
Trace.WriteLine(message);
}
public static void WriteLine(string message, string category)
{
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", TracerStatus.Normal));
Trace.WriteLine($"{category}: {message}");
}
public static void WriteLine(string message, TracerStatus status)
{
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, status));
Trace.WriteLine(message);
}
public static void WriteLine(string message, string category, TracerStatus status)
{
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", status));
Trace.WriteLine($"{category}: {message}");
}
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);
}
}