2024-07-03 18:15:28 +08:00
|
|
|
#define TRACE
|
|
|
|
using System;
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
namespace MyNes.Core
|
2024-07-03 18:15:28 +08:00
|
|
|
{
|
2024-07-03 18:22:22 +08:00
|
|
|
public sealed class Tracer
|
|
|
|
{
|
|
|
|
public static event EventHandler<TracerEventArgs> EventRaised;
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteLine(string message)
|
|
|
|
{
|
|
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, TracerStatus.Normal));
|
|
|
|
Trace.WriteLine(message);
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteLine(string message, string category)
|
|
|
|
{
|
|
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", TracerStatus.Normal));
|
|
|
|
Trace.WriteLine($"{category}: {message}");
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteLine(string message, TracerStatus status)
|
|
|
|
{
|
|
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, status));
|
|
|
|
Trace.WriteLine(message);
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteLine(string message, string category, TracerStatus status)
|
|
|
|
{
|
|
|
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", status));
|
|
|
|
Trace.WriteLine($"{category}: {message}");
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteError(string message)
|
|
|
|
{
|
|
|
|
WriteLine(message, TracerStatus.Error);
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteError(string message, string category)
|
|
|
|
{
|
|
|
|
WriteLine(message, category, TracerStatus.Error);
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteWarning(string message)
|
|
|
|
{
|
|
|
|
WriteLine(message, TracerStatus.Warning);
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteWarning(string message, string category)
|
|
|
|
{
|
|
|
|
WriteLine(message, category, TracerStatus.Warning);
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteInformation(string message)
|
|
|
|
{
|
|
|
|
WriteLine(message, TracerStatus.Infromation);
|
|
|
|
}
|
2024-07-03 18:15:28 +08:00
|
|
|
|
2024-07-03 18:22:22 +08:00
|
|
|
public static void WriteInformation(string message, string category)
|
|
|
|
{
|
|
|
|
WriteLine(message, category, TracerStatus.Infromation);
|
|
|
|
}
|
|
|
|
}
|
2024-07-03 15:40:13 +08:00
|
|
|
}
|