sillyspec 3.8.5 → 3.8.7

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 (163) hide show
  1. package/README.md +0 -6
  2. package/docs/.vitepress/config.mts +45 -0
  3. package/docs/.vitepress/dist/404.html +25 -0
  4. package/docs/.vitepress/dist/assets/app.YytxICdd.js +1 -0
  5. package/docs/.vitepress/dist/assets/chunks/framework.Czhw_PXq.js +19 -0
  6. package/docs/.vitepress/dist/assets/chunks/theme.DusTRZQk.js +1 -0
  7. package/docs/.vitepress/dist/assets/index.md.C3VCvtQA.js +1 -0
  8. package/docs/.vitepress/dist/assets/index.md.C3VCvtQA.lean.js +1 -0
  9. package/docs/.vitepress/dist/assets/inter-italic-cyrillic-ext.r48I6akx.woff2 +0 -0
  10. package/docs/.vitepress/dist/assets/inter-italic-cyrillic.By2_1cv3.woff2 +0 -0
  11. package/docs/.vitepress/dist/assets/inter-italic-greek-ext.1u6EdAuj.woff2 +0 -0
  12. package/docs/.vitepress/dist/assets/inter-italic-greek.DJ8dCoTZ.woff2 +0 -0
  13. package/docs/.vitepress/dist/assets/inter-italic-latin-ext.CN1xVJS-.woff2 +0 -0
  14. package/docs/.vitepress/dist/assets/inter-italic-latin.C2AdPX0b.woff2 +0 -0
  15. package/docs/.vitepress/dist/assets/inter-italic-vietnamese.BSbpV94h.woff2 +0 -0
  16. package/docs/.vitepress/dist/assets/inter-roman-cyrillic-ext.BBPuwvHQ.woff2 +0 -0
  17. package/docs/.vitepress/dist/assets/inter-roman-cyrillic.C5lxZ8CY.woff2 +0 -0
  18. package/docs/.vitepress/dist/assets/inter-roman-greek-ext.CqjqNYQ-.woff2 +0 -0
  19. package/docs/.vitepress/dist/assets/inter-roman-greek.BBVDIX6e.woff2 +0 -0
  20. package/docs/.vitepress/dist/assets/inter-roman-latin-ext.4ZJIpNVo.woff2 +0 -0
  21. package/docs/.vitepress/dist/assets/inter-roman-latin.Di8DUHzh.woff2 +0 -0
  22. package/docs/.vitepress/dist/assets/inter-roman-vietnamese.BjW4sHH5.woff2 +0 -0
  23. package/docs/.vitepress/dist/assets/sillyspec_commands.md.CXFFsj08.js +15 -0
  24. package/docs/.vitepress/dist/assets/sillyspec_commands.md.CXFFsj08.lean.js +1 -0
  25. package/docs/.vitepress/dist/assets/sillyspec_dashboard.md.BuPXHqjX.js +4 -0
  26. package/docs/.vitepress/dist/assets/sillyspec_dashboard.md.BuPXHqjX.lean.js +1 -0
  27. package/docs/.vitepress/dist/assets/sillyspec_file-io.md.Cz3x7llx.js +1 -0
  28. package/docs/.vitepress/dist/assets/sillyspec_file-io.md.Cz3x7llx.lean.js +1 -0
  29. package/docs/.vitepress/dist/assets/sillyspec_getting-started.md.ClcvV8k3.js +4 -0
  30. package/docs/.vitepress/dist/assets/sillyspec_getting-started.md.ClcvV8k3.lean.js +1 -0
  31. package/docs/.vitepress/dist/assets/sillyspec_install.md.CKuR2tiT.js +5 -0
  32. package/docs/.vitepress/dist/assets/sillyspec_install.md.CKuR2tiT.lean.js +1 -0
  33. package/docs/.vitepress/dist/assets/sillyspec_lifecycle.md.DY293cR1.js +28 -0
  34. package/docs/.vitepress/dist/assets/sillyspec_lifecycle.md.DY293cR1.lean.js +1 -0
  35. package/docs/.vitepress/dist/assets/sillyspec_structure.md.sVYS4zPs.js +30 -0
  36. package/docs/.vitepress/dist/assets/sillyspec_structure.md.sVYS4zPs.lean.js +1 -0
  37. package/docs/.vitepress/dist/assets/style.DFTx90Kk.css +1 -0
  38. package/docs/.vitepress/dist/hashmap.json +1 -0
  39. package/docs/.vitepress/dist/index.html +28 -0
  40. package/docs/.vitepress/dist/sillyspec/commands.html +42 -0
  41. package/docs/.vitepress/dist/sillyspec/dashboard.html +31 -0
  42. package/docs/.vitepress/dist/sillyspec/file-io.html +28 -0
  43. package/docs/.vitepress/dist/sillyspec/getting-started.html +31 -0
  44. package/docs/.vitepress/dist/sillyspec/install.html +32 -0
  45. package/docs/.vitepress/dist/sillyspec/lifecycle.html +55 -0
  46. package/docs/.vitepress/dist/sillyspec/structure.html +57 -0
  47. package/docs/.vitepress/dist/vp-icons.css +1 -0
  48. package/docs/index.md +34 -0
  49. package/docs/sillyspec/commands.md +218 -0
  50. package/docs/sillyspec/dashboard.md +51 -0
  51. package/docs/sillyspec/file-io.md +34 -0
  52. package/docs/sillyspec/getting-started.md +61 -0
  53. package/docs/sillyspec/install.md +51 -0
  54. package/docs/sillyspec/lifecycle.md +146 -0
  55. package/docs/sillyspec/structure.md +62 -0
  56. package/package.json +11 -9
  57. package/packages/dashboard/dist/assets/index-Bh-GPjKY.css +1 -0
  58. package/packages/dashboard/dist/assets/index-CrCn5Gg6.js +17 -0
  59. package/packages/dashboard/dist/index.html +2 -2
  60. package/packages/dashboard/package-lock.json +0 -220
  61. package/packages/dashboard/package.json +5 -8
  62. package/packages/dashboard/server/index.js +106 -255
  63. package/packages/dashboard/server/parser.js +29 -333
  64. package/packages/dashboard/server/watcher.js +131 -203
  65. package/packages/dashboard/src/App.vue +10 -181
  66. package/packages/dashboard/src/components/ActionBar.vue +42 -26
  67. package/packages/dashboard/src/components/CommandPalette.vue +65 -40
  68. package/packages/dashboard/src/components/DetailPanel.vue +53 -68
  69. package/packages/dashboard/src/components/LogStream.vue +33 -13
  70. package/packages/dashboard/src/components/PipelineStage.vue +8 -8
  71. package/packages/dashboard/src/components/PipelineView.vue +45 -80
  72. package/packages/dashboard/src/components/ProjectList.vue +45 -103
  73. package/packages/dashboard/src/components/StageBadge.vue +13 -13
  74. package/packages/dashboard/src/components/StepCard.vue +15 -15
  75. package/packages/dashboard/src/composables/useDashboard.js +6 -20
  76. package/packages/dashboard/src/composables/useKeyboard.js +4 -6
  77. package/packages/dashboard/src/main.js +1 -4
  78. package/packages/dashboard/src/style.css +17 -17
  79. package/src/index.js +12 -123
  80. package/src/init.js +227 -86
  81. package/src/setup.js +9 -1
  82. package/templates/archive.md +120 -0
  83. package/templates/brainstorm.md +170 -0
  84. package/{.claude/skills/sillyspec-commit/SKILL.md → templates/commit.md} +45 -29
  85. package/templates/continue.md +32 -0
  86. package/templates/execute.md +304 -0
  87. package/templates/explore.md +59 -0
  88. package/templates/export.md +21 -0
  89. package/templates/init.md +61 -0
  90. package/templates/plan.md +146 -0
  91. package/templates/quick.md +135 -0
  92. package/templates/scan-quick.md +49 -0
  93. package/templates/scan.md +156 -0
  94. package/templates/skills/playwright-e2e/SKILL.md +340 -0
  95. package/templates/status.md +75 -0
  96. package/templates/verify.md +236 -0
  97. package/templates/workspace-sync.md +99 -0
  98. package/templates/workspace.md +70 -0
  99. package/.claude/skills/sillyspec-archive/SKILL.md +0 -17
  100. package/.claude/skills/sillyspec-auto/SKILL.md +0 -77
  101. package/.claude/skills/sillyspec-brainstorm/SKILL.md +0 -17
  102. package/.claude/skills/sillyspec-continue/SKILL.md +0 -44
  103. package/.claude/skills/sillyspec-doctor/SKILL.md +0 -22
  104. package/.claude/skills/sillyspec-execute/SKILL.md +0 -17
  105. package/.claude/skills/sillyspec-explore/SKILL.md +0 -96
  106. package/.claude/skills/sillyspec-export/SKILL.md +0 -53
  107. package/.claude/skills/sillyspec-init/SKILL.md +0 -170
  108. package/.claude/skills/sillyspec-plan/SKILL.md +0 -52
  109. package/.claude/skills/sillyspec-propose/SKILL.md +0 -17
  110. package/.claude/skills/sillyspec-quick/SKILL.md +0 -17
  111. package/.claude/skills/sillyspec-resume/SKILL.md +0 -111
  112. package/.claude/skills/sillyspec-scan/SKILL.md +0 -17
  113. package/.claude/skills/sillyspec-state/SKILL.md +0 -54
  114. package/.claude/skills/sillyspec-status/SKILL.md +0 -17
  115. package/.claude/skills/sillyspec-verify/SKILL.md +0 -17
  116. package/.claude/skills/sillyspec-workspace/SKILL.md +0 -149
  117. package/.sillyspec/changes/archive/2026-04-08-derive-state/design.md +0 -97
  118. package/.sillyspec/changes/archive/2026-04-08-derive-state/plan.md +0 -51
  119. package/.sillyspec/changes/archive/2026-04-08-derive-state/proposal.md +0 -29
  120. package/.sillyspec/changes/archive/2026-04-08-derive-state/requirements.md +0 -34
  121. package/.sillyspec/changes/archive/2026-04-08-derive-state/tasks.md +0 -13
  122. package/.sillyspec/changes/archive/2026-04-08-derive-state/verify-result.md +0 -43
  123. package/.sillyspec/changes/auto-mode/design.md +0 -50
  124. package/.sillyspec/changes/auto-mode/proposal.md +0 -19
  125. package/.sillyspec/changes/auto-mode/requirements.md +0 -21
  126. package/.sillyspec/changes/auto-mode/tasks.md +0 -7
  127. package/.sillyspec/changes/brainstorm-archive/2026-04-05-unified-docs-design.md +0 -199
  128. package/.sillyspec/changes/dashboard/design.md.braindraft +0 -206
  129. package/.sillyspec/changes/run-command-design/design.md +0 -1230
  130. package/.sillyspec/changes/unified-docs-design/design.md +0 -199
  131. package/.sillyspec/docs/sillyspec/scan/.gitkeep +0 -0
  132. package/.sillyspec/knowledge/INDEX.md +0 -8
  133. package/.sillyspec/knowledge/uncategorized.md +0 -3
  134. package/.sillyspec/projects/sillyspec.yaml +0 -3
  135. package/packages/dashboard/dist/assets/index-D1EVTLmc.js +0 -7446
  136. package/packages/dashboard/dist/assets/index-DGe8CqeP.css +0 -1
  137. package/packages/dashboard/public/logo.jpg +0 -0
  138. package/packages/dashboard/src/components/DocPreview.vue +0 -160
  139. package/packages/dashboard/src/components/DocTree.vue +0 -58
  140. package/packages/dashboard/src/components/ProjectOverview.vue +0 -178
  141. package/packages/dashboard/src/components/detail/DocsDetail.vue +0 -48
  142. package/packages/dashboard/src/components/detail/GitDetail.vue +0 -61
  143. package/packages/dashboard/src/components/detail/TechDetail.vue +0 -43
  144. package/src/derive.js +0 -147
  145. package/src/migrate.js +0 -117
  146. package/src/progress.js +0 -495
  147. package/src/run.js +0 -640
  148. package/src/stages/archive.js +0 -54
  149. package/src/stages/brainstorm.js +0 -239
  150. package/src/stages/doctor.js +0 -312
  151. package/src/stages/execute.js +0 -259
  152. package/src/stages/index.js +0 -35
  153. package/src/stages/plan.js +0 -259
  154. package/src/stages/propose.js +0 -115
  155. package/src/stages/quick.js +0 -64
  156. package/src/stages/scan.js +0 -141
  157. package/src/stages/status.js +0 -65
  158. package/src/stages/verify.js +0 -135
  159. /package/.sillyspec/{changes/brainstorm-archive → specs}/2026-04-05-dashboard-design.md +0 -0
  160. /package/{packages/dashboard → docs/.vitepress}/dist/favicon.jpg +0 -0
  161. /package/{logo.jpg → docs/.vitepress/dist/logo.jpg} +0 -0
  162. /package/{packages/dashboard → docs}/public/favicon.jpg +0 -0
  163. /package/{packages/dashboard/dist → docs/public}/logo.jpg +0 -0
