Files
better-genshin-impact/BetterGenshinImpact/Service/GearTask/Execution/GearTaskExecutionEvents.cs
辉鸭蛋 7f7a34e9ba feat(gear-task): 引入事件驱动的任务执行与历史记录系统
- 新增 IGearTaskEventBus 接口及默认实现,用于解耦执行器与记录器、UI 投影等消费者
- 新增 IGearTaskResumable 接口,支持任务节点内部恢复(如 Pathing 任务可恢复至特定路径点)
- 重构任务执行流程,使用 GearTaskExecutionRunner 替代旧的 GearTaskExecutionManager
- 实现基于磁盘 JSON 的历史记录存储(IGearTaskHistoryStore),支持执行记录的保存、加载与清理
- 为 PathingGearTask 添加恢复能力,通过 PathingGearTaskResumeState 记录断点状态
- 在 PathExecutor 中集成运行时事件通知,支持路径点进入、完成、传送等事件的发布
- 统一执行事件模型(GearTaskExecutionEvent),包含任务定义、节点路径、时间戳等元数据
- 服务注册更新,使用新的执行器、事件总线、历史记录器等组件
2026-05-11 01:57:29 +08:00

172 lines
4.1 KiB
C#

namespace BetterGenshinImpact.Service.GearTask.Execution;
/// <summary>
/// 一次任务组执行开始。
/// </summary>
public sealed class ExecutionStartedEvent : GearTaskExecutionEvent
{
/// <summary>
/// 如果本次执行来自续跑,则记录源执行记录 Id。
/// </summary>
public string? SourceRecordId { get; set; }
/// <summary>
/// 本次预计可执行的总节点数,用于进度展示。
/// </summary>
public int TotalRunnableNodeCount { get; set; }
}
/// <summary>
/// 一次任务组执行正常结束。
/// </summary>
public sealed class ExecutionCompletedEvent : GearTaskExecutionEvent
{
}
/// <summary>
/// 一次任务组执行因异常失败。
/// </summary>
public sealed class ExecutionFailedEvent : GearTaskExecutionEvent
{
public string ErrorMessage { get; set; } = string.Empty;
}
/// <summary>
/// 一次任务组执行被取消。
/// </summary>
public sealed class ExecutionCancelledEvent : GearTaskExecutionEvent
{
public string? Reason { get; set; }
}
/// <summary>
/// 一次任务组执行被外部中断,但不一定等价于异常失败。
/// </summary>
public sealed class ExecutionInterruptedEvent : GearTaskExecutionEvent
{
public string? Reason { get; set; }
}
/// <summary>
/// 单个任务节点开始执行。
/// </summary>
public sealed class TaskNodeStartedEvent : GearTaskExecutionEvent
{
}
/// <summary>
/// 单个任务节点执行完成。
/// </summary>
public sealed class TaskNodeCompletedEvent : GearTaskExecutionEvent
{
public string? Message { get; set; }
}
/// <summary>
/// 单个任务节点执行失败。
/// </summary>
public sealed class TaskNodeFailedEvent : GearTaskExecutionEvent
{
public string ErrorMessage { get; set; } = string.Empty;
}
/// <summary>
/// 单个任务节点被跳过。
/// </summary>
public sealed class TaskNodeSkippedEvent : GearTaskExecutionEvent
{
public string Reason { get; set; } = string.Empty;
}
/// <summary>
/// 任务内部恢复点更新。
/// </summary>
public sealed class ResumePointUpdatedEvent : GearTaskExecutionEvent
{
/// <summary>
/// 是否支持在该任务内部继续执行,而不是仅支持节点级重跑。
/// </summary>
public bool CanResumeInsideTask { get; set; }
/// <summary>
/// 任务私有恢复状态序列化结果。
/// </summary>
public string? ResumeTokenJson { get; set; }
public string? Message { get; set; }
}
/// <summary>
/// Pathing 进入某个 waypoint。
/// </summary>
public sealed class PathingWaypointEnteredEvent : GearTaskExecutionEvent
{
public int WaypointGroupIndex { get; set; }
public int WaypointIndex { get; set; }
public string? Action { get; set; }
public double PositionX { get; set; }
public double PositionY { get; set; }
}
/// <summary>
/// Pathing 完成某个 waypoint。
/// </summary>
public sealed class PathingWaypointCompletedEvent : GearTaskExecutionEvent
{
public int WaypointGroupIndex { get; set; }
public int WaypointIndex { get; set; }
public string? Action { get; set; }
public double PositionX { get; set; }
public double PositionY { get; set; }
}
/// <summary>
/// Pathing 完成传送步骤。
/// </summary>
public sealed class PathingTeleportCompletedEvent : GearTaskExecutionEvent
{
public int WaypointGroupIndex { get; set; }
public int WaypointIndex { get; set; }
public double PositionX { get; set; }
public double PositionY { get; set; }
}
/// <summary>
/// Pathing 完成 waypoint 绑定动作。
/// </summary>
public sealed class PathingActionCompletedEvent : GearTaskExecutionEvent
{
public int WaypointGroupIndex { get; set; }
public int WaypointIndex { get; set; }
public string Action { get; set; } = string.Empty;
public double PositionX { get; set; }
public double PositionY { get; set; }
}
/// <summary>
/// JavaScript 脚本主动上报的检查点事件。
/// </summary>
public sealed class ScriptCheckpointReachedEvent : GearTaskExecutionEvent
{
public string CheckpointName { get; set; } = string.Empty;
public string? ResumeTokenJson { get; set; }
public string? Message { get; set; }
}