sdd-full 4.2.0 → 4.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin.js +98 -80
- package/package.json +1 -1
- package/skills/README.md +97 -0
- package/skills/call-adaptation/SKILL.md +23 -0
- package/skills/call-adaptation/call-adaptation-guide.md +136 -0
- package/skills/call-adaptation/claude-code-call-spec.md +50 -0
- package/skills/call-adaptation/trae-call-spec.md +56 -0
- package/skills/checklist.md +154 -0
- package/skills/design-planning/ai-coding-rules/SKILL.md +52 -0
- package/skills/design-planning/design-to-code/SKILL.md +53 -0
- package/skills/design-planning/enterprise-spec/SKILL.md +52 -3
- package/skills/design-planning/flutter-av/SKILL.md +44 -34
- package/skills/design-planning/flutter-map/SKILL.md +41 -31
- package/skills/design-planning/function-sdd/SKILL.md +54 -0
- package/skills/design-planning/sdd-code/SKILL.md +347 -0
- package/skills/design-planning/sdd-deploy/SKILL.md +501 -0
- package/skills/design-planning/sdd-ops/SKILL.md +306 -0
- package/skills/design-planning/sdd-test/SKILL.md +383 -0
- package/skills/design-planning/ui-sdd/SKILL.md +291 -0
- package/skills/design-planning/ui-sdd-specialized/SKILL.md +46 -40
- package/skills/design-planning/writing-plans/SKILL.md +144 -0
- package/skills/development-execution/flutter-errors/SKILL.md +44 -34
- package/skills/development-execution/sdd-add/SKILL.md +540 -0
- package/skills/development-execution/systematic-debugging/SKILL.md +298 -0
- package/skills/development-execution/test-driven-development/SKILL.md +373 -0
- package/skills/development-execution/verification-before-completion/SKILL.md +141 -0
- package/skills/knowledge-precipitation/claudeception/SKILL.md +96 -0
- package/skills/knowledge-precipitation/mempalace-auto-saver/SKILL.md +302 -0
- package/skills/quality-assurance/bdd-acceptance/SKILL.md +44 -37
- package/skills/quality-assurance/flutter-test/SKILL.md +56 -0
- package/skills/quality-assurance/quality-gate/SKILL.md +350 -0
- package/skills/quality-assurance/security-audit/SKILL.md +386 -0
- package/skills/release-ops/finishing-a-development-branch/SKILL.md +202 -0
- package/skills/release-ops/release-flow/SKILL.md +404 -0
- package/skills/requirement-analysis/brainstorming/SKILL.md +166 -0
- package/skills/requirement-analysis/competitive-brief/SKILL.md +121 -0
- package/skills/requirement-analysis/market-research/SKILL.md +143 -0
- package/skills/requirement-analysis/prd-write/SKILL.md +111 -0
- package/skills/requirement-analysis/requirement-completion-officer/SKILL.md +124 -0
- package/skills/requirement-analysis/sdd/SKILL.md +1044 -0
- package/skills/requirement-analysis/sdd-full/SKILL.md +717 -36
- package/skills/requirement-analysis/unified-flow/SKILL.md +128 -26
- package/skills/rules/project_rules.md +167 -0
- package/skills/rules/user_rules.md +254 -69
- package/skills/special-tools/env-check/SKILL.md +40 -34
- package/skills/special-tools/receiving-code-review/SKILL.md +215 -0
- package/skills/special-tools/requesting-code-review/SKILL.md +107 -0
- package/skills/special-tools/using-superpowers/SKILL.md +117 -0
- package/skills/templates/API-SDD.md +31 -0
- package/skills/templates/Andrej Karpathy AI/347/274/226/347/240/201/350/247/204/345/210/231/350/220/275/345/234/260SDD.md" +117 -0
- package/skills/templates/BDD/351/243/216/346/240/274/351/252/214/346/224/266/346/240/207/345/207/206SDD.md +147 -0
- package/skills/templates/Base-SDD.md +38 -0
- package/skills/templates/Brain-SDD.md +36 -0
- package/skills/templates/Code-SDD.md +41 -0
- package/skills/templates/Competitor-SDD.md +34 -0
- package/skills/templates/Env-SDD.md +37 -0
- package/skills/templates/Flutter/345/205/250/347/261/273/345/236/213/346/265/213/350/257/225/347/255/226/347/225/245SDD.md +162 -0
- package/skills/templates/Flutter/345/234/260/345/233/276/345/257/274/350/210/252/344/270/232/345/212/241SDD.md +136 -0
- package/skills/templates/Flutter/345/270/270/350/247/201/345/274/202/345/270/270/344/270/223/351/241/271SDD.md +159 -0
- package/skills/templates/Flutter/351/237/263/350/247/206/351/242/221/345/205/250/346/240/210SDD.md +121 -0
- package/skills/templates/PRD-SDD.md +45 -0
- package/skills/templates/SKILL.md +91 -0
- package/skills/templates/Test-SDD.md +34 -0
- package/skills/templates/UI-SDD.md +38 -0
- package/skills/templates/UI-SDD/344/270/223/347/224/250/346/250/241/346/235/277.md +141 -0
- package/skills/templates/UI/350/265/204/346/272/220/346/217/220/347/244/272/350/257/215/347/224/237/346/210/220SDD.md +67 -0
- package/skills/templates//344/274/201/344/270/232/347/272/247/345/205/250/346/240/210/345/267/245/347/250/213/350/247/204/350/214/203SDD.md +152 -0
- package/skills/templates//345/205/250/346/265/201/347/250/213SDD/350/236/215/345/220/210/344/275/223/347/263/273.md +198 -0
- package/skills/templates//345/212/237/350/203/275SDD/344/270/223/347/224/250/346/250/241/346/235/277.md +132 -0
- package/skills/templates//347/216/257/345/242/203/351/242/204/346/243/200/346/240/207/345/207/206/345/214/226SDD.md +153 -0
- package/skills/templates//351/253/230/344/277/235/347/234/237/350/256/276/350/256/241/350/275/254/344/273/243/347/240/201SDD.md +119 -0
- package/skills//345/256/214/346/225/264/345/274/200/345/217/221/346/265/201/347/250/213/346/211/213/345/206/214.md +408 -0
- package/skills//346/212/200/350/203/275/344/275/223/347/263/273/345/256/214/345/226/204/345/273/272/350/256/256.md +305 -0
- package/skills//346/212/200/350/203/275/344/275/277/347/224/250/346/214/207/345/215/227.md +285 -0
- package/skills//346/212/200/350/203/275/345/206/263/347/255/226/346/240/221.md +320 -0
- package/skills/brainstorming/SKILL.md +0 -164
- package/skills/brainstorming/scripts/frame-template.html +0 -214
- package/skills/brainstorming/scripts/helper.js +0 -88
- package/skills/brainstorming/scripts/server.cjs +0 -338
- package/skills/brainstorming/scripts/start-server.sh +0 -153
- package/skills/brainstorming/scripts/stop-server.sh +0 -55
- package/skills/brainstorming/spec-document-reviewer-prompt.md +0 -48
- package/skills/brainstorming/visual-companion.md +0 -286
- package/skills/chinese-code-review/SKILL.md +0 -277
- package/skills/chinese-commit-conventions/SKILL.md +0 -364
- package/skills/chinese-documentation/SKILL.md +0 -448
- package/skills/chinese-git-workflow/SKILL.md +0 -510
- package/skills/dispatching-parallel-agents/SKILL.md +0 -182
- package/skills/executing-plans/SKILL.md +0 -175
- package/skills/finishing-a-development-branch/SKILL.md +0 -200
- package/skills/mcp-builder/SKILL.md +0 -255
- package/skills/receiving-code-review/SKILL.md +0 -213
- package/skills/requesting-code-review/SKILL.md +0 -105
- package/skills/requesting-code-review/code-reviewer.md +0 -146
- package/skills/rules/skill-map.md +0 -97
- package/skills/subagent-driven-development/SKILL.md +0 -277
- package/skills/subagent-driven-development/code-quality-reviewer-prompt.md +0 -26
- package/skills/subagent-driven-development/implementer-prompt.md +0 -113
- package/skills/subagent-driven-development/spec-reviewer-prompt.md +0 -61
- package/skills/systematic-debugging/CREATION-LOG.md +0 -119
- package/skills/systematic-debugging/SKILL.md +0 -296
- package/skills/systematic-debugging/condition-based-waiting-example.ts +0 -158
- package/skills/systematic-debugging/condition-based-waiting.md +0 -115
- package/skills/systematic-debugging/defense-in-depth.md +0 -122
- package/skills/systematic-debugging/find-polluter.sh +0 -63
- package/skills/systematic-debugging/root-cause-tracing.md +0 -169
- package/skills/systematic-debugging/test-academic.md +0 -14
- package/skills/systematic-debugging/test-pressure-1.md +0 -58
- package/skills/systematic-debugging/test-pressure-2.md +0 -68
- package/skills/systematic-debugging/test-pressure-3.md +0 -69
- package/skills/test-driven-development/SKILL.md +0 -371
- package/skills/test-driven-development/testing-anti-patterns.md +0 -299
- package/skills/using-git-worktrees/SKILL.md +0 -218
- package/skills/using-superpowers/SKILL.md +0 -134
- package/skills/using-superpowers/references/codex-tools.md +0 -25
- package/skills/using-superpowers/references/gemini-tools.md +0 -33
- package/skills/verification-before-completion/SKILL.md +0 -139
- package/skills/workflow-runner/SKILL.md +0 -172
- package/skills/writing-plans/SKILL.md +0 -152
- package/skills/writing-plans/plan-document-reviewer-prompt.md +0 -49
- package/skills/writing-skills/SKILL.md +0 -654
- package/skills/writing-skills/anthropic-best-practices.md +0 -1149
- package/skills/writing-skills/examples/CLAUDE_MD_TESTING.md +0 -189
- package/skills/writing-skills/graphviz-conventions.dot +0 -172
- package/skills/writing-skills/persuasion-principles.md +0 -187
- package/skills/writing-skills/render-graphs.js +0 -168
- package/skills/writing-skills/testing-skills-with-subagents.md +0 -384
|
@@ -1,172 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: workflow-runner
|
|
3
|
-
description: "在 Claude Code / OpenClaw / Cursor 中直接运行 agency-orchestrator YAML 工作流——无需 API key,使用当前会话的 LLM 作为执行引擎。当用户提供 .yaml 工作流文件或要求多角色协作完成任务时触发。"
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
# 工作流执行器:在 AI 工具内运行多角色编排
|
|
7
|
-
|
|
8
|
-
直接在当前会话中执行 agency-orchestrator 的 YAML 工作流,无需配置 API key。当前 LLM 就是执行引擎——依次扮演每个角色完成任务。
|
|
9
|
-
|
|
10
|
-
## 适用场景
|
|
11
|
-
|
|
12
|
-
- 用户提供了一个 `.yaml` 工作流文件(如 `运行 workflows/story-creation.yaml`)
|
|
13
|
-
- 用户要求多个角色协作完成任务(如"用产品经理和架构师一起评审这个 PRD")
|
|
14
|
-
- 用户安装了 `agency-agents-zh` 并希望直接在 AI 工具内编排多角色
|
|
15
|
-
|
|
16
|
-
## 执行流程(5 步)
|
|
17
|
-
|
|
18
|
-
按以下顺序执行,不要跳步:
|
|
19
|
-
|
|
20
|
-
### 第 1 步:解析工作流
|
|
21
|
-
|
|
22
|
-
用 Read 工具读取用户指定的 YAML 文件,提取以下字段:
|
|
23
|
-
|
|
24
|
-
```yaml
|
|
25
|
-
name: "工作流名称"
|
|
26
|
-
agents_dir: "agency-agents-zh" # 角色定义目录
|
|
27
|
-
inputs: # 输入变量
|
|
28
|
-
- name: xxx
|
|
29
|
-
required: true/false
|
|
30
|
-
default: "默认值"
|
|
31
|
-
steps: # 执行步骤
|
|
32
|
-
- id: step_id
|
|
33
|
-
role: "category/agent-name" # 角色路径
|
|
34
|
-
task: "任务描述 {{变量}}" # 支持模板变量
|
|
35
|
-
output: variable_name # 输出变量名
|
|
36
|
-
depends_on: [other_step_id] # 依赖关系
|
|
37
|
-
```
|
|
38
|
-
|
|
39
|
-
**忽略 `llm`、`concurrency`、`timeout`、`retry` 配置**——Skill 模式使用当前会话的 LLM,这些字段仅用于 CLI 模式。
|
|
40
|
-
|
|
41
|
-
**定位角色目录**:用 Bash `test -d` 按以下顺序检查,用第一个存在的:
|
|
42
|
-
1. 当前工作目录下的 `{agents_dir}/`(如 `./agency-agents-zh/`)
|
|
43
|
-
2. `../{agents_dir}/`(上级目录)
|
|
44
|
-
3. 相对于 YAML 文件所在目录的 `{agents_dir}/`
|
|
45
|
-
4. `node_modules/agency-agents-zh/`
|
|
46
|
-
|
|
47
|
-
如果全部找不到,**停止执行**并提示用户:
|
|
48
|
-
```
|
|
49
|
-
找不到角色目录。请先安装:
|
|
50
|
-
git clone --depth 1 https://github.com/jnMetaCode/agency-agents-zh.git
|
|
51
|
-
或:npm install agency-agents-zh
|
|
52
|
-
```
|
|
53
|
-
|
|
54
|
-
### 第 2 步:收集输入
|
|
55
|
-
|
|
56
|
-
- 对每个 `required: true` 的输入,检查用户消息中是否已提供值
|
|
57
|
-
- 未提供的必填输入:**立即向用户询问**,不要猜测或用空值
|
|
58
|
-
- 有 `default` 的可选输入:使用默认值
|
|
59
|
-
- 无默认值的可选输入:设为空字符串
|
|
60
|
-
|
|
61
|
-
### 第 3 步:构建执行顺序
|
|
62
|
-
|
|
63
|
-
根据 `depends_on` 进行拓扑排序,将步骤分成多个层级:
|
|
64
|
-
|
|
65
|
-
- **无 depends_on 的步骤** → 第 1 层
|
|
66
|
-
- **depends_on 全部在第 N 层或之前的步骤** → 第 N+1 层
|
|
67
|
-
- **同一层内的步骤**互不依赖,可并行
|
|
68
|
-
|
|
69
|
-
在回复中展示执行计划:
|
|
70
|
-
```
|
|
71
|
-
执行计划(共 N 步):
|
|
72
|
-
第 1 层: [step_id] — 角色名
|
|
73
|
-
第 2 层: [step_a, step_b] — 并行
|
|
74
|
-
第 3 层: [step_id] — 角色名
|
|
75
|
-
```
|
|
76
|
-
|
|
77
|
-
### 第 4 步:逐层执行
|
|
78
|
-
|
|
79
|
-
对每一层:
|
|
80
|
-
|
|
81
|
-
#### 4a. 预读角色文件
|
|
82
|
-
|
|
83
|
-
用 Read 工具读取该层所有步骤的角色 `.md` 文件:`{角色目录}/{role}.md`
|
|
84
|
-
|
|
85
|
-
从文件中提取:
|
|
86
|
-
- **角色名**:frontmatter 中的 `name` 字段
|
|
87
|
-
- **角色 system prompt**:第二个 `---` 之后的全部 markdown 内容
|
|
88
|
-
|
|
89
|
-
#### 4b. 渲染 task 模板
|
|
90
|
-
|
|
91
|
-
将 task 中的 `{{变量名}}` 替换为:
|
|
92
|
-
- 来自 inputs 的用户输入值
|
|
93
|
-
- 来自前序步骤 output 的结果文本
|
|
94
|
-
|
|
95
|
-
#### 4c. 执行
|
|
96
|
-
|
|
97
|
-
**单步骤层**:直接在主会话中扮演该角色执行。格式:
|
|
98
|
-
|
|
99
|
-
```
|
|
100
|
-
### Step N/Total: step_id(角色名)
|
|
101
|
-
|
|
102
|
-
[以该角色身份完成 task,使用角色的专业知识和沟通风格]
|
|
103
|
-
```
|
|
104
|
-
|
|
105
|
-
**多步骤层(并行)**:使用 Agent 工具为每个步骤启动子代理。每个子代理的 prompt 必须包含:
|
|
106
|
-
- 角色文件的**完整文本内容**(不是路径——子代理可能无法读文件)
|
|
107
|
-
- 渲染后的 task 文本
|
|
108
|
-
- 指令:"以上是你的角色定义,请以该角色身份完成以下任务,直接输出结果"
|
|
109
|
-
|
|
110
|
-
#### 4d. 保存输出到上下文
|
|
111
|
-
|
|
112
|
-
如果 step 有 `output` 字段,将该步骤的输出文本存入变量上下文,供后续步骤的 `{{变量}}` 使用。
|
|
113
|
-
|
|
114
|
-
### 第 5 步:保存结果并展示
|
|
115
|
-
|
|
116
|
-
用 Write 工具将结果保存到文件:
|
|
117
|
-
|
|
118
|
-
```
|
|
119
|
-
.ao-output/{工作流名称}-{YYYY-MM-DD}/
|
|
120
|
-
├── steps/
|
|
121
|
-
│ ├── 1-{step_id}.md # 每步的输出
|
|
122
|
-
│ ├── 2-{step_id}.md
|
|
123
|
-
│ └── ...
|
|
124
|
-
├── summary.md # 最后一步的完整输出(最终成果)
|
|
125
|
-
└── metadata.json # 基本元数据
|
|
126
|
-
```
|
|
127
|
-
|
|
128
|
-
metadata.json 格式:
|
|
129
|
-
```json
|
|
130
|
-
{
|
|
131
|
-
"name": "工作流名称",
|
|
132
|
-
"date": "2026-03-22",
|
|
133
|
-
"success": true,
|
|
134
|
-
"steps": [
|
|
135
|
-
{"id": "step_id", "role": "category/agent", "status": "completed"},
|
|
136
|
-
...
|
|
137
|
-
]
|
|
138
|
-
}
|
|
139
|
-
```
|
|
140
|
-
|
|
141
|
-
执行完毕后,向用户展示:
|
|
142
|
-
1. 最终成果(summary.md 的内容)
|
|
143
|
-
2. 文件保存位置
|
|
144
|
-
3. 执行了几个步骤
|
|
145
|
-
|
|
146
|
-
## 重要规则
|
|
147
|
-
|
|
148
|
-
<HARD-GATE>
|
|
149
|
-
- 每个步骤都必须真正扮演对应角色,使用该角色的专业知识和沟通风格,不能泛泛回答
|
|
150
|
-
- 角色切换必须明确——每步开始时标注角色名
|
|
151
|
-
- 不要跳过步骤或合并步骤,严格按 DAG 层级顺序执行
|
|
152
|
-
- 如果角色文件找不到,告知用户并建议安装 agency-agents-zh
|
|
153
|
-
- 不要在没有读取角色 .md 文件的情况下执行步骤——必须先 Read 再执行
|
|
154
|
-
</HARD-GATE>
|
|
155
|
-
|
|
156
|
-
## 没有 YAML 文件时的快捷模式
|
|
157
|
-
|
|
158
|
-
如果用户没有指定 YAML 文件,但描述了需要多角色协作的任务:
|
|
159
|
-
|
|
160
|
-
1. 根据用户描述,**自动生成** YAML 工作流定义
|
|
161
|
-
2. 展示给用户确认
|
|
162
|
-
3. 确认后按上述流程执行
|
|
163
|
-
|
|
164
|
-
示例:
|
|
165
|
-
- 用户说"帮我用叙事学家和心理学家写个故事" → 生成 story-creation 类似的工作流
|
|
166
|
-
- 用户说"让产品经理和架构师评审这个 PRD" → 生成 product-review 类似的工作流
|
|
167
|
-
|
|
168
|
-
## 故障处理
|
|
169
|
-
|
|
170
|
-
- **角色文件不存在**:提示用户运行 `ao init` 或 `npm install agency-agents-zh`
|
|
171
|
-
- **模板变量未定义**:检查上下文,如果是必填输入则向用户询问
|
|
172
|
-
- **步骤执行失败**:标记该步骤为失败,跳过所有依赖它的下游步骤,继续执行其他独立步骤
|
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: writing-plans
|
|
3
|
-
description: 当你有规格说明或需求用于多步骤任务时使用,在动手写代码之前
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
# 编写计划
|
|
7
|
-
|
|
8
|
-
## 概述
|
|
9
|
-
|
|
10
|
-
编写全面的实现计划,假设工程师对我们的代码库零上下文,且品味存疑。记录他们需要知道的一切:每个任务要修改哪些文件、代码、测试、可能需要查阅的文档、如何测试。将整个计划拆成小步骤任务。DRY。YAGNI。TDD。频繁 commit。
|
|
11
|
-
|
|
12
|
-
假设他们是有经验的开发者,但对我们的工具链和问题领域几乎一无所知。假设他们不太擅长测试设计。
|
|
13
|
-
|
|
14
|
-
**开始时宣布:** "我正在使用 writing-plans 技能创建实现计划。"
|
|
15
|
-
|
|
16
|
-
**上下文:** 此技能应在专用 worktree 中运行(由 brainstorming 技能创建)。
|
|
17
|
-
|
|
18
|
-
**计划保存位置:** `docs/superpowers/plans/YYYY-MM-DD-<feature-name>.md`
|
|
19
|
-
- (用户对计划位置的偏好优先于此默认值)
|
|
20
|
-
|
|
21
|
-
## 范围检查
|
|
22
|
-
|
|
23
|
-
如果规格涵盖了多个独立子系统,它应该在头脑风暴阶段就被拆分为子项目规格。如果没有,建议将其拆分为独立的计划——每个子系统一个。每个计划应该能独立产出可工作、可测试的软件。
|
|
24
|
-
|
|
25
|
-
## 文件结构
|
|
26
|
-
|
|
27
|
-
在定义任务之前,先列出将要创建或修改的文件以及每个文件的职责。这是锁定分解决策的地方。
|
|
28
|
-
|
|
29
|
-
- 设计边界清晰、接口定义良好的单元。每个文件应有一个明确的职责。
|
|
30
|
-
- 你对能一次放入上下文的代码推理得最好,文件越专注你的编辑越可靠。优先选择小而专注的文件,而非承担过多功能的大文件。
|
|
31
|
-
- 一起变更的文件应放在一起。按职责拆分,而非按技术层级拆分。
|
|
32
|
-
- 在现有代码库中,遵循已有模式。如果代码库使用大文件,不要单方面重构——但如果你正在修改的文件已经变得难以管理,在计划中包含拆分是合理的。
|
|
33
|
-
|
|
34
|
-
此结构决定了任务分解。每个任务应产出独立的、有意义的变更。
|
|
35
|
-
|
|
36
|
-
## 小步骤任务粒度
|
|
37
|
-
|
|
38
|
-
**每步是一个操作(2-5 分钟):**
|
|
39
|
-
- "编写失败的测试" - 一步
|
|
40
|
-
- "运行它确认失败" - 一步
|
|
41
|
-
- "实现最少代码让测试通过" - 一步
|
|
42
|
-
- "运行测试确认通过" - 一步
|
|
43
|
-
- "Commit" - 一步
|
|
44
|
-
|
|
45
|
-
## 计划文档头部
|
|
46
|
-
|
|
47
|
-
**每个计划必须以此头部开始:**
|
|
48
|
-
|
|
49
|
-
```markdown
|
|
50
|
-
# [功能名称] 实现计划
|
|
51
|
-
|
|
52
|
-
> **面向 AI 代理的工作者:** 必需子技能:使用 superpowers:subagent-driven-development(推荐)或 superpowers:executing-plans 逐任务实现此计划。步骤使用复选框(`- [ ]`)语法来跟踪进度。
|
|
53
|
-
|
|
54
|
-
**目标:** [一句话描述要构建什么]
|
|
55
|
-
|
|
56
|
-
**架构:** [2-3 句话描述方案]
|
|
57
|
-
|
|
58
|
-
**技术栈:** [关键技术/库]
|
|
59
|
-
|
|
60
|
-
---
|
|
61
|
-
```
|
|
62
|
-
|
|
63
|
-
## 任务结构
|
|
64
|
-
|
|
65
|
-
````markdown
|
|
66
|
-
### 任务 N:[组件名称]
|
|
67
|
-
|
|
68
|
-
**文件:**
|
|
69
|
-
- 创建:`exact/path/to/file.py`
|
|
70
|
-
- 修改:`exact/path/to/existing.py:123-145`
|
|
71
|
-
- 测试:`tests/exact/path/to/test.py`
|
|
72
|
-
|
|
73
|
-
- [ ] **步骤 1:编写失败的测试**
|
|
74
|
-
|
|
75
|
-
```python
|
|
76
|
-
def test_specific_behavior():
|
|
77
|
-
result = function(input)
|
|
78
|
-
assert result == expected
|
|
79
|
-
```
|
|
80
|
-
|
|
81
|
-
- [ ] **步骤 2:运行测试验证失败**
|
|
82
|
-
|
|
83
|
-
运行:`pytest tests/path/test.py::test_name -v`
|
|
84
|
-
预期:FAIL,报错 "function not defined"
|
|
85
|
-
|
|
86
|
-
- [ ] **步骤 3:编写最少实现代码**
|
|
87
|
-
|
|
88
|
-
```python
|
|
89
|
-
def function(input):
|
|
90
|
-
return expected
|
|
91
|
-
```
|
|
92
|
-
|
|
93
|
-
- [ ] **步骤 4:运行测试验证通过**
|
|
94
|
-
|
|
95
|
-
运行:`pytest tests/path/test.py::test_name -v`
|
|
96
|
-
预期:PASS
|
|
97
|
-
|
|
98
|
-
- [ ] **步骤 5:Commit**
|
|
99
|
-
|
|
100
|
-
```bash
|
|
101
|
-
git add tests/path/test.py src/path/file.py
|
|
102
|
-
git commit -m "feat: add specific feature"
|
|
103
|
-
```
|
|
104
|
-
````
|
|
105
|
-
|
|
106
|
-
## 禁止占位符
|
|
107
|
-
|
|
108
|
-
每个步骤都必须包含工程师需要的实际内容。以下是**计划缺陷**——绝不要写出来:
|
|
109
|
-
- "待定"、"TODO"、"后续实现"、"补充细节"
|
|
110
|
-
- "添加适当的错误处理" / "添加验证" / "处理边界情况"
|
|
111
|
-
- "为上述代码编写测试"(没有实际测试代码)
|
|
112
|
-
- "类似任务 N"(重复代码——工程师可能不按顺序阅读任务)
|
|
113
|
-
- 只描述做什么而不展示怎么做的步骤(代码步骤必须有代码块)
|
|
114
|
-
- 引用了未在任何任务中定义的类型、函数或方法
|
|
115
|
-
|
|
116
|
-
## 注意事项
|
|
117
|
-
- 始终使用精确的文件路径
|
|
118
|
-
- 每个步骤都包含完整代码——如果步骤涉及代码变更,就展示代码
|
|
119
|
-
- 精确的命令和预期输出
|
|
120
|
-
- DRY、YAGNI、TDD、频繁 commit
|
|
121
|
-
|
|
122
|
-
## 自检
|
|
123
|
-
|
|
124
|
-
编写完整计划后,以全新视角审视规格并对照检查计划。这是你自己执行的检查清单——不是子代理调度。
|
|
125
|
-
|
|
126
|
-
**1. 规格覆盖度:** 浏览规格中的每个章节/需求。你能指出实现它的任务吗?列出所有遗漏。
|
|
127
|
-
|
|
128
|
-
**2. 占位符扫描:** 搜索计划中的红旗——上方"禁止占位符"章节中的任何模式。修复它们。
|
|
129
|
-
|
|
130
|
-
**3. 类型一致性:** 后续任务中使用的类型、方法签名和属性名是否与前面任务中定义的一致?任务 3 中叫 `clearLayers()` 但任务 7 中叫 `clearFullLayers()` 就是 bug。
|
|
131
|
-
|
|
132
|
-
如果发现问题,直接内联修复。无需重新审查——修好继续推进。如果发现规格中的需求没有对应任务,就添加任务。
|
|
133
|
-
|
|
134
|
-
## 执行交接
|
|
135
|
-
|
|
136
|
-
保存计划后,提供执行选项:
|
|
137
|
-
|
|
138
|
-
**"计划已完成并保存到 `docs/superpowers/plans/<filename>.md`。两种执行方式:**
|
|
139
|
-
|
|
140
|
-
**1. 子代理驱动(推荐)** - 每个任务调度一个新的子代理,任务间进行审查,快速迭代
|
|
141
|
-
|
|
142
|
-
**2. 内联执行** - 在当前会话中使用 executing-plans 执行任务,批量执行并设有检查点
|
|
143
|
-
|
|
144
|
-
**选哪种方式?"**
|
|
145
|
-
|
|
146
|
-
**如果选择子代理驱动:**
|
|
147
|
-
- **必需子技能:** 使用 superpowers:subagent-driven-development
|
|
148
|
-
- 每个任务一个新子代理 + 两阶段审查
|
|
149
|
-
|
|
150
|
-
**如果选择内联执行:**
|
|
151
|
-
- **必需子技能:** 使用 superpowers:executing-plans
|
|
152
|
-
- 批量执行并设有检查点供审查
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
# 计划文档审查员提示模板
|
|
2
|
-
|
|
3
|
-
调度计划文档审查员子代理时使用此模板。
|
|
4
|
-
|
|
5
|
-
**用途:** 验证计划是否完整、与规格匹配,并且任务分解合理。
|
|
6
|
-
|
|
7
|
-
**调度时机:** 完整计划编写完成后。
|
|
8
|
-
|
|
9
|
-
```
|
|
10
|
-
Task tool(通用):
|
|
11
|
-
description: "审查计划文档"
|
|
12
|
-
prompt: |
|
|
13
|
-
你是一名计划文档审查员。验证此计划是否完整并准备好进行实现。
|
|
14
|
-
|
|
15
|
-
**待审查计划:** [PLAN_FILE_PATH]
|
|
16
|
-
**参考规格:** [SPEC_FILE_PATH]
|
|
17
|
-
|
|
18
|
-
## 检查内容
|
|
19
|
-
|
|
20
|
-
| 类别 | 检查要点 |
|
|
21
|
-
|------|----------|
|
|
22
|
-
| 完整性 | TODO、占位符、不完整的任务、缺失的步骤 |
|
|
23
|
-
| 规格对齐 | 计划覆盖了规格需求,没有重大范围蔓延 |
|
|
24
|
-
| 任务分解 | 任务有清晰的边界,步骤可执行 |
|
|
25
|
-
| 可构建性 | 工程师能否按此计划执行而不会卡住? |
|
|
26
|
-
|
|
27
|
-
## 校准标准
|
|
28
|
-
|
|
29
|
-
**只标记会在实现阶段造成实际问题的事项。**
|
|
30
|
-
实现者构建了错误的东西或卡住了——这是问题。
|
|
31
|
-
措辞上的小改进、风格偏好和"锦上添花"的建议则不是。
|
|
32
|
-
|
|
33
|
-
除非存在严重缺陷——规格中的需求遗漏、
|
|
34
|
-
矛盾的步骤、占位内容、或者模糊到无法执行的任务——否则应予以通过。
|
|
35
|
-
|
|
36
|
-
## 输出格式
|
|
37
|
-
|
|
38
|
-
## 计划审查
|
|
39
|
-
|
|
40
|
-
**状态:** 通过 | 发现问题
|
|
41
|
-
|
|
42
|
-
**问题(如有):**
|
|
43
|
-
- [任务 X,步骤 Y]:[具体问题] - [为什么这对实现很重要]
|
|
44
|
-
|
|
45
|
-
**建议(仅供参考,不阻止通过):**
|
|
46
|
-
- [改进建议]
|
|
47
|
-
```
|
|
48
|
-
|
|
49
|
-
**审查员返回:** 状态、问题(如有)、建议
|