GeWuYou cc8f40ee44 style(formatter): 统一代码格式化和文档缩进
- 调整文档文件中的缩进格式一致性
- 修正所有C#接口和类定义中的注释缩进
- 移除测试代码中不必要的构造函数参数
- 重构条件语句减少嵌套层级
- 规范方法体的大括号使用风格
- 整理全局命名空间声明格式
- 优化方法实现的代码结构和可读性
- [release ci]
2026-01-29 22:35:45 +08:00

77 lines
3.1 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.model;
namespace GFramework.Game.Abstractions.setting;
/// <summary>
/// 定义设置模型的接口,提供获取特定类型设置节的功能
/// </summary>
public interface ISettingsModel : IModel
{
/// <summary>
/// 获取或创建数据设置(自动创建)
/// </summary>
/// <typeparam name="T">设置数据的类型必须继承自class、ISettingsData且具有无参构造函数</typeparam>
/// <returns>指定类型的设置数据实例</returns>
T GetData<T>() where T : class, IResettable, new();
/// <summary>
/// 尝试获取指定类型的设置节实例
/// </summary>
/// <param name="type">要获取的设置节类型</param>
/// <param name="section">输出参数如果成功则包含找到的设置节实例否则为null</param>
/// <returns>如果找到指定类型的设置节则返回true否则返回false</returns>
bool TryGet(Type type, out ISettingsSection section);
/// <summary>
/// 获取已注册的可应用设置
/// </summary>
/// <typeparam name="T">可应用设置的类型必须继承自class和IApplyAbleSettings</typeparam>
/// <returns>指定类型的可应用设置实例如果不存在则返回null</returns>
T? GetApplicator<T>() where T : class, IApplyAbleSettings;
/// <summary>
/// 获取所有设置数据的集合
/// </summary>
/// <returns>包含所有设置数据的可枚举集合</returns>
IEnumerable<IResettable> AllData();
/// <summary>
/// 获取所有可应用设置的集合
/// </summary>
/// <returns>包含所有可应用设置的可枚举集合</returns>
IEnumerable<IApplyAbleSettings> AllApplicators();
/// <summary>
/// 注册可应用设置(必须手动注册)
/// </summary>
/// <typeparam name="T">可应用设置的类型必须继承自class和IApplyAbleSettings</typeparam>
/// <param name="applicator">要注册的可应用设置实例</param>
/// <returns>返回当前设置模型实例,支持链式调用</returns>
ISettingsModel RegisterApplicator<T>(T applicator) where T : class, IApplyAbleSettings;
/// <summary>
/// 注册设置迁移器
/// </summary>
/// <param name="migration">要注册的设置迁移实例</param>
/// <returns>返回当前设置模型实例,支持链式调用</returns>
ISettingsModel RegisterMigration(ISettingsMigration migration);
/// <summary>
/// 异步初始化指定类型的设置
/// </summary>
/// <param name="settingTypes">要初始化的设置类型数组</param>
/// <returns>异步操作任务</returns>
Task InitializeAsync(params Type[] settingTypes);
/// <summary>
/// 重置指定类型的设置
/// </summary>
/// <typeparam name="T">要重置的设置类型必须实现IResettable接口并具有无参构造函数</typeparam>
void Reset<T>() where T : class, IResettable, new();
/// <summary>
/// 重置所有设置
/// </summary>
void ResetAll();
}