super-engineer-workflow 0.1.0

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.
Files changed (53) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/CONTRIBUTING.md +34 -0
  3. package/LICENSE +21 -0
  4. package/README.md +300 -0
  5. package/SECURITY.md +21 -0
  6. package/bin/super-engineer.js +19 -0
  7. package/docs/se/345/221/275/344/273/244/345/215/217/350/256/256.md +335 -0
  8. package/docs//344/270/255/346/226/207/344/275/277/347/224/250/346/211/213/345/206/214.md +707 -0
  9. package/docs//345/205/254/345/274/200/345/217/221/345/270/203/346/243/200/346/237/245/346/270/205/345/215/225.md +43 -0
  10. package/docs//345/277/253/351/200/237/345/210/235/345/247/213/345/214/226/345/267/245/344/275/234/345/214/272.md +419 -0
  11. package/docs//351/241/271/347/233/256/346/236/266/346/236/204/344/270/216/350/256/276/350/256/241/350/257/264/346/230/216.md +657 -0
  12. package/package.json +55 -0
  13. package/scripts/se-cli.py +301 -0
  14. package/scripts/se-setup.py +331 -0
  15. package/scripts/se-smoke-test.py +86 -0
  16. package/super-engineer-workflow/SKILL.md +439 -0
  17. package/super-engineer-workflow/adapters/go.yml +8 -0
  18. package/super-engineer-workflow/adapters/java-gradle.yml +8 -0
  19. package/super-engineer-workflow/adapters/java-maven.yml +8 -0
  20. package/super-engineer-workflow/adapters/node-react.yml +8 -0
  21. package/super-engineer-workflow/adapters/node-vue.yml +8 -0
  22. package/super-engineer-workflow/adapters/python.yml +8 -0
  23. package/super-engineer-workflow/agents/openai.yaml +4 -0
  24. package/super-engineer-workflow/assets/config-schema.json +100 -0
  25. package/super-engineer-workflow/assets/config.example.yml +12 -0
  26. package/super-engineer-workflow/assets/plan-schema.json +362 -0
  27. package/super-engineer-workflow/assets/status-schema.json +83 -0
  28. package/super-engineer-workflow/assets/workspace.example.yml +25 -0
  29. package/super-engineer-workflow/config.example.yml +12 -0
  30. package/super-engineer-workflow/references/contracts.md +39 -0
  31. package/super-engineer-workflow/references/execution-modes.md +38 -0
  32. package/super-engineer-workflow/references/java.md +21 -0
  33. package/super-engineer-workflow/references/planning.md +45 -0
  34. package/super-engineer-workflow/references/platform-openclaw.md +10 -0
  35. package/super-engineer-workflow/references/project-docs.md +7 -0
  36. package/super-engineer-workflow/references/review-checklist.md +26 -0
  37. package/super-engineer-workflow/references/se-commands.md +582 -0
  38. package/super-engineer-workflow/references/verify-checklist.md +45 -0
  39. package/super-engineer-workflow/references/workflow.md +208 -0
  40. package/super-engineer-workflow/scripts/archive-openspec.py +110 -0
  41. package/super-engineer-workflow/scripts/bootstrap-openspec.py +42 -0
  42. package/super-engineer-workflow/scripts/common.py +3285 -0
  43. package/super-engineer-workflow/scripts/generate-discovery.py +185 -0
  44. package/super-engineer-workflow/scripts/generate-review-report.py +296 -0
  45. package/super-engineer-workflow/scripts/generate-self-check.py +185 -0
  46. package/super-engineer-workflow/scripts/generate-smart-plan.py +429 -0
  47. package/super-engineer-workflow/scripts/init-workspace.py +68 -0
  48. package/super-engineer-workflow/scripts/prepare-archive-openspec.py +186 -0
  49. package/super-engineer-workflow/scripts/propose-openspec.py +170 -0
  50. package/super-engineer-workflow/scripts/run-verify-and-report.py +399 -0
  51. package/super-engineer-workflow/scripts/run-workflow.py +506 -0
  52. package/super-engineer-workflow/scripts/update-status.py +43 -0
  53. package/super-engineer-workflow/scripts/writeback-openspec.py +311 -0
