GFramework/GFramework.Core/Systems/AbstractSystem.cs
gewuyou ff553977e3 chore(license): 补齐 Apache-2.0 文件头治理
- 新增许可证文件头检查与修复脚本

- 补充维护者手动修复 PR 工作流和 CI 校验

- 更新贡献指南中的文件头说明

- 补齐仓库维护源码和配置文件的许可证声明
2026-05-03 19:39:49 +08:00

65 lines
1.7 KiB
C#

// Copyright (c) 2025-2026 GeWuYou
// SPDX-License-Identifier: Apache-2.0
using GFramework.Core.Abstractions.Enums;
using GFramework.Core.Abstractions.Logging;
using GFramework.Core.Abstractions.Systems;
using GFramework.Core.Logging;
using GFramework.Core.Rule;
namespace GFramework.Core.Systems;
/// <summary>
/// 抽象系统基类,实现系统接口的基本功能
/// 提供架构关联、初始化和销毁机制
/// </summary>
public abstract class AbstractSystem : ContextAwareBase, ISystem
{
private ILogger _logger = null!;
/// <summary>
/// 系统初始化方法,调用抽象初始化方法
/// </summary>
public void Initialize()
{
var name = GetType().Name;
_logger = LoggerFactoryResolver.Provider.CreateLogger(name);
_logger.Debug($"Initializing system: {name}");
OnInit();
_logger.Info($"System initialized: {name}");
}
/// <summary>
/// 系统销毁方法,调用抽象销毁方法
/// </summary>
public void Destroy()
{
_logger.Debug($"Destroying system: {GetType().Name}");
OnDestroy();
_logger.Info($"System destroyed: {GetType().Name}");
}
/// <summary>
/// 处理架构阶段事件的虚拟方法
/// </summary>
/// <param name="phase">当前的架构阶段</param>
public virtual void OnArchitecturePhase(ArchitecturePhase phase)
{
}
/// <summary>
/// 抽象初始化方法,由子类实现具体的初始化逻辑
/// </summary>
protected abstract void OnInit();
/// <summary>
/// 抽象销毁方法,由子类实现具体的资源清理逻辑
/// </summary>
protected virtual void OnDestroy()
{
}
}