mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-23 11:14:30 +08:00
- 将Architecture类重构为使用构造函数注入IArchitectureConfiguration、IArchitectureServices和IArchitectureContext - 移除泛型参数和单例模式,改为使用依赖注入容器管理实例 - 添加异步初始化方法InitializeAsync支持异步初始化场景 - 引入ArchitectureOptions类统一管理架构配置选项 - 创建DefaultArchitectureConfiguration和DefaultArchitectureServices默认实现 - 新增IArchitectureContext接口提供统一的上下文访问 - 添加IAsyncInitializable接口支持异步初始化能力 - 简化架构生命周期阶段,移除Created、BeforeInit和AfterInit阶段 - 更新事件系统为ITypeEventSystem接口实现 - 重构命令和控制器接口,统一使用IContextAware替代多个能力接口 - 移除FunctionalArchitectureOptions和相关委托配置方式 - 优化日志记录使用配置中的LoggerFactory实例
106 lines
3.7 KiB
C#
106 lines
3.7 KiB
C#
using GFramework.Core.command;
|
||
using GFramework.Core.events;
|
||
using GFramework.Core.model;
|
||
using GFramework.Core.query;
|
||
using GFramework.Core.system;
|
||
using GFramework.Core.utility;
|
||
|
||
namespace GFramework.Core.architecture;
|
||
|
||
/// <summary>
|
||
/// 架构接口,定义了应用程序架构的核心功能,包括系统、模型、工具的注册和获取,
|
||
/// 以及命令、查询、事件的发送和处理机制
|
||
/// </summary>
|
||
public interface IArchitecture: IAsyncInitializable
|
||
{
|
||
/// <summary>
|
||
/// 初始化方法,用于执行对象的初始化操作
|
||
/// </summary>
|
||
/// <remarks>
|
||
/// 该方法通常用于设置初始状态、初始化成员变量或执行必要的预处理操作
|
||
/// </remarks>
|
||
void Initialize();
|
||
|
||
/// <summary>
|
||
/// 销毁方法,用于执行对象的清理和销毁操作
|
||
/// </summary>
|
||
/// <remarks>
|
||
/// 该方法通常用于释放资源、清理内存或执行必要的清理操作
|
||
/// </remarks>
|
||
void Destroy();
|
||
|
||
|
||
/// <summary>
|
||
/// 注册系统实例到架构中
|
||
/// </summary>
|
||
/// <typeparam name="T">系统类型,必须实现ISystem接口</typeparam>
|
||
/// <param name="system">要注册的系统实例</param>
|
||
void RegisterSystem<T>(T system) where T : ISystem;
|
||
|
||
/// <summary>
|
||
/// 注册模型实例到架构中
|
||
/// </summary>
|
||
/// <typeparam name="T">模型类型,必须实现IModel接口</typeparam>
|
||
/// <param name="model">要注册的模型实例</param>
|
||
void RegisterModel<T>(T model) where T : IModel;
|
||
|
||
/// <summary>
|
||
/// 注册工具实例到架构中
|
||
/// </summary>
|
||
/// <typeparam name="T">工具类型,必须实现IUtility接口</typeparam>
|
||
/// <param name="utility">要注册的工具实例</param>
|
||
void RegisterUtility<T>(T utility) where T : IUtility;
|
||
|
||
|
||
|
||
/// <summary>
|
||
/// 发送并执行指定的命令
|
||
/// </summary>
|
||
/// <typeparam name="T">命令类型,必须实现ICommand接口</typeparam>
|
||
/// <param name="command">要执行的命令实例</param>
|
||
void SendCommand<T>(T command) where T : ICommand;
|
||
|
||
/// <summary>
|
||
/// 发送并执行带有返回值的命令
|
||
/// </summary>
|
||
/// <typeparam name="TResult">命令执行结果的类型</typeparam>
|
||
/// <param name="command">要执行的命令实例</param>
|
||
/// <returns>命令执行的结果</returns>
|
||
TResult SendCommand<TResult>(ICommand<TResult> command);
|
||
|
||
/// <summary>
|
||
/// 发送并执行查询操作
|
||
/// </summary>
|
||
/// <typeparam name="TResult">查询结果的类型</typeparam>
|
||
/// <param name="query">要执行的查询实例</param>
|
||
/// <returns>查询的结果</returns>
|
||
TResult SendQuery<TResult>(IQuery<TResult> query);
|
||
|
||
/// <summary>
|
||
/// 发送无参事件
|
||
/// </summary>
|
||
/// <typeparam name="T">事件类型,必须具有无参构造函数</typeparam>
|
||
void SendEvent<T>() where T : new();
|
||
|
||
/// <summary>
|
||
/// 发送指定的事件实例
|
||
/// </summary>
|
||
/// <typeparam name="T">事件类型</typeparam>
|
||
/// <param name="e">要发送的事件实例</param>
|
||
void SendEvent<T>(T e);
|
||
|
||
/// <summary>
|
||
/// 注册事件监听器
|
||
/// </summary>
|
||
/// <typeparam name="T">事件类型</typeparam>
|
||
/// <param name="onEvent">事件触发时的回调方法</param>
|
||
/// <returns>用于取消注册的句柄</returns>
|
||
IUnRegister RegisterEvent<T>(Action<T> onEvent);
|
||
|
||
/// <summary>
|
||
/// 取消注册事件监听器
|
||
/// </summary>
|
||
/// <typeparam name="T">事件类型</typeparam>
|
||
/// <param name="onEvent">要取消注册的事件回调方法</param>
|
||
void UnRegisterEvent<T>(Action<T> onEvent);
|
||
} |