GFramework/GFramework.Core/state/ContextAwareStateBase.cs
GeWuYou 73d1fcf6fd refactor(core): 将 IDisposable 替换为 IDestroyable 接口
- 重命名 IDisposable 接口为 IDestroyable 并移动到 lifecycle 命名空间
- 更新 Architecture.cs 中的可销毁组件集合类型从 IDisposable 到 IDestroyable
- 修改 WaitForEvent 和 WaitForMultipleEvents 类实现 IDestroyable 接口
- 更新 AsyncContextAwareStateBase 和 ContextAwareStateBase 继承 IDestroyable 接口
- 修改 StateMachineSystem 中状态清理逻辑使用 IDestroyable 类型判断
- 更新 ILifecycle 接口继承关系使用新的 IDestroyable 接口
2026-02-17 18:41:16 +08:00

75 lines
2.4 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using GFramework.Core.Abstractions.architecture;
using GFramework.Core.Abstractions.lifecycle;
using GFramework.Core.Abstractions.rule;
using GFramework.Core.Abstractions.state;
namespace GFramework.Core.state;
/// <summary>
/// 上下文感知状态基类
/// 提供基础的状态管理功能和架构上下文访问能力
/// 实现了IState和IContextAware接口
/// </summary>
public class ContextAwareStateBase : IState, IContextAware, IDestroyable
{
/// <summary>
/// 架构上下文引用,用于访问架构相关的服务和数据
/// </summary>
private IArchitectureContext? _context;
/// <summary>
/// 设置架构上下文
/// </summary>
/// <param name="context">架构上下文实例</param>
public void SetContext(IArchitectureContext context)
{
_context = context;
}
/// <summary>
/// 获取架构上下文
/// </summary>
/// <returns>架构上下文实例</returns>
public IArchitectureContext GetContext()
{
return _context ?? throw new InvalidOperationException(
$"Architecture context has not been set. Call {nameof(SetContext)} before accessing the context.");
}
/// <summary>
/// 销毁当前状态,释放相关资源
/// 子类可重写此方法以执行特定的清理操作
/// </summary>
public virtual void Destroy()
{
}
/// <summary>
/// 进入状态时调用的方法
/// 子类可重写此方法以实现特定的状态进入逻辑
/// </summary>
/// <param name="from">从哪个状态转换而来可能为null表示初始状态</param>
public virtual void OnEnter(IState? from)
{
}
/// <summary>
/// 退出状态时调用的方法
/// 子类可重写此方法以实现特定的状态退出逻辑
/// </summary>
/// <param name="to">将要转换到的目标状态可能为null表示结束状态</param>
public virtual void OnExit(IState? to)
{
}
/// <summary>
/// 判断当前状态是否可以转换到目标状态
/// 子类可重写此方法以实现自定义的状态转换规则
/// </summary>
/// <param name="target">希望转换到的目标状态对象</param>
/// <returns>如果允许转换则返回true否则返回false</returns>
public virtual bool CanTransitionTo(IState target)
{
return true;
}
}