Changed the `ProjectRepository` class to be static for easier usage. Changed `ProjectService` constants to public properties for accessibility. Changed `App.xaml` to consolidate theme resources into `Override.xaml`. Changed `App.xaml.cs` to implement an `AppStateMachine` for better state management. Changed `ConsolePage` and `HierarchyPage` to utilize the new ViewModel structure. Changed `ProjectPage` to use the `ExplorerItem` model for asset display. Changed `Entity` and `EntityManager` to enhance component management with a new `IComponentData` interface. Changed the `Logger` class to introduce structured logging functionality. Changed the system architecture to support dependency management for better organization. Changed the `QueryEnumerable` class to allow for more flexible entity queries. Changed the `TypeHandle` class to improve efficiency in retrieving type handles. Changed the `World` class to support robust world management and multiple worlds. Updated the `Test` class to demonstrate the new entity and component management system.
73 lines
1.6 KiB
C#
73 lines
1.6 KiB
C#
using Ghost.Engine.Models;
|
|
using System.Diagnostics;
|
|
|
|
namespace Ghost.Engine.Services;
|
|
|
|
internal enum LogChangeType
|
|
{
|
|
LogAdded,
|
|
LogRemoved,
|
|
LogsCleared
|
|
}
|
|
|
|
public static class Logger
|
|
{
|
|
|
|
private const int _MAX_LOGS = 4096;
|
|
|
|
private static readonly List<LogMessage> _logs = new();
|
|
internal static List<LogMessage> Logs => _logs;
|
|
|
|
internal static event Action<LogChangeType>? OnLogsUpdate;
|
|
|
|
internal static bool HasStackTrace
|
|
{
|
|
get; set;
|
|
}
|
|
|
|
private static void LogInternal(LogLevel level, string message, int skipFrame)
|
|
{
|
|
if (_logs.Count >= _MAX_LOGS)
|
|
{
|
|
_logs.RemoveAt(0);
|
|
OnLogsUpdate?.Invoke(LogChangeType.LogRemoved);
|
|
}
|
|
|
|
StackTrace? stackTrace = null;
|
|
if (HasStackTrace)
|
|
{
|
|
stackTrace = new StackTrace(skipFrame, true);
|
|
}
|
|
|
|
var logMessage = new LogMessage(level, message, stackTrace);
|
|
_logs.Add(logMessage);
|
|
|
|
OnLogsUpdate?.Invoke(LogChangeType.LogAdded);
|
|
}
|
|
|
|
public static void Log(LogLevel level, string message)
|
|
{
|
|
LogInternal(level, message, 2);
|
|
}
|
|
|
|
public static void LogInfo(string message)
|
|
{
|
|
LogInternal(LogLevel.Info, message, 3);
|
|
}
|
|
|
|
public static void LogWarning(string message)
|
|
{
|
|
LogInternal(LogLevel.Warning, message, 3);
|
|
}
|
|
|
|
public static void LogError(string message)
|
|
{
|
|
LogInternal(LogLevel.Error, message, 3);
|
|
}
|
|
|
|
internal static void Clear()
|
|
{
|
|
_logs.Clear();
|
|
OnLogsUpdate?.Invoke(LogChangeType.LogsCleared);
|
|
}
|
|
} |