@@ -0,0 +1,707 @@
1
+ # super-engineer 中文使用手册
2
+
3
+ 这份手册只做一件事:用一个真实需求,说明工作流怎么开始、怎么推进、用户该怎么向 AI 发指令。
4
+
5
+ 示例需求:
6
+
7
+ > 经销商用户列表接口增加手机号精确筛选,要求兼容旧查询行为,并补齐 controller / service 层测试。
8
+
9
+ 这份手册按下面顺序组织:
10
+
11
+ 1. 工作空间结构
12
+ 2. `todo` 模式配置结构
13
+ 3. `todo` 模式 `auto` 怎么使用
14
+ 4. `todo` 模式 `manual` 怎么使用
15
+ 5. `openspec` 模式 `auto` 怎么使用
16
+ 6. `openspec` 模式 `manual` 怎么使用
17
+
18
+ ## 1. 前置条件
19
+
20
+ 需要满足:
21
+
22
+ - 本地已经安装好 `super-engineer-workflow`
23
+ - 目标代码仓库已经在本地
24
+ - 本地可用 `python3`
25
+ - 已存在 `~/.super-engineer/skill-config.yml`
26
+
27
+ 如果 `~/.super-engineer/skill-config.yml` 不存在,第一次初始化时会自动生成模板,并暂停流程,等你补全。
28
+
29
+ ## 2. 真实例子
30
+
31
+ 整个手册都使用同一个需求:
32
+
33
+ > 经销商用户列表接口增加手机号精确筛选,要求兼容旧查询行为,并补齐 controller / service 层测试。
34
+
35
+ 把它拆成可交付目标,就是:
36
+
37
+ - 修改 `item-user-service`
38
+ - 用户列表接口支持手机号精确筛选
39
+ - `phone` 为空时保持原有查询行为
40
+ - 补齐 controller 测试
41
+ - 补齐 service 测试
42
+
43
+ ## 3. 工作空间结构
44
+
45
+ ### 3.1 `todo` 模式
46
+
47
+ ```text
48
+ your-workspace/
49
+ ├── workspace.yml
50
+ ├── todo.md
51
+ └── output/
52
+
53
+ your-project/
54
+ ├── docs/
55
+ ├── item-user-service/
56
+ └── ...
57
+ ```
58
+
59
+ 这里的职责分工是:
60
+
61
+ - `workspace.yml`:声明当前工作流配置
62
+ - `todo.md`:交付阶段的真实输入
63
+ - `output/`:输出给人看的报告
64
+ - `your-project/`:实际代码目录
65
+
66
+ ### 3.2 `openspec` 模式
67
+
68
+ ```text
69
+ your-workspace/
70
+ ├── workspace.yml
71
+ └── output/
72
+
73
+ your-spec-repo/
74
+ └── openspec/
75
+ ├── specs/
76
+ └── changes/
77
+ └── add-user-phone-filter/
78
+ ├── proposal.md
79
+ ├── design.md
80
+ ├── tasks.md
81
+ └── specs/
82
+
83
+ your-project/
84
+ ├── docs/
85
+ ├── item-user-service/
86
+ └── ...
87
+ ```
88
+
89
+ 这里的职责分工是:
90
+
91
+ - OpenSpec change:规格阶段输入
92
+ - 桥接 todo:桥接后的交付输入
93
+ - `your-project/`:实际代码目录
94
+
95
+ 桥接 todo 的实际文件路径由 `workspace.yml.todo_file` 决定。为了兼容既有 skill 习惯,推荐在需求目录中继续使用 `todo.md`。
96
+
97
+ ## 4. `todo` 模式配置结构
98
+
99
+ ### 4.1 `workspace.yml`
100
+
101
+ `manual` 版本:
102
+
103
+ ```yaml
104
+ version: 1
105
+ mode: manual
106
+ workflow_source: todo
107
+ demand_file: ${demand_name}/需求.md
108
+ todo_file: ${demand_name}/todo.md
109
+ reference_files:
110
+ - ../docs/需求分析与实现指南.md
111
+ code_path: ../../../code
112
+ output_dir: ${demand_name}/output
113
+ ```
114
+
115
+ `auto` 版本只改一处:
116
+
117
+ ```yaml
118
+ mode: auto
119
+ ```
120
+
121
+ 如果同一个工作空间经常切换需求,可以用 `vars` 统一维护需求名:
122
+
123
+ ```yaml
124
+ vars:
125
+ demand_name: 7-deamnd-addition-rate
126
+ ```
127
+
128
+ 然后路径里使用 `${demand_name}` 或 `${vars.demand_name}`。相对路径会按当前打开的工作空间根目录解析。
129
+ OpenSpec change 名称不会从 `demand_name` 推导,必须在 `/se:propose <change-name>` 中显式指定。
130
+
131
+ 如果当前项目不是 Java,或者自动识别出的验证命令不符合团队要求,可以在 `workspace.yml` 中显式配置验证命令:
132
+
133
+ ```yaml
134
+ verify_commands:
135
+ default: pnpm test && pnpm build
136
+ frontend-app: pnpm test && pnpm build
137
+ user-service: go test ./...
138
+ python-service: python -m pytest
139
+ ```
140
+
141
+ key 可以写 `default`、目标仓库目录名或目标仓库绝对路径。工作流会优先使用这个配置,而不是自动推断命令。
142
+
143
+ ### 4.2 `todo.md`
144
+
145
+ ```md
146
+ # 限制条件
147
+ - 修改的服务是 item-user-service
148
+ - 需要兼容旧的查询参数行为
149
+
150
+ # 待办事项
151
+
152
+ ## 用户列表
153
+ - [ ] 用户列表接口增加手机号精确筛选
154
+ 1. 仅支持管理员角色使用
155
+ 2. 前端为空时不传该参数
156
+ 3. 后端需要兼容旧参数
157
+
158
+ ## 测试
159
+ - [ ] 补齐 controller 和 service 层测试
160
+ ```
161
+
162
+ ## 5. `todo` 模式 `auto` 怎么使用
163
+
164
+ `todo + auto` 的含义是:
165
+
166
+ - 用户已经准备好 `todo.md`
167
+ - AI 不在计划、实现、审查之间反复停下来
168
+ - 只要没有硬阻塞,就连续推进到验证阶段
169
+
170
+ 推荐起手提示词:
171
+
172
+ ```text
173
+ /se:apply
174
+ 使用当前工作空间。
175
+ 需求是:经销商用户列表接口增加手机号精确筛选,要求兼容旧查询行为,并补齐 controller / service 层测试。
176
+ 当前模式是 todo + auto。
177
+ 如果 workspace 未初始化,先初始化。
178
+ 如果没有硬阻塞,自动推进到实现、自查、审查和验证。
179
+ 最后只向我汇报:
180
+ 1. 改了哪些仓库和文件
181
+ 2. review gate 结果
182
+ 3. verify 结果
183
+ 4. residual risks
184
+ ```
185
+
186
+ 更稳一点的两步法:
187
+
188
+ 第一步先看计划:
189
+
190
+ ```text
191
+ /se:plan
192
+ 使用当前工作空间。
193
+ 基于 todo.md 生成本轮计划。
194
+ 先不要改代码,只总结目标仓库、影响范围、验收标准和主要风险。
195
+ ```
196
+
197
+ 第二步确认后再直接推进:
198
+
199
+ ```text
200
+ /se:apply
201
+ 继续当前工作空间。
202
+ 按当前计划自动推进到实现、自查、审查和验证。
203
+ 如果没有硬阻塞,不要中途停下。
204
+ ```
205
+
206
+ 适用场景:
207
+
208
+ - 需求局部
209
+ - 目标服务明确
210
+ - 用户更关心交付速度
211
+
212
+ ## 6. `todo` 模式 `manual` 怎么使用
213
+
214
+ `todo + manual` 的含义是:
215
+
216
+ - 用户已经准备好 `todo.md`
217
+ - AI 每到关键门禁先停下来汇报
218
+ - 适合高风险修改或你想逐步确认的场景
219
+
220
+ 推荐操作顺序:
221
+
222
+ ### 第一步:初始化并生成计划
223
+
224
+ ```text
225
+ /se:plan
226
+ 使用当前工作空间。
227
+ 当前模式是 todo + manual。
228
+ 先完成初始化和计划生成,不要开始改代码。
229
+ 告诉我目标仓库、影响范围、验收标准和主要风险。
230
+ ```
231
+
232
+ ### 第二步:确认后开始实现
233
+
234
+ ```text
235
+ /se:apply
236
+ 继续当前工作空间。
237
+ 当前计划已确认,可以开始实现。
238
+ 实现完成后先停在自查结果,不要直接进入后续阶段。
239
+ ```
240
+
241
+ ### 第三步:让 AI 做代码审查
242
+
243
+ ```text
244
+ /se:review
245
+ 继续当前工作空间。
246
+ 对当前改动做代码审查。
247
+ 只告诉我 gate 结果、blocking findings、warning findings 和测试覆盖风险。
248
+ ```
249
+
250
+ ### 第四步:让 AI 做验证
251
+
252
+ ```text
253
+ /se:verify
254
+ 继续当前工作空间。
255
+ 执行验证,并告诉我 workflow 是 done 还是 blocked。
256
+ ```
257
+
258
+ 适用场景:
259
+
260
+ - 涉及共享模块
261
+ - 需要逐步确认修改范围
262
+ - 你希望在 review 前先人工看一遍
263
+
264
+ ## 7. `openspec` 模式 `auto` 怎么使用
265
+
266
+ `openspec + auto` 应该分成三个阶段理解:
267
+
268
+ 1. 规格阶段
269
+ 2. 交付阶段
270
+ 3. 归档阶段
271
+
272
+ 这里最重要的一点是:
273
+ 不要直接从自动实现开始。应该先从 OpenSpec change 开始,产出 `tasks.md`,再桥接成 `workspace.yml.todo_file` 指向的 `todo.md`,审核通过后再进入自动交付。
274
+
275
+ ### 7.1 `workspace.yml`
276
+
277
+ ```yaml
278
+ version: 1
279
+ mode: auto
280
+ workflow_source: openspec
281
+ vars:
282
+ demand_name: add-user-phone-filter
283
+ demand_file: superengineer/${demand_name}/需求.md
284
+ todo_file: superengineer/${demand_name}/todo.md
285
+ reference_files: []
286
+ code_path: ../../../code
287
+ output_dir: superengineer/${demand_name}/output
288
+ openspec:
289
+ changes_dir: ../openspec/changes
290
+ ```
291
+
292
+ `demand_file` 也可以直接配置飞书/Lark 云文档 URL。云文档由官方 `lark-cli` 读取并转换为 Markdown;首次使用前需要安装并授权:
293
+
294
+ ```bash
295
+ npx @larksuite/cli@latest install
296
+ lark-cli config init --new
297
+ lark-cli auth login --recommend
298
+ ```
299
+
300
+ ### 7.2 OpenSpec change 示例
301
+
302
+ `proposal.md`
303
+
304
+ ```md
305
+ # Proposal
306
+
307
+ ## Background
308
+ 客服需要通过手机号精确定位经销商用户。
309
+
310
+ ## Scope
311
+ - 经销商用户列表接口
312
+ - controller / service / query 链路
313
+ - 对应测试
314
+ ```
315
+
316
+ `design.md`
317
+
318
+ ```md
319
+ # Design
320
+
321
+ ## Compatibility
322
+ - 当 `phone` 为空时,保持旧查询行为不变
323
+ - 不涉及数据库 schema 变更
324
+ ```
325
+
326
+ `tasks.md`
327
+
328
+ ```md
329
+ # Tasks
330
+
331
+ ## API
332
+ - [ ] 为经销商用户列表接口增加手机号精确筛选
333
+ - [ ] 当 phone 为空时保持旧行为
334
+
335
+ ## Testing
336
+ - [ ] 补充 controller 测试
337
+ - [ ] 补充 service 测试
338
+ ```
339
+
340
+ ### 7.3 阶段一:先产出 OpenSpec change
341
+
342
+ ```text
343
+ /se:propose add-user-phone-filter
344
+ 请根据当前 workspace 的 demand_file 生成或完善 OpenSpec change。
345
+ ```
346
+
347
+ ### 7.4 阶段二:桥接为交付 todo
348
+
349
+ ```text
350
+ /se:bridge
351
+ 针对当前 OpenSpec change 生成桥接 todo。
352
+ 请把 tasks.md 转成交付阶段可执行的 todo,并总结:
353
+ 1. 哪些任务会进入本轮交付
354
+ 2. 哪些约束需要在实现时严格遵守
355
+ 3. 有没有描述不清的地方
356
+ ```
357
+
358
+ ### 7.5 阶段三:审核桥接 todo
359
+
360
+ 这一步是人审,不建议跳过。
361
+
362
+ 如果审核时发现桥接 todo 和实际业务有偏差,不要进入 `/se:apply`。先判断偏差来自哪里。
363
+
364
+ 如果只是桥接表达不准确,例如 `tasks.md` 没问题,但 `todo.md` 拆分不合理、遗漏实现约束或描述不清,可以先修正 `todo.md`,然后让 AI 重新整理:
365
+
366
+ ```text
367
+ /se:bridge
368
+ 当前桥接 todo 和业务理解有偏差,我已补充或修正。
369
+ 请基于当前 OpenSpec change 和 todo.md 重新整理交付 todo,并列出变化点。
370
+ ```
371
+
372
+ 如果 OpenSpec change 本身就有偏差,例如 `proposal.md`、`design.md` 或 `tasks.md` 对需求理解错误、遗漏业务规则,应回到规格阶段修正当前 change:
373
+
374
+ ```text
375
+ /se:propose add-user-phone-filter
376
+ 当前 OpenSpec change 对业务理解有偏差:
377
+ 补充说明:这里写清楚偏差和正确业务规则。
378
+
379
+ 请修正当前 change,不要创建新的 change。
380
+ 先不要改代码。
381
+ ```
382
+
383
+ 然后重新桥接:
384
+
385
+ ```text
386
+ /se:bridge
387
+ 针对修正后的 OpenSpec change 重新生成桥接 todo,并列出变化点和待审核项。
388
+ ```
389
+
390
+ 如果原始需求本身不完整,先补充 `demand_file` 或在提示词中说明补充信息,再重新执行 `/se:propose` 修正当前 change。
391
+
392
+ 判断规则:
393
+
394
+ ```text
395
+ todo 偏差来自交付拆解 -> 重新 bridge
396
+ todo 偏差来自规格理解 -> 重新 propose
397
+ todo 偏差来自需求缺失 -> 补需求后重新 propose
398
+ ```
399
+
400
+ ### 7.6 阶段四:启动自动交付
401
+
402
+ ```text
403
+ /se:apply
404
+ 使用当前工作空间。
405
+ 当前模式是 openspec + auto。
406
+ 当前桥接 todo 已审核通过。
407
+ 如果没有硬阻塞,自动推进到实现、自查、审查和验证。
408
+ verify 通过后继续检查归档条件;如果结果为 safe_merge,状态进入 archive_ready,下一步再执行 /se:archive。
409
+ ```
410
+
411
+ 适用场景:
412
+
413
+ - 需求已经先在 OpenSpec 里沉淀
414
+ - 你希望交付前先审核执行清单
415
+ - 你希望 verify 后自动进入归档检查
416
+
417
+ ## 8. `openspec` 模式 `manual` 怎么使用
418
+
419
+ `openspec + manual` 和 `openspec + auto` 的差异不在前半段。
420
+ 两者都应该先走:
421
+
422
+ 1. `/se:propose <change-name>`
423
+ 2. `/se:bridge`
424
+ 3. 人工审核桥接 todo
425
+ 4. `/se:apply`
426
+
427
+ 差异在交付阶段:
428
+
429
+ - `auto`:审核通过后连续推进
430
+ - `manual`:审核通过后仍按计划、实现、审查、验证分段停留
431
+
432
+ ### 第一步:规格阶段
433
+
434
+ ```text
435
+ /se:propose add-user-phone-filter
436
+ 请根据当前 workspace 的 demand_file 生成或完善 OpenSpec change。
437
+ ```
438
+
439
+ ### 第二步:桥接阶段
440
+
441
+ ```text
442
+ /se:bridge
443
+ 针对当前 OpenSpec change 生成桥接 todo,并列出待审核项。
444
+ ```
445
+
446
+ ### 第四步:先只生成计划
447
+
448
+ ```text
449
+ /se:plan
450
+ 使用当前工作空间。
451
+ 当前模式是 openspec + manual。
452
+ 当前桥接 todo 已审核通过,基于已审核的桥接 todo 生成计划。
453
+ 先不要改代码,只总结目标仓库、影响范围、验收标准和主要风险。
454
+ ```
455
+
456
+ ### 第五步:确认后进入实现
457
+
458
+ ```text
459
+ /se:apply
460
+ 继续当前工作空间。
461
+ 当前计划已确认,可以开始实现。
462
+ 实现完成后先停在自查结果。
463
+ ```
464
+
465
+ ### 第六步:继续代码审查
466
+
467
+ ```text
468
+ /se:review
469
+ 继续当前工作空间。
470
+ 对当前改动做审查,并确认 execution-summary 已回写。
471
+ ```
472
+
473
+ ### 第七步:继续验证
474
+
475
+ ```text
476
+ /se:verify
477
+ 继续当前工作空间。
478
+ 执行验证,并告诉我 workflow 是 done 还是 blocked。
479
+ ```
480
+
481
+ ### 第八步:检查归档条件
482
+
483
+ ```text
484
+ /se:archive-check
485
+ 继续当前工作空间。
486
+ 检查当前 OpenSpec change 是否满足归档条件。
487
+ 告诉我 archive_ready、merge_mode、blockers 和 spec_conflicts。
488
+ ```
489
+
490
+ ### 第九步:确认后归档
491
+
492
+ ```text
493
+ /se:archive
494
+ 仅在 archive_ready=true、merge_mode=safe_merge、spec_conflicts 为空时执行归档。
495
+ 归档后告诉我同步了哪些 spec,以及 change 被归档到了哪里。
496
+ ```
497
+
498
+ 适用场景:
499
+
500
+ - 变更范围大
501
+ - 需要明确的人工门禁
502
+ - 希望规格、交付、归档三阶段都保留确认点
503
+
504
+ ## 9. 跑完后发现遗漏怎么办
505
+
506
+ 当前工作流不是一次性的。每次 `plan` 会创建一个新的 session,但同一个 session 在完成前可以继续返工。
507
+
508
+ ### 9.1 还没验证通过
509
+
510
+ 如果遗漏是在当前 session 的自查、审查或验证阶段发现的,推荐继续当前 session,不要重新开新计划。
511
+
512
+ 适用情况:
513
+
514
+ - self-check 发现实现遗漏
515
+ - review 发现 blocking finding
516
+ - verify 失败
517
+ - 你人工检查后发现当前实现不完整
518
+
519
+ 推荐提示词:
520
+
521
+ ```text
522
+ /se:apply
523
+ 继续当前工作空间。
524
+ 基于当前 session 的 self-check、review 或 verify 结果修复遗漏。
525
+ 不要重新生成新计划,除非当前计划确实需要补充。
526
+ 修复后重新执行必要的自查、审查和验证。
527
+ ```
528
+
529
+ 如果遗漏明确来自 review:
530
+
531
+ ```text
532
+ /se:apply
533
+ 继续当前工作空间。
534
+ 根据当前 review 的 blocking findings 修复代码。
535
+ 修复后重新执行 review 和 verify。
536
+ ```
537
+
538
+ 如果遗漏明确来自 verify:
539
+
540
+ ```text
541
+ /se:apply
542
+ 继续当前工作空间。
543
+ 根据当前 verify 失败原因修复代码。
544
+ 修复后重新执行 verify。
545
+ 如果修复影响核心实现逻辑,也重新执行 review。
546
+ ```
547
+
548
+ ### 9.2 已经验证通过,但还没归档
549
+
550
+ 如果 workflow 已经 `done`,但 OpenSpec change 还没有归档,可以补当前 change,然后重新桥接、审核和交付。
551
+
552
+ 推荐提示词:
553
+
554
+ ```text
555
+ /se:propose add-user-phone-filter
556
+ 当前 OpenSpec change 验证通过后发现遗漏:
557
+ 手机号筛选需要同时兼容脱敏手机号字段,否则部分历史用户无法被查到。
558
+ 请补充当前 OpenSpec change,不要创建新的 change。
559
+ ```
560
+
561
+ 然后重新桥接:
562
+
563
+ ```text
564
+ /se:bridge
565
+ 针对更新后的 OpenSpec change 重新生成桥接 todo,并列出新增或变化的待审核项。
566
+ ```
567
+
568
+ 审核后:
569
+
570
+ ```text
571
+ /se:apply
572
+ 我已审核更新后的桥接 todo,可以继续交付遗漏修复。
573
+ 继续当前工作空间。
574
+ 按已审核的桥接 todo 修复遗漏,并完成自查、审查和验证。
575
+ ```
576
+
577
+ ### 9.3 已经归档
578
+
579
+ 如果 OpenSpec change 已经归档,不建议再改旧 change。应该创建 follow-up change 或新一轮 todo。
580
+
581
+ OpenSpec 模式推荐提示词:
582
+
583
+ ```text
584
+ /se:propose add-user-phone-filter-follow-up
585
+ 已归档需求发现后续遗漏:
586
+ 手机号筛选需要同时兼容脱敏手机号字段,否则部分历史用户无法被查到。
587
+ 请创建一个 follow-up change。
588
+ ```
589
+
590
+ todo 模式推荐提示词:
591
+
592
+ ```text
593
+ /se:plan
594
+ 使用当前工作空间。
595
+ 基于新增遗漏点创建新一轮交付计划。
596
+ 遗漏点是:手机号筛选需要同时兼容脱敏手机号字段,否则部分历史用户无法被查到。
597
+ 先不要改代码,只总结影响范围、验收标准和风险。
598
+ ```
599
+
600
+ ### 9.4 判断规则
601
+
602
+ 简单判断:
603
+
604
+ - 还没 `verify done`:继续当前 session 修
605
+ - 已经 `verify done`,但还没归档:补当前 OpenSpec change,再重新 `/se:bridge`,人工审核 todo 后执行 `/se:apply`
606
+ - 已经归档:创建 follow-up change 或新一轮 todo
607
+ - 只是实现 bug,不改变需求:优先继续当前 session,已 done 则新开一轮
608
+ - 改变验收标准或需求范围:新一轮计划,OpenSpec 模式下更新或新建 change
609
+
610
+ ## 10. `/se:*` 命令速查表
611
+
612
+ 这一节用于快速查阅命令顺序。`/se:*` 是发给 AI 的工作流指令,不是 shell 命令。
613
+
614
+ ### 10.1 OpenSpec 模式推荐顺序
615
+
616
+ ```text
617
+ /se:init
618
+ -> /se:propose <change-name>
619
+ -> /se:bridge
620
+ -> 人工审核 todo.md
621
+ -> /se:plan 可选
622
+ -> /se:apply
623
+ -> /se:archive-check
624
+ -> /se:archive 满足 safe_merge 时
625
+ ```
626
+
627
+ | 顺序 | 命令 | 作用 | 完成后允许的下一步 |
628
+ | --- | --- | --- | --- |
629
+ | 1 | `/se:init` | 初始化工作空间,检查配置、目录和输入 | `/se:propose <change-name>` |
630
+ | 2 | `/se:propose <change-name>` | 生成或完善指定 OpenSpec change,只处理规格,不改代码 | `/se:bridge` |
631
+ | 3 | `/se:bridge` | 把 OpenSpec `tasks.md` 桥接成 `todo.md` | 人工审核 todo.md 后 `/se:apply` |
632
+ | 4 | `/se:plan` | 生成交付计划,不改代码 | `/se:apply` |
633
+ | 5 | `/se:apply` | 进入实现、自查、审查、验证 | `/se:archive-check` |
634
+ | 6 | `/se:review` | 单独执行或重跑代码审查 | `/se:verify` 或 `/se:apply` 修复 |
635
+ | 7 | `/se:verify` | 单独执行或重跑验证 | 通过后 `/se:archive-check` |
636
+ | 8 | `/se:archive-check` | 检查是否满足 OpenSpec 归档条件 | 满足 safe_merge 后 `/se:archive` |
637
+ | 9 | `/se:archive` | 执行 OpenSpec 归档 | 结束 |
638
+ | - | `/se:status` | 查看当前工作流状态 | 按状态提示下一步 |
639
+
640
+ 关键门禁:
641
+
642
+ - `/se:propose` 后不能直接 `/se:apply`
643
+ - `/se:bridge` 后必须先人工审核 todo.md
644
+ - 人工审核 todo.md 后直接用 `/se:apply` 进入交付
645
+ - `/se:apply` 之前必须已经完成 `/se:bridge` 并审核 todo.md
646
+ - `/se:archive` 之前必须先 `/se:archive-check`
647
+ - 飞书通知必须通过 `/se:verify` 的标准模板发送,不能让 AI 手工拼 webhook
648
+
649
+ OpenSpec 模式下还有脚本状态机:
650
+
651
+ ```text
652
+ .super-engineer/se-state.json
653
+ ```
654
+
655
+ 脚本会记录 `phase` 和 `allowed_next`。例如 `/se:propose` 后 `phase=proposed`,只允许 `/se:bridge`;如果此时直接执行 `/se:apply`,脚本会拒绝。
656
+
657
+ ### 10.2 todo 模式推荐顺序
658
+
659
+ ```text
660
+ /se:init
661
+ -> /se:plan
662
+ -> /se:apply
663
+ -> /se:review
664
+ -> /se:verify
665
+ ```
666
+
667
+ | 顺序 | 命令 | 作用 |
668
+ | --- | --- | --- |
669
+ | 1 | `/se:init` | 初始化工作空间,检查 `workspace.yml` 和 `todo.md` |
670
+ | 2 | `/se:plan` | 基于 `todo.md` 生成计划,不改代码 |
671
+ | 3 | `/se:apply` | 按计划实现、自查、审查和验证 |
672
+ | 4 | `/se:review` | 单独执行或重跑审查 |
673
+ | 5 | `/se:verify` | 单独执行或重跑验证 |
674
+ | - | `/se:status` | 查看当前状态 |
675
+
676
+ `todo + auto` 可以从 `/se:apply` 开始,但前提是 `workspace.yml` 和 `todo.md` 都有效。
677
+
678
+ ### 10.3 最常用的几条命令
679
+
680
+ 如果你不想记全部命令,先记这几条就够了:
681
+
682
+ - `/se:propose <change-name>`:生成或完善指定 OpenSpec change
683
+ - `/se:bridge`:把 `tasks.md` 转成桥接 todo
684
+ - `/se:plan`:只做计划
685
+ - `/se:apply`:进入交付
686
+ - `/se:archive-check`:检查是否满足归档条件
687
+ - `/se:archive`:执行归档
688
+
689
+ 如果 AI 收到 `/se:*` 后没有进入工作流,而是回复“在吗”“有什么可以帮你”这类普通聊天内容,说明当前模型没有加载 `super-engineer-workflow` skill,或者没有识别 `/se:*` 协议。处理方式:
690
+
691
+ ```text
692
+ 请使用 super-engineer-workflow skill 处理下面的 /se:* 工作流命令。
693
+
694
+ /se:propose demand-addition-rate
695
+
696
+ 使用当前工作空间:
697
+ /Users/muke/Documents/work/desmart/project/ai-workspace
698
+
699
+ 请根据当前 workspace 的 demand_file 生成或完善 OpenSpec change。
700
+ 先不要改代码。
701
+ ```
702
+
703
+ 如果仍然没有触发,需要确认当前 AI 客户端已经安装并启用了 `super-engineer-workflow` skill。
704
+
705
+ 完整命令说明见:
706
+
707
+ - [se命令协议.md](/Users/muke/Documents/personal/codex/super-engineer/docs/se命令协议.md)