using GFramework.Core.Abstractions.architecture; using GFramework.Core.Abstractions.command; using GFramework.Core.Abstractions.ecs; using GFramework.Core.Abstractions.environment; using GFramework.Core.Abstractions.events; using GFramework.Core.Abstractions.ioc; using GFramework.Core.Abstractions.model; using GFramework.Core.Abstractions.query; using GFramework.Core.Abstractions.system; using GFramework.Core.Abstractions.utility; using GFramework.Core.ecs; using Mediator; using ICommand = GFramework.Core.Abstractions.command.ICommand; namespace GFramework.Core.architecture; /// /// 架构上下文类,提供对系统、模型、工具等组件的访问以及命令、查询、事件的执行管理 /// public class ArchitectureContext(IIocContainer container) : IArchitectureContext { private readonly IIocContainer _container = container ?? throw new ArgumentNullException(nameof(container)); private readonly Dictionary _serviceCache = new(); private EcsSystemRunner? _ecsRunner; private EcsWorld? _ecsWorld; #region Mediator Integration (新实现) /// /// 获取 Mediator 实例(延迟加载) /// private IMediator? Mediator => GetOrCache(); /// /// 获取 ISender 实例(更轻量的发送器) /// private ISender? Sender => GetOrCache(); /// /// 获取 IPublisher 实例(用于发布通知) /// private IPublisher? Publisher => GetOrCache(); /// /// 获取指定类型的服务实例,如果缓存中存在则直接返回,否则从容器中获取并缓存 /// /// 服务类型,必须为引用类型 /// 服务实例,如果未找到则返回null public TService? GetService() where TService : class { return GetOrCache(); } /// /// 从缓存中获取或创建指定类型的服务实例 /// 首先尝试从缓存中获取服务实例,如果缓存中不存在则从容器中获取并存入缓存 /// /// 服务类型,必须为引用类型 /// 服务实例,如果未找到则返回null private TService? GetOrCache() where TService : class { // 尝试从服务缓存中获取已存在的服务实例 if (_serviceCache.TryGetValue(typeof(TService), out var cached)) return (TService)cached; // 从依赖注入容器中获取服务实例 var service = _container.Get(); // 如果服务实例存在,则将其存入缓存以供后续使用 if (service != null) _serviceCache[typeof(TService)] = service; return service; } /// /// [Mediator] 发送请求(Command/Query) /// 这是推荐的新方式,统一处理命令和查询 /// /// 响应类型 /// 请求对象(Command 或 Query) /// 取消令牌 /// 响应结果 /// 当 Mediator 未注册时抛出 public async ValueTask SendRequestAsync( IRequest request, CancellationToken cancellationToken = default) { ArgumentNullException.ThrowIfNull(request); var mediator = Mediator; if (mediator == null) throw new InvalidOperationException( "Mediator not registered. Call EnableMediator() in your Architecture.OnInitialize() method."); return await mediator.Send(request, cancellationToken); } /// /// [Mediator] 发送请求的同步版本(不推荐,仅用于兼容性) /// /// 响应类型 /// 请求对象 /// 响应结果 public TResponse SendRequest(IRequest request) { return SendRequestAsync(request).AsTask().GetAwaiter().GetResult(); } /// /// [Mediator] 发布通知(一对多) /// 用于事件驱动场景,多个处理器可以同时处理同一个通知 /// /// 通知类型 /// 通知对象 /// 取消令牌 public async ValueTask PublishAsync( TNotification notification, CancellationToken cancellationToken = default) where TNotification : INotification { ArgumentNullException.ThrowIfNull(notification); var publisher = Publisher; if (publisher == null) throw new InvalidOperationException("Publisher not registered."); await publisher.Publish(notification, cancellationToken); } /// /// [Mediator] 发送请求并返回流(用于大数据集) /// /// 响应项类型 /// 流式请求 /// 取消令牌 /// 异步流 public IAsyncEnumerable CreateStream( IStreamRequest request, CancellationToken cancellationToken = default) { ArgumentNullException.ThrowIfNull(request); var mediator = Mediator; if (mediator == null) throw new InvalidOperationException("Mediator not registered."); return mediator.CreateStream(request, cancellationToken); } /// /// [扩展] 发送命令(无返回值) /// 语法糖,等同于 SendRequestAsync<Unit> /// public async ValueTask SendAsync( TCommand command, CancellationToken cancellationToken = default) where TCommand : IRequest { await SendRequestAsync(command, cancellationToken); } /// /// [扩展] 发送命令(有返回值) /// 语法糖,等同于 SendRequestAsync<TResponse> /// public async ValueTask SendAsync( IRequest command, CancellationToken cancellationToken = default) { return await SendRequestAsync(command, cancellationToken); } #endregion #region Query Execution /// /// 发送一个查询请求 /// /// 查询结果类型 /// 要发送的查询 /// 查询结果 public TResult SendQuery(Abstractions.query.IQuery query) { if (query == null) throw new ArgumentNullException(nameof(query)); var queryBus = GetOrCache(); if (queryBus == null) throw new InvalidOperationException("IQueryExecutor not registered"); return queryBus.Send(query); } /// /// [Mediator] 发送查询的同步版本(不推荐,仅用于兼容性) /// /// 查询响应类型 /// 要发送的查询对象 /// 查询结果 public TResponse SendQuery(Mediator.IQuery query) { return SendQueryAsync(query).AsTask().GetAwaiter().GetResult(); } /// /// 异步发送一个查询请求 /// /// 查询结果类型 /// 要发送的异步查询 /// 查询结果 public async Task SendQueryAsync(IAsyncQuery query) { if (query == null) throw new ArgumentNullException(nameof(query)); var asyncQueryBus = GetOrCache(); if (asyncQueryBus == null) throw new InvalidOperationException("IAsyncQueryExecutor not registered"); return await asyncQueryBus.SendAsync(query); } /// /// [Mediator] 异步发送查询并返回结果 /// 通过Mediator模式发送查询请求,支持取消操作 /// /// 查询响应类型 /// 要发送的查询对象 /// 取消令牌,用于取消操作 /// 包含查询结果的ValueTask public async ValueTask SendQueryAsync(Mediator.IQuery query, CancellationToken cancellationToken = default) { ArgumentNullException.ThrowIfNull(query); var sender = Sender; if (sender == null) throw new InvalidOperationException("Sender not registered."); return await sender.Send(query, cancellationToken); } #endregion #region Component Retrieval /// /// 从IOC容器中获取指定类型的系统实例 /// /// 目标系统类型 /// 对应的系统实例 public TSystem? GetSystem() where TSystem : class, ISystem { return GetService(); } /// /// 从IOC容器中获取指定类型的模型实例 /// /// 目标模型类型 /// 对应的模型实例 public TModel? GetModel() where TModel : class, IModel { return GetService(); } /// /// 从IOC容器中获取指定类型的工具实例 /// /// 目标工具类型 /// 对应的工具实例 public TUtility? GetUtility() where TUtility : class, IUtility { return GetService(); } #endregion #region Command Execution /// /// [Mediator] 异步发送命令并返回结果 /// 通过Mediator模式发送命令请求,支持取消操作 /// /// 命令响应类型 /// 要发送的命令对象 /// 取消令牌,用于取消操作 /// 包含命令执行结果的ValueTask public async ValueTask SendCommandAsync(Mediator.ICommand command, CancellationToken cancellationToken = default) { ArgumentNullException.ThrowIfNull(command); var sender = Sender; if (sender == null) throw new InvalidOperationException("Sender not registered."); return await sender.Send(command, cancellationToken); } /// /// 发送并异步执行一个命令请求 /// /// 要发送的命令 public async Task SendCommandAsync(IAsyncCommand command) { ArgumentNullException.ThrowIfNull(command); var commandBus = GetOrCache(); if (commandBus == null) throw new InvalidOperationException("ICommandExecutor not registered"); await commandBus.SendAsync(command); } /// /// 发送并异步执行一个带返回值的命令请求 /// /// 命令执行结果类型 /// 要发送的命令 /// 命令执行结果 public async Task SendCommandAsync(IAsyncCommand command) { ArgumentNullException.ThrowIfNull(command); var commandBus = GetOrCache(); if (commandBus == null) throw new InvalidOperationException("ICommandExecutor not registered"); return await commandBus.SendAsync(command); } /// /// [Mediator] 发送命令的同步版本(不推荐,仅用于兼容性) /// /// 命令响应类型 /// 要发送的命令对象 /// 命令执行结果 public TResponse SendCommand(Mediator.ICommand command) { return SendCommandAsync(command).AsTask().GetAwaiter().GetResult(); } /// /// 发送一个命令请求 /// /// 要发送的命令 public void SendCommand(ICommand command) { ArgumentNullException.ThrowIfNull(command); var commandBus = GetOrCache(); commandBus?.Send(command); } /// /// 发送一个带返回值的命令请求 /// /// 命令执行结果类型 /// 要发送的命令 /// 命令执行结果 public TResult SendCommand(Abstractions.command.ICommand command) { ArgumentNullException.ThrowIfNull(command); var commandBus = GetOrCache(); if (commandBus == null) throw new InvalidOperationException("ICommandExecutor not registered"); return commandBus.Send(command); } #endregion #region Event Management /// /// 发送一个默认构造的新事件 /// /// 事件类型 public void SendEvent() where TEvent : new() { var eventBus = GetOrCache(); eventBus?.Send(); } /// /// 发送一个具体的事件实例 /// /// 事件类型 /// 事件参数 public void SendEvent(TEvent e) where TEvent : class { ArgumentNullException.ThrowIfNull(e); var eventBus = GetOrCache(); eventBus?.Send(e); } /// /// 注册事件处理器 /// /// 事件类型 /// 事件处理委托 /// 事件注销接口 public IUnRegister RegisterEvent(Action handler) { ArgumentNullException.ThrowIfNull(handler); var eventBus = GetOrCache(); if (eventBus == null) throw new InvalidOperationException("IEventBus not registered"); return eventBus.Register(handler); } /// /// 取消对某类型事件的监听 /// /// 事件类型 /// 之前绑定的事件处理器 public void UnRegisterEvent(Action onEvent) { ArgumentNullException.ThrowIfNull(onEvent); var eventBus = GetOrCache(); eventBus?.UnRegister(onEvent); } /// /// 获取当前环境对象 /// /// 环境对象实例 public IEnvironment GetEnvironment() { var environment = GetOrCache(); return environment ?? throw new InvalidOperationException("IEnvironment not registered"); } #endregion #region ECS Support /// /// 获取ECS世界实例 /// /// ECS世界实例 public IEcsWorld GetEcsWorld() { return _ecsWorld ?? throw new InvalidOperationException("ECS World not initialized. Call InitializeEcs() first."); } /// /// 注册ECS系统 /// /// ECS系统类型 public void RegisterEcsSystem() where T : class, IEcsSystem { // 使用RegisterPlurality注册到所有接口 _container.RegisterPlurality(); } /// /// 初始化ECS(在架构初始化时调用) /// public void InitializeEcs() { if (_ecsWorld != null) return; // 创建ECS世界 _ecsWorld = new EcsWorld(); _container.Register(_ecsWorld); // 注册系统调度器 _container.RegisterPlurality(); _ecsRunner = _container.Get(); } /// /// 获取ECS系统调度器 /// internal EcsSystemRunner? GetEcsRunner() => _ecsRunner; /// /// 销毁ECS资源 /// private void DisposeEcs() { _ecsWorld?.Dispose(); _ecsWorld = null; _ecsRunner = null; } #endregion }