Refactor project structure and improve performance

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.
This commit is contained in:
2025-06-05 21:45:50 +09:00
parent 61bbb1bc68
commit bab3be2508
69 changed files with 2184 additions and 1582 deletions

View File

@@ -0,0 +1,73 @@
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);
}
}