@@ -1,64 +0,0 @@
1
- export const definition = {
2
- name: 'quick',
3
- title: '快速任务',
4
- description: '跳过完整流程,直接做',
5
- auxiliary: true,
6
- steps: [
7
- {
8
- name: '理解任务',
9
- prompt: `解析任务参数,加载项目上下文。
10
-
11
- ### 操作
12
- 1. 检查是否携带 \`--change <变更名>\`,确定记录方式
13
- 2. 理解任务:模糊则问一个问题确认
14
- 3. 加载项目信息:\`cat .sillyspec/projects/*.yaml 2>/dev/null\`(了解项目结构和技术栈)
15
- 4. 加载上下文:\`cat .sillyspec/docs/<project>/scan/CONVENTIONS.md 2>/dev/null\`
16
- 5. 加载本地配置:\`cat .sillyspec/local.yaml 2>/dev/null\`(构建命令、测试命令、环境变量等)
17
- 6. 如有 \`--change\`,加载设计文档:\`cat .sillyspec/changes/<变更名>/design.md 2>/dev/null\`(理解设计意图)
18
- 7. 如有需要,查询知识库:\`cat .sillyspec/knowledge/INDEX.md 2>/dev/null\`
19
-
20
- ### 输出
21
- 任务理解 + 上下文摘要`,
22
- outputHint: '任务理解',
23
- optional: false
24
- },
25
- {
26
- name: '实现并验证',
27
- prompt: `实现任务。
28
-
29
- ### 操作
30
- 1. 先读后写:调用已有方法前 \`cat\` 源文件确认签名,\`grep\` 确认方法存在
31
- 2. 写代码完成任务
32
- 3. 如涉及逻辑变更,建议写单元测试验证(不强制,纯配置/文档/小改动可跳过)
33
- 4. **不要编译!** 除非用户明确要求或改动量很大
34
-
35
- ### 输出
36
- 实现摘要 + 修改文件列表
37
-
38
- ### 铁律
39
- - 不要修改无关文件
40
- - 不要编造不存在的 CLI 子命令
41
- - **Reverse Sync**:如果发现 Bug 是 design.md 遗漏导致的,先修 design.md 再修代码`,
42
- outputHint: '实现摘要',
43
- optional: false
44
- },
45
- {
46
- name: '暂存和记录',
47
- prompt: `Git 暂存并记录任务。
48
-
49
- ### 操作
50
- 1. \`git add -A\` — **不要 commit**,由用户通过统一提交
51
- 2. 记录:
52
- - 有 \`--change\`:在 \`.sillyspec/changes/<变更名>/tasks.md\` 追加 task 并勾选,记录精确到秒的时间戳
53
- - 无 \`--change\`:记录到 \`.sillyspec/quicklog/QUICKLOG-<git用户名>.md\`(按 git 用户名隔离)
54
- 3. QUICKLOG 轮转:超过 500 行则重命名为 \`QUICKLOG-<USER>-YYYY-MM-DD.md\`
55
- 4. 如果发现项目特有的坑,追加到 \`.sillyspec/knowledge/uncategorized.md\`
56
- 5. 任务比预期复杂 → 建议用完整流程
57
-
58
- ### 输出
59
- 暂存确认 + 记录路径`,
60
- outputHint: '暂存和记录确认',
61
- optional: false
62
- }
63
- ]
64
- }
@@ -1,141 +0,0 @@
1
- export const definition = {
2
- name: 'scan',
3
- title: '代码扫描',
4
- description: '分析项目结构、约定和架构',
5
- auxiliary: true,
6
- steps: [
7
- {
8
- name: '检查已有扫描文档和子项目列表',
9
- prompt: `检查已有扫描文档和子项目列表。
10
-
11
- ### 操作
12
- 1. \`ls .sillyspec/projects/*.yaml 2>/dev/null | grep -q .\` — 检查已有文档
13
- 1. \`ls docs/*/scan/ 2>/dev/null\` — 检查已有文档
14
- 2. \`wc -l docs/*/scan/*.md 2>/dev/null\` — 文档行数
15
- 3. 已有 3 份 → 建议升级深度扫描;已有 7 份 → 建议刷新或跳过
16
- 5. 显示子项目列表供选择扫描范围
17
-
18
- ### 输出
19
- 已有文档状态 + 扫描建议`,
20
- outputHint: '工作区和文档状态',
21
- optional: false
22
- },
23
- {
24
- name: '构建环境探测',
25
- prompt: `探测项目的构建环境和依赖。
26
-
27
- ### 操作
28
- 1. \`cat package.json pom.xml build.gradle go.mod Cargo.toml requirements.txt pyproject.toml Gemfile composer.json 2>/dev/null\`
29
- 2. \`find . -maxdepth 2 -name "*.config.*" -not -path "*/node_modules/*" -not -path "*/.git/*" | head -20 | xargs cat 2>/dev/null\`
30
- 3. 结果保存到 \`docs/<project>/scan/_env-detect.md\`(临时文件,扫描完删除)
31
-
32
- ### 输出
33
- 环境探测结果摘要`,
34
- outputHint: '环境探测摘要',
35
- optional: false
36
- },
37
- {
38
- name: '断点续扫检测',
39
- prompt: `检测已有扫描文档,只生成缺失的。
40
-
41
- ### 操作
42
- 1. \`PROJECT=$(python3 -c "import sys,json; print(json.load(open('.sillyspec/.runtime/progress.json')).get('project',''))" 2>/dev/null || basename "$(pwd)")\`
43
- 2. 检查 7 份文档是否存在:ARCHITECTURE、STRUCTURE、CONVENTIONS、INTEGRATIONS、TESTING、CONCERNS、PROJECT
44
- 3. 列出已有 ✅ 和缺失 ⬜
45
- 4. 只生成缺失的文档
46
-
47
- ### 输出
48
- 已有/缺失文档列表`,
49
- outputHint: '断点续扫状态',
50
- optional: false
51
- },
52
- {
53
- name: '深度扫描 — 技术架构',
54
- prompt: `扫描技术栈 + 数据库 Schema + 架构模式。参考 _env-detect.md。
55
-
56
- ### 操作
57
- 1. 用 grep/rg 搜索(\`@Entity\`、\`schema.prisma\`、\`models.py\` 等),**禁止读源码全文**
58
- 2. Schema 只记表名+说明+字段数
59
- 3. 写入 \`docs/<project>/scan/ARCHITECTURE.md\`
60
- 4. 包含 \`## 技术栈\` \`## 架构概览\` \`## 数据模型(摘要)\`
61
-
62
- ### 输出
63
- ARCHITECTURE.md 路径
64
-
65
- ### 注意
66
- - 路径用反引号,不编造`,
67
- outputHint: 'ARCHITECTURE.md 路径',
68
- optional: false
69
- },
70
- {
71
- name: '深度扫描 — 代码约定',
72
- prompt: `扫描框架隐形规则 + 实体继承 + 代码风格。参考 _env-detect.md。
73
-
74
- ### 操作
75
- 1. 用 grep 搜索拦截器/插件/逻辑删除/基类/审计字段,**禁止读源码全文**
76
- 2. 根据检测到的语言/框架自行决定搜索什么模式
77
- 3. 提取 3-5 个典型示例
78
- 4. 写入 \`docs/<project>/scan/CONVENTIONS.md\`
79
- 5. 包含 \`## 框架隐形规则\` \`## 实体继承规范\` \`## 代码风格\`
80
-
81
- ### 输出
82
- CONVENTIONS.md 路径
83
-
84
- ### 注意
85
- - 路径用反引号,不编造`,
86
- outputHint: 'CONVENTIONS.md 路径',
87
- optional: false
88
- },
89
- {
90
- name: '深度扫描 — 目录结构和集成',
91
- prompt: `扫描目录结构 + 外部集成。参考 _env-detect.md。
92
-
93
- ### 操作
94
- 1. 用 find/ls/tree 和 grep,**禁止读源码全文**
95
- 2. 搜索 API 调用、MQ 配置、缓存、第三方 SDK
96
- 3. 写入 \`docs/<project>/scan/STRUCTURE.md\`(目录树+模块说明)
97
- 4. 写入 \`docs/<project>/scan/INTEGRATIONS.md\`(按类型分组)
98
-
99
- ### 输出
100
- STRUCTURE.md 和 INTEGRATIONS.md 路径
101
-
102
- ### 注意
103
- - 路径用反引号,不编造`,
104
- outputHint: 'STRUCTURE.md + INTEGRATIONS.md 路径',
105
- optional: false
106
- },
107
- {
108
- name: '深度扫描 — 测试和债务',
109
- prompt: `扫描测试现状 + 技术债务 + 项目概览。参考 _env-detect.md。
110
-
111
- ### 操作
112
- 1. 用 grep 搜索测试文件、TODO/FIXME、过时依赖,**禁止读源码全文**
113
- 2. 写入 \`docs/<project>/scan/TESTING.md\`(测试结构)
114
- 3. 写入 \`docs/<project>/scan/CONCERNS.md\`(按严重程度分组)
115
- 4. 写入 \`docs/<project>/scan/PROJECT.md\`(项目信息)
116
-
117
- ### 输出
118
- TESTING.md、CONCERNS.md、PROJECT.md 路径`,
119
- outputHint: '三份文档路径',
120
- optional: false
121
- },
122
- {
123
- name: '自检和提交',
124
- prompt: `验证扫描完整性,清理并提交。
125
-
126
- ### 操作
127
- 1. 检查 7 份文档是否全部生成
128
- 2. 自检门控:ARCHITECTURE(技术栈+Schema摘要)、CONVENTIONS(隐形规则+代码风格)、STRUCTURE(目录结构)、INTEGRATIONS(外部依赖)、TESTING(测试现状)、CONCERNS(技术债务)、PROJECT(项目概览)
129
- 3. 清理:\`rm -f docs/<project>/scan/_env-detect.md\`
130
- 4. \`git add .\` — **不要 commit**,由用户通过统一提交工具处理
131
-
132
- ### 输出
133
- 扫描完整性报告
134
-
135
- ### 注意
136
- - ❌ 修改代码 / 编造路径 / 读源码全文`,
137
- outputHint: '自检报告',
138
- optional: false
139
- }
140
- ]
141
- }
@@ -1,65 +0,0 @@
1
- export const definition = {
2
- name: 'status',
3
- title: '状态查看',
4
- description: '查看项目进度和状态',
5
- auxiliary: true,
6
- steps: [
7
- {
8
- name: '项目基础信息',
9
- prompt: `收集项目基础信息。
10
-
11
- ### 操作
12
- 1. \`cat .sillyspec/PROJECT.md 2>/dev/null || echo "未初始化"\`
13
- 2. 获取 project 名
14
- 3. \`ls docs/<project>/scan/ 2>/dev/null | head -10\`
15
- 4. \`cat .sillyspec/REQUIREMENTS.md 2>/dev/null | head -20\`
16
- 5. \`cat .sillyspec/ROADMAP.md 2>/dev/null\`
17
-
18
- ### 输出
19
- 项目基础信息摘要`,
20
- outputHint: '项目基础信息',
21
- optional: false
22
- },
23
- {
24
- name: '变更状态',
25
- prompt: `检查进行中的变更和归档历史。
26
-
27
- ### 操作
28
- 1. \`ls .sillyspec/changes/ 2>/dev/null | grep -v archive\`
29
- 2. 对每个进行中的变更:检查 proposal.md ✅/❌、design.md ✅/❌、requirements.md ✅/❌、tasks.md — X/Y 完成
30
- 3. \`ls .sillyspec/changes/archive/ 2>/dev/null | wc -l\`
31
- 4. \`cat .sillyspec/HANDOFF.json 2>/dev/null\`
32
-
33
- ### 输出
34
- 变更状态列表`,
35
- outputHint: '变更状态',
36
- optional: false
37
- },
38
- {
39
- name: '输出状态报告',
40
- prompt: `生成完整状态报告。
41
-
42
- ### 输出格式:
43
- \`\`\`
44
- 📊 SillySpec 状态
45
-
46
- 📋 项目:xxx(已初始化 / 未初始化)
47
- 📂 代码库:已扫描(7 份文档)/ 未扫描
48
-
49
- 🔄 进行中:N 个变更
50
- - [change-1] Phase 3 (Execute) — tasks 5/8
51
-
52
- ✅ 已归档:N 个变更
53
- 📝 设计文档:N 份
54
- 📝 实现计划:N 份
55
-
56
- 💡 下一步:/sillyspec:continue
57
- \`\`\`
58
-
59
- ### 注意
60
- - 不修改任何文件`,
61
- outputHint: '状态报告',
62
- optional: false
63
- }
64
- ]
65
- }
@@ -1,135 +0,0 @@
1
- export const definition = {
2
- name: 'verify',
3
- title: '验证确认',
4
- description: '对照规范检查 + 测试套件',
5
- steps: [
6
- {
7
- name: '状态检查',
8
- prompt: `检查当前状态,确认可以执行 verify。
9
-
10
- ### 操作
11
- 1. 运行 \`sillyspec progress show\`
12
- 2. 确认 currentStage 为 "verify"
13
-
14
- ### 输出
15
- 当前状态摘要`,
16
- outputHint: '状态摘要',
17
- optional: false
18
- },
19
- {
20
- name: '加载规范并锚定',
21
- prompt: `加载规范文件并确认。
22
-
23
- ### 操作
24
- 1. 读取 proposal.md、design.md、tasks.md、requirements.md
25
- 2. 加载项目信息:\`cat .sillyspec/projects/*.yaml 2>/dev/null\`
26
- 3. 加载本地配置:\`cat .sillyspec/local.yaml 2>/dev/null\`(构建命令、测试命令、lint 命令等)
27
- 4. 加载代码规范:\`cat .sillyspec/docs/<project>/scan/CONVENTIONS.md 2>/dev/null\`
28
- 5. 标注每个文件的存在/不存在状态
29
-
30
- ### 输出
31
- 文件加载确认清单`,
32
- outputHint: '文件确认清单',
33
- optional: false
34
- },
35
- {
36
- name: '逐项检查任务',
37
- prompt: `对照 tasks.md 检查每个任务完成状态。
38
-
39
- ### 操作
40
- 对每个 checkbox:
41
- 1. 检查相关文件是否存在
42
- 2. 检查代码是否实现了描述的功能
43
- 3. 标记:✅ 已完成 / ❌ 未完成 / ⚠️ 部分完成
44
-
45
- ### 批量模式验证指引
46
- 如果 tasks.md 中有批量特征(引擎/模板/配置/批量生成),采用分层验证:
47
- - **L1 自动化(100%)**:运行验证脚本(如有),检查所有实例的文件存在、格式正确、Schema 校验通过
48
- - **L2 AI 抽查(5-10 个)**:选择最复杂的 3 个 + 最简单的 2 个 + 有特殊逻辑的,检查业务逻辑正确性
49
- - **L3 模式性 bug 检测**:L2 发现 bug → 判断是否为系统性问题 → 系统性 bug 则回退修复引擎并重新生成所有实例
50
-
51
- ### 输出
52
- 任务完成度列表 + 完成率
53
-
54
- ### 注意
55
- - 不修改任何代码,只做检查和报告`,
56
- outputHint: '任务完成度报告',
57
- optional: false
58
- },
59
- {
60
- name: '对照设计检查',
61
- prompt: `对照 design.md 检查实现一致性。**design.md 是唯一 truth source,不符合 design.md 的实现 = Bug。**
62
-
63
- ### 操作
64
- 1. 架构决策是否遵循
65
- 2. 文件变更清单是否一致
66
- 3. 数据模型是否符合
67
- 4. API 设计是否符合
68
- 5. **Reverse Sync 检查**:如果发现实现合理但 design.md 未覆盖,先更新 design.md 补充遗漏
69
-
70
- ### 输出
71
- 一致性检查结果`,
72
- outputHint: '设计一致性报告',
73
- optional: false
74
- },
75
- {
76
- name: '任务蓝图验收',
77
- prompt: `检查每个 task-N.md 的验收标准是否全部满足。
78
-
79
- ### 操作
80
- 1. 检查变更目录下 tasks/ 是否存在
81
- 2. 如果存在:
82
- - 逐个读取 tasks/task-NN.md
83
- - 检查每个文件的「验收标准」checkbox 是否全部勾选
84
- - 未勾选的项列为不通过
85
- 3. 如果不存在:跳过此步骤
86
-
87
- ### 输出
88
- 验收结果:通过/不通过 + 未通过的项`,
89
- outputHint: '验收结果',
90
- optional: false
91
- },
92
- {
93
- name: '运行测试和质量扫描',
94
- prompt: `运行测试和代码质量扫描。
95
-
96
- ### 操作
97
- 1. 读取 \`.sillyspec/local.yaml\` 获取构建和测试命令
98
- 2. 如果 local.yaml 有 test 命令,使用它(仅测试变更涉及的模块,非全量)
99
- 3. 如果 local.yaml 无 test 命令,根据项目类型选择:
100
- - Maven:\`mvn test -pl <变更模块> -am\`(仅编译变更模块及其依赖)
101
- - Gradle:\`./gradlew :<模块>:test\`
102
- - npm/pnpm:\`pnpm test --filter=<包名>\` 或 \`npm test -- --testPathPattern=<相关文件>\`
103
- - Python:\`pytest <变更模块路径>/\`
104
- 4. 记录通过/失败数量,分析失败原因
105
- 5. 搜索技术债务:grep TODO/FIXME/HACK/XXX(仅限变更文件)
106
- 6. 如果 local.yaml 有 lint 命令,运行 lint 检查
107
-
108
- ### 注意
109
- - 不要全量编译/测试整个项目,只测变更涉及的模块
110
- - 如果变更模块不确定,优先使用 local.yaml 中的命令
111
-
112
- ### 输出
113
- 测试结果 + 技术债务标记`,
114
- outputHint: '测试结果 + 技术债务',
115
- optional: false
116
- },
117
- {
118
- name: '输出验证报告',
119
- prompt: `生成完整验证报告。
120
-
121
- ### 操作
122
- 1. 汇总以上所有检查结果
123
- 2. 给出结论:PASS / PASS WITH NOTES / FAIL
124
-
125
- ### 输出
126
- 验证报告 markdown + 下一步命令
127
-
128
- ### 注意
129
- - PASS → 下一步 archive
130
- - FAIL → 修复后重新 verify`,
131
- outputHint: '验证报告',
132
- optional: false
133
- }
134
- ]
135
- }
File without changes
File without changes