PROACTIVE — 主动模式
Feature Flag:FEATURE_PROACTIVE=1(与FEATURE_KAIROS=1共享功能) 实现状态:核心循环与 SleepTool 已落地,部分外围文档仍在补齐 引用数:37
一、功能概述
PROACTIVE 实现 Tick 驱动的自主代理。CLI 在用户不输入时也能持续工作:定时唤醒执行任务,配合 SleepTool 控制节奏。适用于长时间运行的后台任务(等待 CI、监控文件变化、定时检查等)。与 KAIROS 的关系
所有代码检查都是feature('PROACTIVE') || feature('KAIROS'),即:
- 单独开
FEATURE_PROACTIVE=1→ 获得 proactive 能力 - 单独开
FEATURE_KAIROS=1→ 自动获得 proactive 能力 - 两者都开 → 相同效果(不重复)
二、实现架构
2.1 模块状态
| 模块 | 文件 | 状态 | 说明 |
|---|---|---|---|
| 核心逻辑 | src/proactive/index.ts | 已实现 | activateProactive()、deactivateProactive()、pause/resume、nextTickAt 调度状态 |
| SleepTool 提示 | src/tools/SleepTool/prompt.ts | 完整 | 工具提示定义(工具名:Sleep) |
| 命令注册 | src/commands.ts:62-65 | 布线 | 动态加载 ./commands/proactive.js |
| 工具注册 | src/tools.ts:26-28 | 布线 | SleepTool 动态加载 |
| REPL 集成 | src/screens/REPL.tsx | 已实现 | tick 驱动、standby/sleeping 状态、页脚与 bridge automation metadata 上报 |
| 系统提示 | src/constants/prompts.ts:864-918 | 完整 | 自主工作行为指令(~55 行详细 prompt) |
| 远控状态镜像 | src/utils/sessionState.ts | 已实现 | 向 remote-control/CCR 暴露 automation_state 元数据 |
2.2 系统提示内容
getProactiveSection() 注入的自主工作指令包含:
| 章节 | 内容 |
|---|---|
| Tick 驱动 | <tick_tag> prompt 保持存活,包含用户本地时间 |
| 节奏控制 | SleepTool 控制等待间隔,prompt cache 5 分钟过期 |
| 空操作规则 | 无事可做时必须调用 Sleep,禁止输出 “still waiting” |
| 首次唤醒 | 简短问候,等待方向(不主动探索) |
| 后续唤醒 | 寻找有用工作:调查、验证、检查(不 spam 用户) |
| 偏向行动 | 读文件、搜索代码、commit — 不需询问 |
| 终端焦点 | terminalFocus 字段调节自主程度 |
2.3 数据流
三、当前行为补充
standby:proactive 已开启,当前没有执行中的 turn,且已调度下一个 tick。sleeping:模型显式调用SleepTool进入等待窗口。- remote-control/CCR 通过
external_metadata.automation_state接收这两个状态,用于 Web UI 的 Autopilot 状态显示。 SleepTool现在不是纯定时器;它会在共享命令队列出现新工作时提前醒来。
四、关键设计决策
- Tick 驱动:模型通过 SleepTool 自行控制唤醒频率,不是外部事件推送
- 空操作必须 Sleep:防止 “still waiting” 类空消息浪费 turn 和 token
- Prompt cache 考量:SleepTool 提示中提到 cache 5 分钟过期,建议平衡等待时间
- Terminal Focus 感知:模型根据用户是否在看终端调整自主程度
五、使用方式
六、文件索引
| 文件 | 职责 |
|---|---|
src/proactive/index.ts | 核心逻辑与 next-tick 状态 |
src/tools/SleepTool/prompt.ts | SleepTool 工具提示 |
src/tools/SleepTool/SleepTool.ts | 休眠/唤醒执行逻辑 |
src/constants/prompts.ts:864-918 | 自主工作系统提示 |
src/screens/REPL.tsx | REPL tick 集成与 automation 状态上报 |
src/utils/sessionStorage.ts:4892-4912 | Tick 消息注入 |
src/utils/sessionState.ts | bridge/CCR metadata 镜像 |
src/components/PromptInput/PromptInputFooterLeftSide.tsx | 页脚 UI 状态 |