cc-devflow 4.3.0 → 4.4.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.
Files changed (575) hide show
  1. package/.claude/skills/cc-act/CHANGELOG.md +64 -0
  2. package/.claude/skills/cc-act/PLAYBOOK.md +212 -0
  3. package/.claude/skills/cc-act/SKILL.md +322 -0
  4. package/.claude/skills/cc-act/assets/PR_BRIEF_TEMPLATE.md +64 -0
  5. package/.claude/skills/cc-act/assets/RELEASE_NOTE_TEMPLATE.md +25 -0
  6. package/.claude/skills/cc-act/references/closure-contract.md +49 -0
  7. package/.claude/skills/cc-act/references/git-commit-guidelines.md +83 -0
  8. package/.claude/skills/cc-act/scripts/archive-requirement.sh +49 -0
  9. package/.claude/skills/cc-act/scripts/cc-act-common.sh +240 -0
  10. package/.claude/skills/cc-act/scripts/detect-ship-target.sh +82 -0
  11. package/.claude/skills/cc-act/scripts/generate-status-report.sh +83 -0
  12. package/.claude/skills/cc-act/scripts/render-pr-brief.sh +195 -0
  13. package/.claude/skills/cc-act/scripts/sync-act-docs.sh +315 -0
  14. package/.claude/skills/cc-act/scripts/verify-act-gate.sh +63 -0
  15. package/.claude/skills/cc-check/CHANGELOG.md +73 -0
  16. package/.claude/skills/cc-check/PLAYBOOK.md +153 -0
  17. package/.claude/skills/cc-check/SKILL.md +345 -0
  18. package/.claude/skills/cc-check/assets/REPORT_CARD_TEMPLATE.json +50 -0
  19. package/.claude/skills/cc-check/references/gate-contract.md +29 -0
  20. package/.claude/skills/cc-check/references/review-contract.md +45 -0
  21. package/.claude/skills/cc-check/scripts/render-report-card.js +229 -0
  22. package/.claude/skills/cc-check/scripts/run-quality-gates.sh +86 -0
  23. package/.claude/skills/cc-check/scripts/verify-gate.sh +57 -0
  24. package/.claude/skills/cc-do/CHANGELOG.md +49 -0
  25. package/.claude/skills/cc-do/PLAYBOOK.md +119 -0
  26. package/.claude/skills/cc-do/SKILL.md +216 -0
  27. package/.claude/skills/cc-do/references/execution-recovery.md +86 -0
  28. package/.claude/skills/cc-do/references/parallel-dispatch.md +80 -0
  29. package/.claude/skills/cc-do/scripts/build-task-context.sh +184 -0
  30. package/.claude/skills/cc-do/scripts/cc-do-common.sh +79 -0
  31. package/.claude/skills/cc-do/scripts/check-task-status.sh +92 -0
  32. package/.claude/skills/cc-do/scripts/detect-file-conflicts.sh +87 -0
  33. package/.claude/skills/cc-do/scripts/mark-task-complete.sh +119 -0
  34. package/.claude/skills/cc-do/scripts/record-review-decision.sh +89 -0
  35. package/.claude/skills/cc-do/scripts/recover-workflow.sh +84 -0
  36. package/.claude/skills/cc-do/scripts/run-problem-analysis.sh +70 -0
  37. package/.claude/skills/cc-do/scripts/select-ready-tasks.sh +135 -0
  38. package/.claude/skills/cc-do/scripts/verify-task-gates.sh +94 -0
  39. package/.claude/skills/cc-do/scripts/write-task-checkpoint.sh +102 -0
  40. package/.claude/skills/cc-investigate/CHANGELOG.md +26 -0
  41. package/.claude/skills/cc-investigate/PLAYBOOK.md +49 -0
  42. package/.claude/skills/cc-investigate/SKILL.md +221 -0
  43. package/.claude/skills/cc-investigate/assets/ANALYSIS_TEMPLATE.md +55 -0
  44. package/.claude/skills/cc-investigate/assets/TASKS_TEMPLATE.md +52 -0
  45. package/.claude/skills/cc-investigate/assets/TASK_MANIFEST_TEMPLATE.json +103 -0
  46. package/.claude/skills/cc-investigate/references/investigation-contract.md +28 -0
  47. package/.claude/skills/cc-investigate/scripts/bootstrap-analysis.sh +38 -0
  48. package/.claude/skills/cc-plan/CHANGELOG.md +99 -0
  49. package/.claude/skills/cc-plan/PLAYBOOK.md +106 -0
  50. package/.claude/skills/cc-plan/SKILL.md +325 -0
  51. package/.claude/skills/cc-plan/assets/DESIGN_TEMPLATE.md +155 -0
  52. package/.claude/skills/cc-plan/assets/TASKS_TEMPLATE.md +98 -0
  53. package/.claude/skills/cc-plan/assets/TASK_MANIFEST_TEMPLATE.json +108 -0
  54. package/.claude/skills/cc-plan/assets/TINY_DESIGN_TEMPLATE.md +79 -0
  55. package/.claude/skills/cc-plan/references/planning-contract.md +82 -0
  56. package/.claude/skills/cc-plan/scripts/bump-skill-version.sh +103 -0
  57. package/.claude/skills/cc-plan/scripts/parse-task-dependencies.js +75 -0
  58. package/.claude/skills/cc-plan/scripts/validate-scope.sh +78 -0
  59. package/.claude/skills/cc-roadmap/CHANGELOG.md +114 -0
  60. package/.claude/skills/cc-roadmap/PLAYBOOK.md +136 -0
  61. package/.claude/skills/cc-roadmap/SKILL.md +259 -0
  62. package/.claude/skills/cc-roadmap/assets/BACKLOG_TEMPLATE.md +45 -0
  63. package/.claude/skills/cc-roadmap/assets/ROADMAP_TEMPLATE.md +153 -0
  64. package/.claude/skills/cc-roadmap/assets/TRACKING_TEMPLATE.json +48 -0
  65. package/.claude/skills/cc-roadmap/references/roadmap-dialogue.md +37 -0
  66. package/.claude/skills/cc-roadmap/scripts/bump-skill-version.sh +103 -0
  67. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/markdown.js +604 -0
  68. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/query.js +63 -0
  69. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/schema.js +245 -0
  70. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/store.js +139 -0
  71. package/.claude/skills/cc-roadmap/scripts/locate-roadmap-item.sh +109 -0
  72. package/.claude/skills/cc-roadmap/scripts/roadmap-tracking.js +153 -0
  73. package/.claude/skills/cc-roadmap/scripts/sync-roadmap-progress.sh +100 -0
  74. package/.claude/skills/cc-simplify/CHANGELOG.md +10 -0
  75. package/.claude/skills/cc-simplify/SKILL.md +55 -0
  76. package/.claude/skills/cc-spec-init/CHANGELOG.md +7 -0
  77. package/.claude/skills/cc-spec-init/PLAYBOOK.md +55 -0
  78. package/.claude/skills/cc-spec-init/SKILL.md +127 -0
  79. package/.claude/skills/cc-spec-init/assets/CAPABILITY_TEMPLATE.md +63 -0
  80. package/.claude/skills/cc-spec-init/assets/CHANGE_META_TEMPLATE.json +25 -0
  81. package/.claude/skills/cc-spec-init/assets/INDEX_TEMPLATE.md +34 -0
  82. package/.claude/skills/cc-spec-init/references/spec-contract.md +22 -0
  83. package/.claude/skills/cc-spec-init/scripts/bootstrap-specs.sh +31 -0
  84. package/.claude/skills/cc-spec-init/scripts/validate-spec-links.sh +45 -0
  85. package/CHANGELOG.md +61 -4
  86. package/README.md +120 -756
  87. package/README.zh-CN.md +119 -756
  88. package/bin/adapt.js +2 -6
  89. package/bin/cc-devflow-cli.js +72 -177
  90. package/config/distributable-skills.json +24 -0
  91. package/docs/CLAUDE.md +10 -6
  92. package/docs/commands/README.md +19 -46
  93. package/docs/commands/README.zh-CN.md +25 -48
  94. package/docs/examples/BY-ARTIFACT.md +7 -0
  95. package/docs/examples/README.md +38 -0
  96. package/docs/examples/START-HERE.md +149 -0
  97. package/docs/examples/example-bindings.json +38 -0
  98. package/docs/examples/full-design-blocked/BACKLOG.md +45 -0
  99. package/docs/examples/full-design-blocked/README.md +55 -0
  100. package/docs/examples/full-design-blocked/ROADMAP.md +53 -0
  101. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/design.md +154 -0
  102. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/task-manifest.json +146 -0
  103. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/tasks.md +78 -0
  104. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/review/report-card.json +52 -0
  105. package/docs/examples/full-design-blocked/roadmap-tracking.json +50 -0
  106. package/docs/examples/local-handoff/BACKLOG.md +45 -0
  107. package/docs/examples/local-handoff/README.md +56 -0
  108. package/docs/examples/local-handoff/ROADMAP.md +45 -0
  109. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/handoff/resume-index.md +39 -0
  110. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/handoff/status.md +29 -0
  111. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/design.md +71 -0
  112. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/task-manifest.json +98 -0
  113. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/tasks.md +59 -0
  114. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/review/report-card.json +44 -0
  115. package/docs/examples/local-handoff/roadmap-tracking.json +48 -0
  116. package/docs/examples/pdca-loop/BACKLOG.md +46 -0
  117. package/docs/examples/pdca-loop/README.md +58 -0
  118. package/docs/examples/pdca-loop/ROADMAP.md +133 -0
  119. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/handoff/pr-brief.md +72 -0
  120. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/handoff/status.md +29 -0
  121. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/design.md +72 -0
  122. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/task-manifest.json +201 -0
  123. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/tasks.md +73 -0
  124. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/review/report-card.json +44 -0
  125. package/docs/examples/pdca-loop/roadmap-tracking.json +114 -0
  126. package/docs/examples/scripts/check-example-bindings.sh +116 -0
  127. package/docs/guides/getting-started.md +94 -129
  128. package/docs/guides/getting-started.zh-CN.md +103 -84
  129. package/docs/skill-runtime-migration.md +46 -0
  130. package/docs/v4.3.0-migration-guide.md +60 -225
  131. package/lib/compiler/CLAUDE.md +55 -84
  132. package/lib/compiler/__tests__/drift.test.js +1 -1
  133. package/lib/compiler/__tests__/errors.test.js +0 -1
  134. package/lib/compiler/__tests__/integration.test.js +49 -3
  135. package/lib/compiler/__tests__/manifest.test.js +0 -156
  136. package/lib/compiler/__tests__/parser.test.js +33 -104
  137. package/lib/compiler/__tests__/schemas.test.js +30 -34
  138. package/lib/compiler/__tests__/skills-registry.test.js +114 -0
  139. package/lib/compiler/__tests__/transformer.test.js +5 -9
  140. package/lib/compiler/emitters/antigravity-emitter.js +5 -213
  141. package/lib/compiler/emitters/base-emitter.js +3 -298
  142. package/lib/compiler/emitters/codex-emitter.js +4 -202
  143. package/lib/compiler/emitters/cursor-emitter.js +3 -287
  144. package/lib/compiler/emitters/qwen-emitter.js +4 -176
  145. package/lib/compiler/index.js +65 -345
  146. package/lib/compiler/manifest.js +6 -68
  147. package/lib/compiler/parser.js +31 -63
  148. package/lib/compiler/platforms.js +32 -277
  149. package/lib/compiler/resource-copier.js +176 -6
  150. package/lib/compiler/rules-emitters/__tests__/antigravity-rules-emitter.test.js +3 -3
  151. package/lib/compiler/rules-emitters/__tests__/cursor-rules-emitter.test.js +14 -4
  152. package/lib/compiler/rules-emitters/__tests__/qwen-rules-emitter.test.js +16 -7
  153. package/lib/compiler/rules-emitters/antigravity-rules-emitter.js +10 -15
  154. package/lib/compiler/rules-emitters/base-rules-emitter.js +5 -5
  155. package/lib/compiler/rules-emitters/cursor-rules-emitter.js +7 -12
  156. package/lib/compiler/rules-emitters/index.js +6 -3
  157. package/lib/compiler/rules-emitters/qwen-rules-emitter.js +7 -7
  158. package/lib/compiler/schemas.js +8 -4
  159. package/lib/compiler/skills-registry.js +213 -15
  160. package/lib/compiler/transformer.js +1 -1
  161. package/lib/skill-runtime/CLAUDE.md +19 -0
  162. package/lib/skill-runtime/__tests__/autopilot.test.js +210 -0
  163. package/lib/skill-runtime/__tests__/cli-bootstrap.integration.test.js +181 -0
  164. package/lib/skill-runtime/__tests__/delegation.test.js +97 -0
  165. package/lib/skill-runtime/__tests__/dispatch.test.js +267 -0
  166. package/lib/skill-runtime/__tests__/intent.test.js +219 -0
  167. package/lib/skill-runtime/__tests__/lifecycle.test.js +169 -0
  168. package/lib/skill-runtime/__tests__/paths.test.js +42 -0
  169. package/lib/skill-runtime/__tests__/planner.tdd.test.js +250 -0
  170. package/lib/skill-runtime/__tests__/prepare-pr.test.js +139 -0
  171. package/lib/skill-runtime/__tests__/query.test.js +284 -0
  172. package/lib/skill-runtime/__tests__/runtime.integration.test.js +279 -0
  173. package/lib/skill-runtime/__tests__/schemas.test.js +207 -0
  174. package/lib/skill-runtime/__tests__/team-state.test.js +51 -0
  175. package/lib/skill-runtime/__tests__/worker-run.test.js +253 -0
  176. package/lib/skill-runtime/__tests__/worker.test.js +56 -0
  177. package/lib/skill-runtime/artifacts.js +93 -0
  178. package/lib/skill-runtime/delegation.js +533 -0
  179. package/lib/skill-runtime/index.js +34 -0
  180. package/lib/skill-runtime/intent.js +333 -0
  181. package/lib/skill-runtime/lifecycle.js +294 -0
  182. package/lib/skill-runtime/operations/CLAUDE.md +19 -0
  183. package/lib/skill-runtime/operations/approve.js +66 -0
  184. package/lib/skill-runtime/operations/autopilot-core.js +337 -0
  185. package/lib/skill-runtime/operations/autopilot-execution.js +307 -0
  186. package/lib/skill-runtime/operations/autopilot-shared.js +48 -0
  187. package/lib/skill-runtime/operations/autopilot.js +163 -0
  188. package/lib/skill-runtime/operations/dispatch.js +454 -0
  189. package/lib/skill-runtime/operations/init.js +64 -0
  190. package/lib/{harness → skill-runtime}/operations/janitor.js +9 -6
  191. package/lib/skill-runtime/operations/plan.js +59 -0
  192. package/lib/skill-runtime/operations/prepare-pr.js +25 -0
  193. package/lib/skill-runtime/operations/release.js +96 -0
  194. package/lib/skill-runtime/operations/resume.js +143 -0
  195. package/lib/skill-runtime/operations/snapshot.js +45 -0
  196. package/lib/skill-runtime/operations/verify.js +170 -0
  197. package/lib/skill-runtime/operations/worker-run.js +529 -0
  198. package/lib/skill-runtime/operations/worker.js +33 -0
  199. package/lib/skill-runtime/paths.js +213 -0
  200. package/lib/skill-runtime/planner.js +519 -0
  201. package/lib/skill-runtime/query.js +157 -0
  202. package/lib/skill-runtime/review.js +557 -0
  203. package/lib/skill-runtime/schemas.js +400 -0
  204. package/lib/{harness → skill-runtime}/store.js +45 -30
  205. package/lib/skill-runtime/team-state.js +122 -0
  206. package/package.json +13 -11
  207. package/.claude/CLAUDE.md +0 -125
  208. package/.claude/agents/architecture-designer.md +0 -443
  209. package/.claude/agents/bug-analyzer.md +0 -381
  210. package/.claude/agents/checklist-agent.md +0 -175
  211. package/.claude/agents/clarify-analyst.md +0 -50
  212. package/.claude/agents/code-quality-reviewer.md +0 -205
  213. package/.claude/agents/code-reviewer.md +0 -71
  214. package/.claude/agents/codex-analyzer.md +0 -39
  215. package/.claude/agents/compatibility-checker.md +0 -579
  216. package/.claude/agents/consistency-checker.md +0 -532
  217. package/.claude/agents/dev-implementer.md +0 -195
  218. package/.claude/agents/flow-researcher.md +0 -132
  219. package/.claude/agents/impact-analyzer.md +0 -440
  220. package/.claude/agents/planner.md +0 -230
  221. package/.claude/agents/prd-writer.md +0 -320
  222. package/.claude/agents/project-guidelines-generator.md +0 -1329
  223. package/.claude/agents/qa-tester.md +0 -313
  224. package/.claude/agents/release-manager.md +0 -295
  225. package/.claude/agents/security-reviewer.md +0 -314
  226. package/.claude/agents/spec-reviewer.md +0 -221
  227. package/.claude/agents/style-guide-generator.md +0 -458
  228. package/.claude/agents/tech-architect.md +0 -516
  229. package/.claude/agents/ui-designer.md +0 -485
  230. package/.claude/commands/core/architecture.md +0 -459
  231. package/.claude/commands/core/guidelines.md +0 -511
  232. package/.claude/commands/core/roadmap.md +0 -468
  233. package/.claude/commands/core/style.md +0 -83
  234. package/.claude/commands/flow/CLAUDE.md +0 -24
  235. package/.claude/commands/flow/archive.md +0 -280
  236. package/.claude/commands/flow/constitution.md +0 -82
  237. package/.claude/commands/flow/context.md +0 -150
  238. package/.claude/commands/flow/delta.md +0 -245
  239. package/.claude/commands/flow/dev.md +0 -40
  240. package/.claude/commands/flow/fix.md +0 -217
  241. package/.claude/commands/flow/ideate.md +0 -214
  242. package/.claude/commands/flow/init.md +0 -38
  243. package/.claude/commands/flow/release.md +0 -36
  244. package/.claude/commands/flow/restart.md +0 -97
  245. package/.claude/commands/flow/spec.md +0 -36
  246. package/.claude/commands/flow/status.md +0 -64
  247. package/.claude/commands/flow/update.md +0 -111
  248. package/.claude/commands/flow/upgrade.md +0 -115
  249. package/.claude/commands/flow/verify.md +0 -37
  250. package/.claude/commands/flow/workspace.md +0 -155
  251. package/.claude/commands/util/cancel-ralph.md +0 -60
  252. package/.claude/commands/util/code-review.md +0 -58
  253. package/.claude/commands/util/git-commit.md +0 -422
  254. package/.claude/commands/util/problem-analyzer.md +0 -60
  255. package/.claude/config/quality-gates.yml +0 -305
  256. package/.claude/config/quality-rules.yml +0 -161
  257. package/.claude/docs/SPEC_KIT_CONSTITUTION_ANALYSIS.md +0 -426
  258. package/.claude/docs/design/consistency-conflict-detection-algorithms.md +0 -658
  259. package/.claude/docs/design/intent-driven-input-design.md +0 -380
  260. package/.claude/docs/design/prd-version-management-design.md +0 -437
  261. package/.claude/docs/examples/design-inspiration-pool.md +0 -59
  262. package/.claude/docs/examples/ui-prototype-constitution-checklist.md +0 -75
  263. package/.claude/docs/guides/INIT_TROUBLESHOOTING.md +0 -117
  264. package/.claude/docs/guides/NEW_TROUBLESHOOTING.md +0 -99
  265. package/.claude/docs/guides/ROADMAP_TROUBLESHOOTING.md +0 -188
  266. package/.claude/docs/guides/TASK_COMPLETION_MARKING.md +0 -338
  267. package/.claude/docs/guides/TEAM_MODE_GUIDE.md +0 -312
  268. package/.claude/docs/implementation-summary-v7.md +0 -449
  269. package/.claude/docs/spec-format-guide.md +0 -349
  270. package/.claude/docs/state-consolidation-design.md +0 -323
  271. package/.claude/docs/templates/ARCHITECTURE_TEMPLATE.md +0 -332
  272. package/.claude/docs/templates/ATTEMPT_TEMPLATE.md +0 -156
  273. package/.claude/docs/templates/BACKLOG_TEMPLATE.md +0 -261
  274. package/.claude/docs/templates/BRAINSTORM_TEMPLATE.md +0 -148
  275. package/.claude/docs/templates/CHECKLIST_TEMPLATE.md +0 -52
  276. package/.claude/docs/templates/CLARIFICATION_REPORT_TEMPLATE.md +0 -206
  277. package/.claude/docs/templates/CODE_REVIEW_TEMPLATE.md +0 -71
  278. package/.claude/docs/templates/DELTA_SPEC_TEMPLATE.md +0 -91
  279. package/.claude/docs/templates/DESIGN_DECISIONS_TEMPLATE.md +0 -151
  280. package/.claude/docs/templates/DESIGN_TEMPLATE.md +0 -157
  281. package/.claude/docs/templates/ERROR_LOG_TEMPLATE.md +0 -80
  282. package/.claude/docs/templates/INIT_FLOW_TEMPLATE.md +0 -198
  283. package/.claude/docs/templates/INTENT_CLARIFICATION_TEMPLATE.md +0 -57
  284. package/.claude/docs/templates/JOURNAL_TEMPLATE.md +0 -75
  285. package/.claude/docs/templates/NEW_ORCHESTRATION_TEMPLATE.md +0 -76
  286. package/.claude/docs/templates/PROPOSAL_TEMPLATE.md +0 -91
  287. package/.claude/docs/templates/RESEARCH_TEMPLATE.md +0 -276
  288. package/.claude/docs/templates/REVIEW-HIGH.md +0 -57
  289. package/.claude/docs/templates/ROADMAP_DIALOGUE_TEMPLATE.md +0 -198
  290. package/.claude/docs/templates/ROADMAP_TEMPLATE.md +0 -310
  291. package/.claude/docs/templates/SPEC_TEMPLATE_DELTA.md +0 -139
  292. package/.claude/docs/templates/SPEC_TEMPLATE_PROJECT.md +0 -93
  293. package/.claude/docs/templates/STYLE_TEMPLATE.md +0 -479
  294. package/.claude/docs/templates/UI_PROTOTYPE_TEMPLATE.md +0 -373
  295. package/.claude/docs/templates/_shared/CLAUDE.md +0 -36
  296. package/.claude/docs/templates/_shared/CONSTITUTION_CHECK.md +0 -125
  297. package/.claude/docs/templates/_shared/VALIDATION_CHECKLIST.md +0 -187
  298. package/.claude/docs/templates/_shared/YAML_FRONTMATTER.md +0 -164
  299. package/.claude/docs/templates/context/dev.jsonl.template +0 -6
  300. package/.claude/docs/templates/context/epic.jsonl.template +0 -5
  301. package/.claude/docs/templates/context/prd.jsonl.template +0 -4
  302. package/.claude/docs/templates/context/research.jsonl.template +0 -4
  303. package/.claude/docs/templates/context/review.jsonl.template +0 -5
  304. package/.claude/docs/templates/context/tech.jsonl.template +0 -5
  305. package/.claude/guides/agent-guides/agent-coordination-guide.md +0 -459
  306. package/.claude/guides/project-guidelines-system.md +0 -463
  307. package/.claude/guides/technical-guides/datetime-handling-guide.md +0 -563
  308. package/.claude/guides/technical-guides/git-github-guide.md +0 -642
  309. package/.claude/guides/technical-guides/test-execution-guide.md +0 -618
  310. package/.claude/guides/workflow-guides/bug-fix-orchestrator.md +0 -217
  311. package/.claude/guides/workflow-guides/flow-orchestrator.md +0 -48
  312. package/.claude/hooks/CLAUDE.md +0 -342
  313. package/.claude/hooks/checklist-gate.js +0 -397
  314. package/.claude/hooks/error-handling-reminder.sh +0 -12
  315. package/.claude/hooks/error-handling-reminder.ts +0 -459
  316. package/.claude/hooks/hooks.json +0 -15
  317. package/.claude/hooks/inject-agent-context.ts +0 -480
  318. package/.claude/hooks/inject-skill-context.ts +0 -359
  319. package/.claude/hooks/post-tool-use-tracker.sh +0 -280
  320. package/.claude/hooks/pre-tool-use-guardrail.sh +0 -36
  321. package/.claude/hooks/pre-tool-use-guardrail.ts +0 -342
  322. package/.claude/hooks/ralph-loop.ts +0 -931
  323. package/.claude/hooks/ralph-stop-hook.sh +0 -190
  324. package/.claude/hooks/skill-activation-prompt.sh +0 -36
  325. package/.claude/hooks/skill-activation-prompt.ts +0 -214
  326. package/.claude/hooks/state/skills-used-test-guard.json +0 -3
  327. package/.claude/hooks/task-completed-hook.ts +0 -593
  328. package/.claude/hooks/teammate-idle-hook.ts +0 -690
  329. package/.claude/hooks/types/team-types.d.ts +0 -238
  330. package/.claude/rules/devflow-conventions.md +0 -286
  331. package/.claude/rules/project-constitution.md +0 -1002
  332. package/.claude/rules/rationalization-library.md +0 -282
  333. package/.claude/schemas/constitution.schema.json +0 -43
  334. package/.claude/scripts/.claude/commands/flow/export-openspec.md +0 -221
  335. package/.claude/scripts/.claude/commands/flow/import-openspec.md +0 -171
  336. package/.claude/scripts/CLAUDE.md +0 -76
  337. package/.claude/scripts/__tests__/openspec.test.js +0 -212
  338. package/.claude/scripts/analyze-upgrade-impact.sh +0 -200
  339. package/.claude/scripts/archive-requirement.sh +0 -394
  340. package/.claude/scripts/calculate-checklist-completion.sh +0 -243
  341. package/.claude/scripts/calculate-quarter.sh +0 -206
  342. package/.claude/scripts/check-dependencies.sh +0 -409
  343. package/.claude/scripts/check-prerequisites.sh +0 -232
  344. package/.claude/scripts/check-task-status.sh +0 -288
  345. package/.claude/scripts/checklist-errors.sh +0 -131
  346. package/.claude/scripts/common.sh +0 -1102
  347. package/.claude/scripts/consolidate-research.sh +0 -182
  348. package/.claude/scripts/create-requirement.sh +0 -451
  349. package/.claude/scripts/delta-parser.ts +0 -637
  350. package/.claude/scripts/detect-file-conflicts.sh +0 -151
  351. package/.claude/scripts/export-contracts.sh +0 -117
  352. package/.claude/scripts/export-openspec.js +0 -222
  353. package/.claude/scripts/extract-data-model.sh +0 -78
  354. package/.claude/scripts/flow-context-add.sh +0 -134
  355. package/.claude/scripts/flow-context-init.sh +0 -133
  356. package/.claude/scripts/flow-context-validate.sh +0 -144
  357. package/.claude/scripts/flow-delta-apply.sh +0 -297
  358. package/.claude/scripts/flow-delta-archive.sh +0 -71
  359. package/.claude/scripts/flow-delta-create.sh +0 -202
  360. package/.claude/scripts/flow-delta-list.sh +0 -142
  361. package/.claude/scripts/flow-delta-status.sh +0 -235
  362. package/.claude/scripts/flow-quality-full.sh +0 -215
  363. package/.claude/scripts/flow-quality-quick.sh +0 -119
  364. package/.claude/scripts/flow-workspace-init.sh +0 -117
  365. package/.claude/scripts/flow-workspace-record.sh +0 -164
  366. package/.claude/scripts/generate-clarification-questions.sh +0 -377
  367. package/.claude/scripts/generate-clarification-report.sh +0 -463
  368. package/.claude/scripts/generate-quickstart.sh +0 -146
  369. package/.claude/scripts/generate-research-tasks.sh +0 -157
  370. package/.claude/scripts/generate-status-report.sh +0 -523
  371. package/.claude/scripts/generate-tech-analysis.sh +0 -46
  372. package/.claude/scripts/get-workflow-status.sh +0 -415
  373. package/.claude/scripts/import-openspec.js +0 -272
  374. package/.claude/scripts/locate-requirement-in-roadmap.sh +0 -233
  375. package/.claude/scripts/manage-constitution.sh +0 -602
  376. package/.claude/scripts/mark-task-complete.sh +0 -198
  377. package/.claude/scripts/parse-task-dependencies.js +0 -334
  378. package/.claude/scripts/populate-research-tasks.sh +0 -284
  379. package/.claude/scripts/record-quality-error.sh +0 -165
  380. package/.claude/scripts/recover-workflow.sh +0 -463
  381. package/.claude/scripts/run-clarify-scan.sh +0 -601
  382. package/.claude/scripts/run-high-review.sh +0 -62
  383. package/.claude/scripts/run-problem-analysis.sh +0 -68
  384. package/.claude/scripts/run-quality-gates.sh +0 -242
  385. package/.claude/scripts/setup-epic.sh +0 -173
  386. package/.claude/scripts/setup-ralph-loop.sh +0 -155
  387. package/.claude/scripts/sync-roadmap-progress.sh +0 -300
  388. package/.claude/scripts/sync-task-marks.sh +0 -199
  389. package/.claude/scripts/team-dev-init.sh +0 -319
  390. package/.claude/scripts/team-state-recovery.sh +0 -229
  391. package/.claude/scripts/test-clarify-scan.sh +0 -515
  392. package/.claude/scripts/update-agent-context.sh +0 -806
  393. package/.claude/scripts/validate-constitution.sh +0 -567
  394. package/.claude/scripts/validate-hooks.sh +0 -487
  395. package/.claude/scripts/validate-research.sh +0 -332
  396. package/.claude/scripts/validate-scope-boundary.sh +0 -493
  397. package/.claude/scripts/validate-scope.sh +0 -200
  398. package/.claude/scripts/verify-gate.sh +0 -269
  399. package/.claude/scripts/verify-setup.sh +0 -37
  400. package/.claude/scripts/workflow-status.ts +0 -433
  401. package/.claude/settings.json +0 -95
  402. package/.claude/skills/_reference-implementations/README.md +0 -96
  403. package/.claude/skills/_reference-implementations/backend-express-prisma/SKILL.md +0 -302
  404. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/architecture-overview.md +0 -451
  405. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/async-and-errors.md +0 -307
  406. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/complete-examples.md +0 -638
  407. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/configuration.md +0 -275
  408. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/database-patterns.md +0 -224
  409. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/middleware-guide.md +0 -213
  410. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/routing-and-controllers.md +0 -756
  411. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/sentry-and-monitoring.md +0 -336
  412. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/services-and-repositories.md +0 -789
  413. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/testing-guide.md +0 -235
  414. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/validation-patterns.md +0 -754
  415. package/.claude/skills/_reference-implementations/frontend-react-mui/SKILL.md +0 -399
  416. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/common-patterns.md +0 -331
  417. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/complete-examples.md +0 -872
  418. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/component-patterns.md +0 -502
  419. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/data-fetching.md +0 -767
  420. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/file-organization.md +0 -502
  421. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/loading-and-error-states.md +0 -501
  422. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/performance.md +0 -406
  423. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/routing-guide.md +0 -364
  424. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/styling-guide.md +0 -428
  425. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/typescript-standards.md +0 -418
  426. package/.claude/skills/attention-refresh/SKILL.md +0 -170
  427. package/.claude/skills/brainstorming/SKILL.md +0 -161
  428. package/.claude/skills/cc-devflow-orchestrator/SKILL.md +0 -169
  429. package/.claude/skills/constitution-guardian/SKILL.md +0 -306
  430. package/.claude/skills/constitution-quick-ref/SKILL.md +0 -374
  431. package/.claude/skills/debugging/SKILL.md +0 -221
  432. package/.claude/skills/file-standards/SKILL.md +0 -353
  433. package/.claude/skills/finishing-branch/SKILL.md +0 -189
  434. package/.claude/skills/flow-dev/CLAUDE.md +0 -16
  435. package/.claude/skills/flow-dev/SKILL.md +0 -94
  436. package/.claude/skills/flow-dev/assets/IMPLEMENTATION_PLAN_TEMPLATE.md +0 -71
  437. package/.claude/skills/flow-dev/context.jsonl +0 -4
  438. package/.claude/skills/flow-dev/dev-implementer.jsonl +0 -8
  439. package/.claude/skills/flow-dev/scripts/entry-gate.sh +0 -116
  440. package/.claude/skills/flow-dev/scripts/exit-gate.sh +0 -101
  441. package/.claude/skills/flow-dev/scripts/task-orchestrator.sh +0 -106
  442. package/.claude/skills/flow-fix/SKILL.md +0 -105
  443. package/.claude/skills/flow-fix/context.jsonl +0 -6
  444. package/.claude/skills/flow-fix/references/bug-analyzer.md +0 -381
  445. package/.claude/skills/flow-init/SKILL.md +0 -105
  446. package/.claude/skills/flow-init/assets/BRAINSTORM_TEMPLATE.md +0 -148
  447. package/.claude/skills/flow-init/assets/INIT_FLOW_TEMPLATE.md +0 -198
  448. package/.claude/skills/flow-init/assets/RESEARCH_TEMPLATE.md +0 -276
  449. package/.claude/skills/flow-init/context.jsonl +0 -5
  450. package/.claude/skills/flow-init/references/flow-researcher.md +0 -132
  451. package/.claude/skills/flow-init/scripts/check-prerequisites.sh +0 -240
  452. package/.claude/skills/flow-init/scripts/consolidate-research.sh +0 -182
  453. package/.claude/skills/flow-init/scripts/create-requirement.sh +0 -404
  454. package/.claude/skills/flow-init/scripts/generate-research-tasks.sh +0 -157
  455. package/.claude/skills/flow-init/scripts/populate-research-tasks.sh +0 -284
  456. package/.claude/skills/flow-init/scripts/validate-research.sh +0 -340
  457. package/.claude/skills/flow-quality/SKILL.md +0 -98
  458. package/.claude/skills/flow-quality/context.jsonl +0 -6
  459. package/.claude/skills/flow-quality/references/code-quality-reviewer.md +0 -205
  460. package/.claude/skills/flow-quality/references/qa-tester.md +0 -313
  461. package/.claude/skills/flow-quality/references/security-reviewer.md +0 -314
  462. package/.claude/skills/flow-quality/references/spec-reviewer.md +0 -221
  463. package/.claude/skills/flow-release/SKILL.md +0 -60
  464. package/.claude/skills/flow-release/context.jsonl +0 -5
  465. package/.claude/skills/flow-release/references/release-manager.md +0 -295
  466. package/.claude/skills/flow-spec/CLAUDE.md +0 -17
  467. package/.claude/skills/flow-spec/SKILL.md +0 -102
  468. package/.claude/skills/flow-spec/context.jsonl +0 -5
  469. package/.claude/skills/flow-spec/scripts/entry-gate.sh +0 -194
  470. package/.claude/skills/flow-spec/scripts/exit-gate.sh +0 -244
  471. package/.claude/skills/flow-spec/scripts/parallel-orchestrator.sh +0 -205
  472. package/.claude/skills/flow-spec/scripts/team-communication.sh +0 -353
  473. package/.claude/skills/flow-spec/scripts/team-init.sh +0 -195
  474. package/.claude/skills/flow-spec/scripts/test-team-mode.sh +0 -496
  475. package/.claude/skills/flow-spec/team-config.json +0 -165
  476. package/.claude/skills/flow-verify/CLAUDE.md +0 -10
  477. package/.claude/skills/flow-verify/SKILL.md +0 -53
  478. package/.claude/skills/flow-verify/context.jsonl +0 -5
  479. package/.claude/skills/fractal-docs/SKILL.md +0 -45
  480. package/.claude/skills/journey-checker/SKILL.md +0 -199
  481. package/.claude/skills/journey-checker/pressure-scenarios.md +0 -164
  482. package/.claude/skills/receiving-review/SKILL.md +0 -153
  483. package/.claude/skills/skill-creator/LICENSE.txt +0 -202
  484. package/.claude/skills/skill-creator/SKILL.md +0 -356
  485. package/.claude/skills/skill-creator/references/output-patterns.md +0 -82
  486. package/.claude/skills/skill-creator/references/workflows.md +0 -28
  487. package/.claude/skills/skill-creator/scripts/init_skill.py +0 -303
  488. package/.claude/skills/skill-creator/scripts/package_skill.py +0 -110
  489. package/.claude/skills/skill-creator/scripts/quick_validate.py +0 -95
  490. package/.claude/skills/skill-rules.json +0 -359
  491. package/.claude/skills/tdd/SKILL.md +0 -218
  492. package/.claude/skills/tdd-enforcer/SKILL.md +0 -192
  493. package/.claude/skills/utility/npm-release/CLAUDE.md +0 -55
  494. package/.claude/skills/utility/npm-release/SKILL.md +0 -379
  495. package/.claude/skills/utility/npm-release/references/version-decision-guide.md +0 -134
  496. package/.claude/skills/utility/npm-release/scripts/atomic-version-bump.sh +0 -95
  497. package/.claude/skills/utility/npm-release/scripts/validate-version-sync.sh +0 -82
  498. package/.claude/skills/utility/npm-release/scripts/version-decision-tree.sh +0 -44
  499. package/.claude/skills/verification/SKILL.md +0 -158
  500. package/.claude/skills/workflow.yaml +0 -219
  501. package/.claude/tests/README.md +0 -300
  502. package/.claude/tests/TODO.md +0 -69
  503. package/.claude/tests/__pycache__/test_analyze_upgrade_impact.cpython-311-pytest-7.2.2.pyc +0 -0
  504. package/.claude/tests/__pycache__/test_consolidate_research.cpython-311-pytest-7.2.2.pyc +0 -0
  505. package/.claude/tests/__pycache__/test_export_contracts.cpython-311-pytest-7.2.2.pyc +0 -0
  506. package/.claude/tests/__pycache__/test_extract_data_model.cpython-311-pytest-7.2.2.pyc +0 -0
  507. package/.claude/tests/__pycache__/test_generate_quickstart.cpython-311-pytest-7.2.2.pyc +0 -0
  508. package/.claude/tests/__pycache__/test_generate_research_tasks.cpython-311-pytest-7.2.2.pyc +0 -0
  509. package/.claude/tests/constitution/run_all_constitution_tests.sh +0 -111
  510. package/.claude/tests/constitution/test_agent_assignment.sh +0 -207
  511. package/.claude/tests/constitution/test_article_coverage.sh +0 -201
  512. package/.claude/tests/constitution/test_template_completeness.sh +0 -150
  513. package/.claude/tests/constitution/test_version_consistency.sh +0 -120
  514. package/.claude/tests/fixtures/spec_delta_full.md +0 -16
  515. package/.claude/tests/fixtures/tasks_progress_sample.md +0 -5
  516. package/.claude/tests/run-all-tests.sh +0 -229
  517. package/.claude/tests/scripts/run.sh +0 -30
  518. package/.claude/tests/scripts/test-framework.sh +0 -128
  519. package/.claude/tests/scripts/test_check_prerequisites.sh +0 -511
  520. package/.claude/tests/scripts/test_check_prerequisites.sh.bak +0 -504
  521. package/.claude/tests/scripts/test_check_prerequisites.sh.bak2 +0 -505
  522. package/.claude/tests/scripts/test_check_prerequisites.sh.bak3 +0 -506
  523. package/.claude/tests/scripts/test_check_prerequisites.sh.bak4 +0 -507
  524. package/.claude/tests/scripts/test_check_prerequisites.sh.bak5 +0 -508
  525. package/.claude/tests/scripts/test_check_task_status.sh +0 -499
  526. package/.claude/tests/scripts/test_common.sh +0 -244
  527. package/.claude/tests/scripts/test_generate_status_report.sh +0 -71
  528. package/.claude/tests/scripts/test_mark_task_complete.sh +0 -441
  529. package/.claude/tests/scripts/test_mark_task_complete.sh.backup +0 -410
  530. package/.claude/tests/scripts/test_recover_workflow.sh +0 -304
  531. package/.claude/tests/scripts/test_setup_epic.sh +0 -437
  532. package/.claude/tests/scripts/test_sync_task_marks.sh +0 -196
  533. package/.claude/tests/scripts/test_validate_constitution.sh +0 -74
  534. package/.claude/tests/scripts/test_validate_research.sh +0 -462
  535. package/.claude/tests/slugify.bats +0 -82
  536. package/.claude/tests/test-framework.sh +0 -732
  537. package/.claude/tests/test_analyze_upgrade_impact.py +0 -34
  538. package/.claude/tests/test_consolidate_research.py +0 -48
  539. package/.claude/tests/test_export_contracts.py +0 -43
  540. package/.claude/tests/test_extract_data_model.py +0 -33
  541. package/.claude/tests/test_generate_quickstart.py +0 -50
  542. package/.claude/tests/test_generate_research_tasks.py +0 -52
  543. package/.claude/tsc-cache/70d2fc6d-2936-429b-b529-429f1aae8c88/affected-repos.txt +0 -1
  544. package/.claude/tsc-cache/70d2fc6d-2936-429b-b529-429f1aae8c88/edited-files.log +0 -2
  545. package/bin/harness.js +0 -22
  546. package/docs/commands/core-roadmap.md +0 -106
  547. package/docs/commands/core-roadmap.zh-CN.md +0 -102
  548. package/docs/commands/core-style.md +0 -53
  549. package/docs/commands/core-style.zh-CN.md +0 -53
  550. package/docs/commands/flow-init.md +0 -140
  551. package/docs/commands/flow-init.zh-CN.md +0 -169
  552. package/docs/commands/flow-new.md +0 -39
  553. package/docs/commands/flow-new.zh-CN.md +0 -39
  554. package/lib/compiler/__tests__/compile-regression.test.js +0 -103
  555. package/lib/compiler/__tests__/multi-module-emitters.test.js +0 -534
  556. package/lib/compiler/__tests__/resource-copier.test.js +0 -26
  557. package/lib/compiler/__tests__/skill-discovery.test.js +0 -72
  558. package/lib/compiler/context-expander.js +0 -179
  559. package/lib/compiler/rules-emitters/__tests__/codex-rules-emitter.test.js +0 -109
  560. package/lib/compiler/rules-emitters/codex-rules-emitter.js +0 -116
  561. package/lib/compiler/skill-discovery.js +0 -68
  562. package/lib/harness/CLAUDE.md +0 -22
  563. package/lib/harness/__tests__/planner.tdd.test.js +0 -125
  564. package/lib/harness/cli.js +0 -208
  565. package/lib/harness/index.js +0 -18
  566. package/lib/harness/operations/dispatch.js +0 -298
  567. package/lib/harness/operations/init.js +0 -48
  568. package/lib/harness/operations/pack.js +0 -100
  569. package/lib/harness/operations/plan.js +0 -83
  570. package/lib/harness/operations/release.js +0 -170
  571. package/lib/harness/operations/resume.js +0 -44
  572. package/lib/harness/operations/verify.js +0 -177
  573. package/lib/harness/planner.js +0 -272
  574. package/lib/harness/query.js +0 -126
  575. package/lib/harness/schemas.js +0 -129
