--- name: subagent-driven-development description: 当在当前会话中执行包含独立任务的实现计划时使用 --- # 子智能体驱动开发 通过为每个任务分派一个全新的子智能体来执行计划,每个任务完成后进行两阶段审查:先审查规格合规性,再审查代码质量。 **为什么用子智能体:** 你将任务委派给具有隔离上下文的专用智能体。通过精心设计它们的指令和上下文,确保它们专注并成功完成任务。它们不应继承你的会话上下文或历史记录——你要精确构造它们所需的一切。这样也能为你自己保留用于协调工作的上下文。 **核心原则:** 每个任务一个全新子智能体 + 两阶段审查(先规格后质量)= 高质量、快速迭代 ## 何时使用 ```dot digraph when_to_use { "有实现计划?" [shape=diamond]; "任务基本独立?" [shape=diamond]; "留在当前会话?" [shape=diamond]; "subagent-driven-development" [shape=box]; "executing-plans" [shape=box]; "手动执行或先头脑风暴" [shape=box]; "有实现计划?" -> "任务基本独立?" [label="是"]; "有实现计划?" -> "手动执行或先头脑风暴" [label="否"]; "任务基本独立?" -> "留在当前会话?" [label="是"]; "任务基本独立?" -> "手动执行或先头脑风暴" [label="否 - 紧密耦合"]; "留在当前会话?" -> "subagent-driven-development" [label="是"]; "留在当前会话?" -> "executing-plans" [label="否 - 并行会话"]; } ``` **与 Executing Plans(并行会话)的对比:** - 同一会话(无上下文切换) - 每个任务全新子智能体(无上下文污染) - 每个任务后两阶段审查:先规格合规性,再代码质量 - 更快的迭代(任务间无需人工介入) ## 流程 ```dot digraph process { rankdir=TB; subgraph cluster_per_task { label="每个任务"; "分派实现子智能体 (./implementer-prompt.md)" [shape=box]; "实现子智能体有疑问?" [shape=diamond]; "回答问题,提供上下文" [shape=box]; "实现子智能体实现、测试、提交、自审" [shape=box]; "分派规格审查子智能体 (./spec-reviewer-prompt.md)" [shape=box]; "规格审查子智能体确认代码匹配规格?" [shape=diamond]; "实现子智能体修复规格差距" [shape=box]; "分派代码质量审查子智能体 (./code-quality-reviewer-prompt.md)" [shape=box]; "代码质量审查子智能体通过?" [shape=diamond]; "实现子智能体修复质量问题" [shape=box]; "在 TodoWrite 中标记任务完成" [shape=box]; } "读取计划,提取所有任务的完整文本,记录上下文,创建 TodoWrite" [shape=box]; "还有剩余任务?" [shape=diamond]; "分派最终代码审查子智能体审查整体实现" [shape=box]; "使用 superpowers:finishing-a-development-branch" [shape=box style=filled fillcolor=lightgreen]; "读取计划,提取所有任务的完整文本,记录上下文,创建 TodoWrite" -> "分派实现子智能体 (./implementer-prompt.md)"; "分派实现子智能体 (./implementer-prompt.md)" -> "实现子智能体有疑问?"; "实现子智能体有疑问?" -> "回答问题,提供上下文" [label="是"]; "回答问题,提供上下文" -> "分派实现子智能体 (./implementer-prompt.md)"; "实现子智能体有疑问?" -> "实现子智能体实现、测试、提交、自审" [label="否"]; "实现子智能体实现、测试、提交、自审" -> "分派规格审查子智能体 (./spec-reviewer-prompt.md)"; "分派规格审查子智能体 (./spec-reviewer-prompt.md)" -> "规格审查子智能体确认代码匹配规格?"; "规格审查子智能体确认代码匹配规格?" -> "实现子智能体修复规格差距" [label="否"]; "实现子智能体修复规格差距" -> "分派规格审查子智能体 (./spec-reviewer-prompt.md)" [label="重新审查"]; "规格审查子智能体确认代码匹配规格?" -> "分派代码质量审查子智能体 (./code-quality-reviewer-prompt.md)" [label="是"]; "分派代码质量审查子智能体 (./code-quality-reviewer-prompt.md)" -> "代码质量审查子智能体通过?"; "代码质量审查子智能体通过?" -> "实现子智能体修复质量问题" [label="否"]; "实现子智能体修复质量问题" -> "分派代码质量审查子智能体 (./code-quality-reviewer-prompt.md)" [label="重新审查"]; "代码质量审查子智能体通过?" -> "在 TodoWrite 中标记任务完成" [label="是"]; "在 TodoWrite 中标记任务完成" -> "还有剩余任务?"; "还有剩余任务?" -> "分派实现子智能体 (./implementer-prompt.md)" [label="是"]; "还有剩余任务?" -> "分派最终代码审查子智能体审查整体实现" [label="否"]; "分派最终代码审查子智能体审查整体实现" -> "使用 superpowers:finishing-a-development-branch"; } ``` ## 模型选择 使用能胜任每个角色的最低成本模型,以节省开支并提高速度。 **机械性实现任务**(隔离的函数、清晰的规格、1-2 个文件):使用快速、便宜的模型。当计划编写得足够详细时,大多数实现任务都是机械性的。 **集成和判断类任务**(多文件协调、模式匹配、调试):使用标准模型。 **架构、设计和审查类任务**:使用最强的可用模型。 **任务复杂度信号:** - 涉及 1-2 个文件且有完整规格 → 便宜模型 - 涉及多个文件且有集成考虑 → 标准模型 - 需要设计判断或广泛的代码库理解 → 最强模型 ## 处理实现者状态 实现子智能体报告四种状态之一。根据每种状态进行相应处理: **DONE:** 进入规格合规性审查。 **DONE_WITH_CONCERNS:** 实现者完成了工作但标记了疑虑。在继续之前阅读这些疑虑。如果疑虑涉及正确性或范围,在审查前解决。如果只是观察性说明(如"这个文件越来越大了"),记录下来并继续审查。 **NEEDS_CONTEXT:** 实现者需要未提供的信息。提供缺失的上下文并重新分派。 **BLOCKED:** 实现者无法完成任务。评估阻塞原因: 1. 如果是上下文问题,提供更多上下文并用同一模型重新分派 2. 如果任务需要更强的推理能力,用更强的模型重新分派 3. 如果任务太大,拆分为更小的部分 4. 如果计划本身有问题,上报给人类 **绝不** 忽略上报或在不做任何更改的情况下让同一模型重试。如果实现者说卡住了,说明有什么东西需要改变。 ## 提示词模板 - `./implementer-prompt.md` - 分派实现子智能体 - `./spec-reviewer-prompt.md` - 分派规格合规审查子智能体 - `./code-quality-reviewer-prompt.md` - 分派代码质量审查子智能体 ## 示例工作流 ``` 你:我正在使用子智能体驱动开发来执行这个计划。 [一次性读取计划文件:docs/superpowers/plans/feature-plan.md] [提取全部 5 个任务的完整文本和上下文] [用所有任务创建 TodoWrite] 任务 1:Hook 安装脚本 [获取任务 1 的文本和上下文(已提取)] [分派实现子智能体,附带完整任务文本 + 上下文] 实现者:"在我开始之前——hook 应该安装在用户级别还是系统级别?" 你:"用户级别(~/.config/superpowers/hooks/)" 实现者:"明白了。现在开始实现……" [稍后] 实现者: - 实现了 install-hook 命令 - 添加了测试,5/5 通过 - 自审:发现遗漏了 --force 参数,已添加 - 已提交 [分派规格合规审查] 规格审查者:✅ 符合规格 - 所有需求已满足,无多余内容 [获取 git SHA,分派代码质量审查] 代码审查者:优点:测试覆盖好,代码整洁。问题:无。通过。 [标记任务 1 完成] 任务 2:恢复模式 [获取任务 2 的文本和上下文(已提取)] [分派实现子智能体,附带完整任务文本 + 上下文] 实现者:[无疑问,直接开始] 实现者: - 添加了 verify/repair 模式 - 8/8 测试通过 - 自审:一切正常 - 已提交 [分派规格合规审查] 规格审查者:❌ 问题: - 缺失:进度报告(规格要求"每 100 项报告一次") - 多余:添加了 --json 参数(未被要求) [实现者修复问题] 实现者:移除了 --json 参数,添加了进度报告 [规格审查者再次审查] 规格审查者:✅ 现在符合规格 [分派代码质量审查] 代码审查者:优点:扎实。问题(重要):魔法数字(100) [实现者修复] 实现者:提取了 PROGRESS_INTERVAL 常量 [代码审查者再次审查] 代码审查者:✅ 通过 [标记任务 2 完成] ... [所有任务完成后] [分派最终代码审查] 最终审查者:所有需求已满足,可以合并 完成! ``` ## 优势 **与手动执行相比:** - 子智能体自然遵循 TDD - 每个任务全新上下文(不会混淆) - 并行安全(子智能体不会互相干扰) - 子智能体可以提问(工作前和工作中都可以) **与 Executing Plans 相比:** - 同一会话(无交接) - 持续进展(无需等待) - 审查检查点自动化 **效率提升:** - 无文件读取开销(控制者提供完整文本) - 控制者精确策划所需上下文 - 子智能体预先获得完整信息 - 问题在工作开始前就被提出(而非工作结束后) **质量关卡:** - 自审在交接前发现问题 - 两阶段审查:规格合规性,然后代码质量 - 审查循环确保修复确实有效 - 规格合规防止过度/不足构建 - 代码质量确保实现良好 **成本:** - 更多子智能体调用(每个任务需要实现者 + 2 个审查者) - 控制者需要更多准备工作(预先提取所有任务) - 审查循环增加迭代次数 - 但能及早发现问题(比后期调试更省成本) ## 红线 **绝不:** - 未经用户明确同意就在 main/master 分支上开始实现 - 跳过审查(规格合规性或代码质量) - 带着未修复的问题继续 - 并行分派多个实现子智能体(会冲突) - 让子智能体读取计划文件(应提供完整文本) - 跳过场景铺设上下文(子智能体需要理解任务在哪个环节) - 忽视子智能体的问题(在让它们继续之前先回答) - 在规格合规性上接受"差不多就行"(规格审查者发现问题 = 未完成) - 跳过审查循环(审查者发现问题 = 实现者修复 = 再次审查) - 让实现者的自审替代正式审查(两者都需要) - **在规格合规性审查通过之前开始代码质量审查**(顺序错误) - 在任一审查有未解决问题时就进入下一个任务 **如果子智能体提问:** - 清晰完整地回答 - 必要时提供额外上下文 - 不要催促它们进入实现阶段 **如果审查者发现问题:** - 实现者(同一子智能体)修复 - 审查者再次审查 - 重复直到通过 - 不要跳过重新审查 **如果子智能体失败:** - 分派修复子智能体并提供具体指令 - 不要尝试手动修复(上下文污染) ## 集成 **必需的工作流技能:** - **superpowers:using-git-worktrees** - 必需:在开始前建立隔离工作区 - **superpowers:writing-plans** - 创建本技能执行的计划 - **superpowers:requesting-code-review** - 审查子智能体的代码审查模板 - **superpowers:finishing-a-development-branch** - 所有任务完成后收尾 **子智能体应使用:** - **superpowers:test-driven-development** - 子智能体对每个任务遵循 TDD **替代工作流:** - **superpowers:executing-plans** - 用于并行会话而非同会话执行