@@ -1,349 +0,0 @@
1
- # CC-DevFlow spec.md Format Guide
2
-
3
- > **Version**: v4.3.0
4
- > **Purpose**: 定义项目级和需求级 spec.md 的格式规范
5
-
6
- ---
7
-
8
- ## 核心设计原则
9
-
10
- **OpenSpec 复刻**:
11
- - 项目级 `devflow/specs/` = 不可变源代码真相(描述当前系统状态)
12
- - 需求级 `requirements/{REQ}/specs/` = Delta(ADDED/MODIFIED/REMOVED/RENAMED)
13
- - 归档时自动合并 Delta 到项目级
14
-
15
- **关键区别**:
16
- - ❌ 错误理解:每个需求有自己的 spec.md
17
- - ✅ 正确理解:项目有统一的 specs/,需求通过 Delta 修改它
18
-
19
- ---
20
-
21
- ## 项目级 spec.md 格式
22
-
23
- ### YAML Frontmatter
24
-
25
- ```yaml
26
- ---
27
- module: "auth" # 模块名称
28
- created_at: "2026-01-01T10:00:00Z" # 创建时间
29
- updated_at: "2026-03-12T15:30:00Z" # 最后更新时间
30
- version: "2.1.0" # 语义化版本号
31
- ---
32
- ```
33
-
34
- ### 文档结构
35
-
36
- ```markdown
37
- # {Module Name}
38
-
39
- ## Purpose
40
- {高层描述:这个模块是干什么的}
41
-
42
- ## Requirements
43
-
44
- ### Requirement: {Requirement Name}
45
- The system {SHALL|MUST|SHOULD|MAY} {behavior description}.
46
-
47
- #### Scenario: {Scenario Name}
48
- - GIVEN {precondition}
49
- - WHEN {action}
50
- - THEN {expected result}
51
- - AND {additional assertion}
52
-
53
- ### Requirement: {Another Requirement}
54
- ...
55
-
56
- ## Implementation
57
-
58
- ### API Endpoints
59
- - POST /api/auth/login
60
- - GET /api/auth/verify
61
-
62
- ### Data Model
63
- ```sql
64
- CREATE TABLE users (
65
- id UUID PRIMARY KEY,
66
- email VARCHAR(255) UNIQUE NOT NULL
67
- );
68
- ```
69
-
70
- ### Files
71
- - `src/api/auth/login.ts`
72
- - `src/middleware/jwt.ts`
73
- ```
74
-
75
- ### RFC 2119 关键字
76
-
77
- | 关键字 | 含义 | 用法 |
78
- |--------|------|------|
79
- | SHALL | 必须实现 | 核心功能 |
80
- | MUST | 强制要求 | 安全/合规 |
81
- | SHOULD | 推荐实现 | 最佳实践 |
82
- | MAY | 可选实现 | 增强功能 |
83
-
84
- ### BDD Scenario 格式
85
-
86
- ```markdown
87
- #### Scenario: {场景名称}
88
- - GIVEN {前置条件}
89
- - WHEN {触发动作}
90
- - THEN {预期结果}
91
- - AND {额外断言}
92
- ```
93
-
94
- **示例**:
95
- ```markdown
96
- #### Scenario: Valid credentials
97
- - GIVEN a registered user
98
- - WHEN the user submits valid email and password
99
- - THEN a JWT token is issued
100
- - AND the user is redirected to dashboard
101
- ```
102
-
103
- ---
104
-
105
- ## 需求级 Delta spec.md 格式
106
-
107
- ### YAML Frontmatter
108
-
109
- ```yaml
110
- ---
111
- delta_id: "REQ-123" # 需求 ID
112
- module: "auth" # 目标模块
113
- title: "添加 2FA 支持" # 变更标题
114
- created_at: "2026-03-12T10:00:00Z" # 创建时间
115
- status: "draft" # draft | approved | applied
116
- ---
117
- ```
118
-
119
- ### 文档结构
120
-
121
- ```markdown
122
- # Delta: {变更标题}
123
-
124
- ## Summary
125
- {为什么需要这个变更?简短说明}
126
-
127
- ## ADDED Requirements
128
-
129
- ### Requirement: {New Requirement Name}
130
- The system SHALL {new behavior}.
131
-
132
- #### Scenario: {New Scenario}
133
- - GIVEN ...
134
- - WHEN ...
135
- - THEN ...
136
-
137
- ## MODIFIED Requirements
138
-
139
- ### Requirement: {Existing Requirement Name}
140
- The system SHALL {modified behavior}.
141
- (Previously: {old behavior})
142
-
143
- ## REMOVED Requirements
144
-
145
- ### Requirement: {Removed Requirement Name}
146
- {说明为什么移除}
147
-
148
- ## RENAMED Requirements
149
-
150
- ### Requirement: {Old Name} → {New Name}
151
- {说明为什么重命名}
152
- ```
153
-
154
- ### Delta 操作类型
155
-
156
- | 操作 | 含义 | 示例 |
157
- |------|------|------|
158
- | ADDED | 新增需求 | 添加 2FA 功能 |
159
- | MODIFIED | 修改现有需求 | 会话超时从 60 分钟改为 30 分钟 |
160
- | REMOVED | 删除需求 | 移除已废弃的 OAuth 1.0 支持 |
161
- | RENAMED | 重命名需求 | "User Authentication" → "Multi-Factor Authentication" |
162
-
163
- ---
164
-
165
- ## 完整示例
166
-
167
- ### 项目级 spec.md
168
-
169
- ```markdown
170
- ---
171
- module: "auth"
172
- created_at: "2026-01-01T10:00:00Z"
173
- updated_at: "2026-03-12T15:30:00Z"
174
- version: "2.1.0"
175
- ---
176
-
177
- # Authentication Module
178
-
179
- ## Purpose
180
- Provides secure authentication and session management for the application.
181
-
182
- ## Requirements
183
-
184
- ### Requirement: User Login
185
- The system SHALL allow users to log in with email and password.
186
-
187
- #### Scenario: Valid credentials
188
- - GIVEN a registered user
189
- - WHEN the user submits valid email and password
190
- - THEN a JWT token is issued
191
- - AND the user is redirected to dashboard
192
-
193
- #### Scenario: Invalid credentials
194
- - GIVEN a registered user
195
- - WHEN the user submits invalid password
196
- - THEN an error message is displayed
197
- - AND no token is issued
198
-
199
- ### Requirement: Session Management
200
- The system MUST expire sessions after 30 minutes of inactivity.
201
-
202
- #### Scenario: Idle timeout
203
- - GIVEN an authenticated session
204
- - WHEN 30 minutes pass without activity
205
- - THEN the session is invalidated
206
- - AND the user must re-authenticate
207
-
208
- ## Implementation
209
-
210
- ### API Endpoints
211
- - POST /api/auth/login
212
- - POST /api/auth/logout
213
- - GET /api/auth/verify
214
-
215
- ### Data Model
216
- ```sql
217
- CREATE TABLE users (
218
- id UUID PRIMARY KEY,
219
- email VARCHAR(255) UNIQUE NOT NULL,
220
- password_hash VARCHAR(255) NOT NULL,
221
- created_at TIMESTAMP DEFAULT NOW()
222
- );
223
- ```
224
-
225
- ### Files
226
- - `src/api/auth/login.ts`
227
- - `src/api/auth/logout.ts`
228
- - `src/middleware/jwt.ts`
229
- ```
230
-
231
- ### 需求级 Delta spec.md
232
-
233
- ```markdown
234
- ---
235
- delta_id: "REQ-123"
236
- module: "auth"
237
- title: "添加 2FA 支持"
238
- created_at: "2026-03-12T10:00:00Z"
239
- status: "draft"
240
- ---
241
-
242
- # Delta: 添加 2FA 支持
243
-
244
- ## Summary
245
- 为提高安全性,添加两因素认证支持。用户可选择启用 2FA,登录时需要输入 OTP 验证码。
246
-
247
- ## ADDED Requirements
248
-
249
- ### Requirement: Two-Factor Authentication
250
- The system MUST require a second factor during login for users with 2FA enabled.
251
-
252
- #### Scenario: OTP required
253
- - GIVEN a user with 2FA enabled
254
- - WHEN the user submits valid credentials
255
- - THEN an OTP challenge is presented
256
- - AND the user must enter a valid OTP code
257
-
258
- #### Scenario: OTP validation
259
- - GIVEN a user has entered valid credentials
260
- - WHEN the user submits a valid OTP code
261
- - THEN a JWT token is issued
262
- - AND the user is redirected to dashboard
263
-
264
- #### Scenario: Invalid OTP
265
- - GIVEN a user has entered valid credentials
266
- - WHEN the user submits an invalid OTP code
267
- - THEN an error message is displayed
268
- - AND the user remains on the OTP challenge page
269
-
270
- ## MODIFIED Requirements
271
-
272
- ### Requirement: Session Management
273
- The system SHALL expire sessions after 30 minutes of inactivity.
274
- (Previously: 60 minutes)
275
-
276
- **Rationale**: 缩短超时时间以提高安全性,配合 2FA 使用。
277
-
278
- ## REMOVED Requirements
279
-
280
- None
281
-
282
- ## RENAMED Requirements
283
-
284
- None
285
- ```
286
-
287
- ---
288
-
289
- ## 合并逻辑
290
-
291
- 归档时,`delta-parser.ts` 自动执行以下操作:
292
-
293
- 1. **ADDED**: 追加到项目级 spec.md 的 Requirements 章节
294
- 2. **MODIFIED**: 替换项目级 spec.md 中对应的 Requirement
295
- 3. **REMOVED**: 从项目级 spec.md 中删除对应的 Requirement
296
- 4. **RENAMED**: 重命名项目级 spec.md 中的 Requirement 标题
297
- 5. **Version Bump**: 更新项目级 spec.md 的 version 字段
298
-
299
- ---
300
-
301
- ## 最佳实践
302
-
303
- ### 1. 保持 Delta 最小化
304
- - 只包含本次需求的变更
305
- - 不要在 Delta 中重复现有内容
306
-
307
- ### 2. 使用清晰的 Scenario
308
- - 每个 Scenario 测试一个具体行为
309
- - 使用 Given-When-Then 格式
310
- - 避免模糊的描述
311
-
312
- ### 3. 记录变更原因
313
- - MODIFIED 时说明为什么修改
314
- - REMOVED 时说明为什么移除
315
- - RENAMED 时说明为什么重命名
316
-
317
- ### 4. 版本号规范
318
- - ADDED 新功能 → MINOR 版本号 +1
319
- - MODIFIED 现有功能 → PATCH 版本号 +1
320
- - REMOVED 功能 → MAJOR 版本号 +1(破坏性变更)
321
-
322
- ---
323
-
324
- ## 工具支持
325
-
326
- ### 生成 Delta
327
- ```bash
328
- /flow:spec "REQ-123"
329
- → 生成 devflow/requirements/REQ-123/specs/{module}/spec.md
330
- ```
331
-
332
- ### 验证 Delta
333
- ```bash
334
- /flow:validate-scope "REQ-123"
335
- → 检测需求偏移,生成 scope-creep-report.md
336
- ```
337
-
338
- ### 合并 Delta
339
- ```bash
340
- /flow:release "REQ-123"
341
- → 自动合并 Delta 到 devflow/specs/{module}/spec.md
342
- → 更新版本号
343
- → 归档需求
344
- ```
345
-
346
- ---
347
-
348
- **Last Updated**: 2026-03-12
349
- **Version**: v4.3.0
@@ -1,323 +0,0 @@
1
- # State Consolidation Design (Task #10 重新设计)
2
-
3
- > **Version**: 1.0.0
4
- > **Date**: 2026-03-12
5
- > **Status**: Design Proposal
6
-
7
- ---
8
-
9
- ## 问题诊断
10
-
11
- ### 现象层
12
- Task #10 原始设计要求创建统一的 `.harness/state.json`,合并:
13
- - `orchestration_status.json`
14
- - `session-checklist.json`
15
- - `session-progress.md`
16
- - `session-handoff.md`
17
-
18
- ### 本质层
19
- 这个设计与 v6.0 Harness-First 架构冲突:
20
- - v6.0 已经实现了**关注点分离**
21
- - 将所有状态塞入一个文件违反了单一职责原则
22
- - 真正的问题是**旧文件未被废弃**,而非需要新的统一文件
23
-
24
- ### 哲学层
25
- **单一真相源 ≠ 单一文件**
26
-
27
- 正确的架构:
28
- ```
29
- harness-state.json → 生命周期状态 (initialized/released)
30
- task-manifest.json → 任务定义与进度 (tasks[].status)
31
- checkpoint.json → 会话恢复点 (per task)
32
- report-card.json → 质量验证结果
33
- ```
34
-
35
- ---
36
-
37
- ## v6.0 当前架构分析
38
-
39
- ### 1. harness-state.json (核心生命周期)
40
- ```json
41
- {
42
- "changeId": "REQ-123",
43
- "goal": "Deliver REQ-123 safely",
44
- "status": "initialized|released",
45
- "initializedAt": "2026-03-12T10:00:00Z",
46
- "releasedAt": "2026-03-12T15:00:00Z",
47
- "updatedAt": "2026-03-12T15:00:00Z"
48
- }
49
- ```
50
-
51
- **职责**:
52
- - 需求的生命周期状态
53
- - 初始化和发布时间戳
54
- - 不包含任务细节
55
-
56
- ### 2. task-manifest.json (任务定义与进度)
57
- ```json
58
- {
59
- "changeId": "REQ-123",
60
- "goal": "...",
61
- "createdAt": "...",
62
- "updatedAt": "...",
63
- "tasks": [
64
- {
65
- "id": "T001",
66
- "title": "...",
67
- "status": "pending|running|passed|failed",
68
- "attempts": 0,
69
- "maxRetries": 1,
70
- "dependsOn": [],
71
- "touches": [],
72
- "run": [],
73
- "checks": []
74
- }
75
- ],
76
- "metadata": {
77
- "source": "TASKS.md",
78
- "generatedBy": "harness:plan"
79
- }
80
- }
81
- ```
82
-
83
- **职责**:
84
- - 任务定义(依赖、文件、命令)
85
- - 任务执行状态(pending/running/passed/failed)
86
- - 重试次数和错误信息
87
- - **已经包含了 progress 信息**(completedTasks = tasks.filter(t => t.status === 'passed').length)
88
-
89
- ### 3. checkpoint.json (会话恢复)
90
- ```json
91
- {
92
- "changeId": "REQ-123",
93
- "taskId": "T001",
94
- "sessionId": "session-abc123",
95
- "status": "passed",
96
- "summary": "Task completed successfully",
97
- "timestamp": "2026-03-12T10:30:00Z",
98
- "attempt": 0
99
- }
100
- ```
101
-
102
- **职责**:
103
- - 每个任务的检查点
104
- - 会话恢复信息
105
- - 任务执行摘要
106
-
107
- ### 4. report-card.json (质量验证)
108
- ```json
109
- {
110
- "changeId": "REQ-123",
111
- "overall": "pass|fail",
112
- "quickGates": [...],
113
- "strictGates": [...],
114
- "review": {...},
115
- "blockingFindings": [],
116
- "timestamp": "..."
117
- }
118
- ```
119
-
120
- **职责**:
121
- - 质量门禁结果
122
- - 阻塞性问题列表
123
-
124
- ---
125
-
126
- ## 旧文件映射分析
127
-
128
- ### orchestration_status.json → 已被替代
129
- ```json
130
- {
131
- "reqId": "REQ-006",
132
- "status": "release_complete", // → harness-state.json: status
133
- "phase": "release", // → harness-state.json: status
134
- "completedSteps": [...], // → task-manifest.json: tasks[].status
135
- "documents": {...}, // → 文件系统本身就是真相源
136
- "research": {...}, // → 文件系统
137
- "createdAt": "...", // → harness-state.json: initializedAt
138
- "updatedAt": "...", // → harness-state.json: updatedAt
139
- "prUrl": "..." // → 不属于 harness 职责
140
- }
141
- ```
142
-
143
- **结论**:orchestration_status.json 是冗余的,所有信息已在新架构中表达。
144
-
145
- ### session-checklist.json → 已被替代
146
- ```json
147
- {
148
- "flow:init": { "passes": true },
149
- "flow:spec": { "passes": false }
150
- }
151
- ```
152
-
153
- **映射**:
154
- - `flow:init.passes` → harness-state.json: status === 'initialized'
155
- - `flow:spec.passes` → task-manifest.json 存在且有效
156
-
157
- **结论**:session-checklist.json 是冗余的。
158
-
159
- ### session-progress.md → 可生成
160
- ```markdown
161
- ## Progress
162
- - Total Tasks: 6
163
- - Completed: 2
164
- - Failed: 0
165
- ```
166
-
167
- **映射**:
168
- ```javascript
169
- const manifest = readJson('task-manifest.json');
170
- const totalTasks = manifest.tasks.length;
171
- const completedTasks = manifest.tasks.filter(t => t.status === 'passed').length;
172
- const failedTasks = manifest.tasks.filter(t => t.status === 'failed').length;
173
- ```
174
-
175
- **结论**:session-progress.md 可从 task-manifest.json 实时生成,无需存储。
176
-
177
- ### session-handoff.md → 可生成
178
- ```markdown
179
- ## Next Steps
180
- - Continue from Task T003
181
- - Review checkpoint at ...
182
- ```
183
-
184
- **映射**:
185
- ```javascript
186
- const manifest = readJson('task-manifest.json');
187
- const nextTask = manifest.tasks.find(t => t.status === 'pending');
188
- const lastCheckpoint = readJson(`checkpoint-${lastTaskId}.json`);
189
- ```
190
-
191
- **结论**:session-handoff.md 可从 task-manifest.json + checkpoint.json 生成。
192
-
193
- ---
194
-
195
- ## 正确的实现策略
196
-
197
- ### Phase 1: 废弃旧文件(不破坏兼容性)
198
-
199
- 1. **标记为 deprecated**:
200
- - 在 flow-init/flow-spec skills 中移除对 session-* 文件的引用
201
- - 添加迁移警告:检测到旧文件时输出 deprecation warning
202
-
203
- 2. **迁移脚本**(可选):
204
- ```bash
205
- # .claude/scripts/migrate-legacy-state.sh
206
- # 将 orchestration_status.json 转换为 harness-state.json
207
- ```
208
-
209
- ### Phase 2: 增强 harness-state.json(最小化扩展)
210
-
211
- 当前 harness-state.json 已经足够简洁,只需添加一个可选字段:
212
-
213
- ```json
214
- {
215
- "changeId": "REQ-123",
216
- "goal": "...",
217
- "status": "initialized|planned|in_progress|verified|released",
218
- "initializedAt": "...",
219
- "plannedAt": "...", // 新增:plan 完成时间
220
- "verifiedAt": "...", // 新增:verify 完成时间
221
- "releasedAt": "...",
222
- "updatedAt": "..."
223
- }
224
- ```
225
-
226
- **新增状态**:
227
- - `planned` - harness:plan 完成后
228
- - `in_progress` - harness:dispatch 开始后
229
- - `verified` - harness:verify 通过后
230
-
231
- ### Phase 3: 提供查询工具
232
-
233
- 创建辅助函数从分散的文件中聚合信息:
234
-
235
- ```javascript
236
- // lib/harness/query.js
237
-
238
- async function getProgress(repoRoot, changeId) {
239
- const manifest = await readJson(getTaskManifestPath(repoRoot, changeId));
240
- return {
241
- totalTasks: manifest.tasks.length,
242
- completedTasks: manifest.tasks.filter(t => t.status === 'passed').length,
243
- failedTasks: manifest.tasks.filter(t => t.status === 'failed').length,
244
- pendingTasks: manifest.tasks.filter(t => t.status === 'pending').length
245
- };
246
- }
247
-
248
- async function getNextTask(repoRoot, changeId) {
249
- const manifest = await readJson(getTaskManifestPath(repoRoot, changeId));
250
- return manifest.tasks.find(t => t.status === 'pending');
251
- }
252
-
253
- async function getFullState(repoRoot, changeId) {
254
- const state = await readJson(getHarnessStatePath(repoRoot, changeId));
255
- const manifest = await readJson(getTaskManifestPath(repoRoot, changeId));
256
- const report = await readJson(getReportCardPath(repoRoot, changeId), null);
257
-
258
- return {
259
- lifecycle: state,
260
- progress: await getProgress(repoRoot, changeId),
261
- nextTask: await getNextTask(repoRoot, changeId),
262
- quality: report
263
- };
264
- }
265
- ```
266
-
267
- ---
268
-
269
- ## 实施计划
270
-
271
- ### Task #10 重新定义
272
-
273
- **目标**:废弃旧状态文件,增强 harness-state.json,提供查询工具
274
-
275
- **步骤**:
276
-
277
- 1. **更新 harness-state.json schema**:
278
- - 添加 `plannedAt`, `verifiedAt` 字段
279
- - 扩展 status 枚举:`initialized|planned|in_progress|verified|released`
280
-
281
- 2. **更新 operations**:
282
- - `plan.js`: 写入 `plannedAt`
283
- - `dispatch.js`: 写入 `status: 'in_progress'`
284
- - `verify.js`: 写入 `verifiedAt`
285
-
286
- 3. **创建查询工具**:
287
- - `lib/harness/query.js`: getProgress, getNextTask, getFullState
288
-
289
- 4. **废弃旧文件引用**:
290
- - 更新 flow-init/flow-spec skills
291
- - 移除 session-* 文件的生成逻辑
292
- - 添加 deprecation warnings
293
-
294
- 5. **文档更新**:
295
- - 更新 CLAUDE.md 说明新架构
296
- - 添加迁移指南
297
-
298
- ---
299
-
300
- ## 验证标准
301
-
302
- - [ ] harness-state.json 包含完整生命周期状态
303
- - [ ] task-manifest.json 包含任务进度
304
- - [ ] query.js 可以聚合所有状态信息
305
- - [ ] flow-init/flow-spec 不再引用 session-* 文件
306
- - [ ] 旧需求(REQ-004/005/006)可以继续工作(向后兼容)
307
-
308
- ---
309
-
310
- ## 总结
311
-
312
- **核心原则**:
313
- 1. 不创建新的臃肿文件
314
- 2. 保持 v6.0 的关注点分离
315
- 3. 通过查询工具聚合信息
316
- 4. 优雅地废弃旧文件
317
-
318
- **哲学**:
319
- > 单一真相源通过**职责分离 + 查询聚合**实现,而非将所有数据塞入一个文件。
320
-
321
- ---
322
-
323
- **[PROTOCOL]**: 变更时更新此头部,然后检查 CLAUDE.md