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
@@ -0,0 +1,333 @@
1
+ /**
2
+ * [INPUT]: 依赖 store 的路径与文件读写能力,依赖 change-state/task-manifest/report-card/checkpoint 作为 durable truth。
3
+ * [OUTPUT]: 对外提供 handoff 级工件生成与 legacy artifact 清理能力。
4
+ * [POS]: skill runtime 的薄 handoff 层,只保留终态交付文件,不再投影中间态 Markdown。
5
+ * [PROTOCOL]: 变更时更新此头部,然后检查 CLAUDE.md
6
+ */
7
+
8
+ const {
9
+ nowIso,
10
+ exists,
11
+ readJson,
12
+ writeText,
13
+ removePath,
14
+ getRuntimeStatePath,
15
+ getTaskManifestPath,
16
+ getReportCardPath,
17
+ getCheckpointPath,
18
+ getReleaseNotePath
19
+ } = require('./store');
20
+ const {
21
+ deriveLifecycleStage,
22
+ summarizeTaskStates,
23
+ getApprovalState,
24
+ deriveLifecycleNextAction,
25
+ isTaskSettledStatus
26
+ } = require('./lifecycle');
27
+ const {
28
+ getChangePaths
29
+ } = require('./paths');
30
+ const {
31
+ getIntentResumeIndexPath,
32
+ getIntentPrBriefPath,
33
+ getIntentHandoffArtifactPaths,
34
+ getLegacyIntentProjectionPaths,
35
+ ensureIntentScaffold
36
+ } = require('./artifacts');
37
+
38
+ function formatList(items, empty = '- None') {
39
+ if (!items || items.length === 0) {
40
+ return empty;
41
+ }
42
+
43
+ return items.map((item) => `- ${item}`).join('\n');
44
+ }
45
+
46
+ function truncateLine(value, max = 120) {
47
+ const normalized = String(value || '').replace(/\s+/g, ' ').trim();
48
+ if (normalized.length <= max) {
49
+ return normalized;
50
+ }
51
+
52
+ return `${normalized.slice(0, max - 3).trimEnd()}...`;
53
+ }
54
+
55
+ function suggestPrTitle(changeId, goal) {
56
+ const prefix = changeId.startsWith('FIX-') ? 'fix' : 'feat';
57
+ return `${prefix}(${changeId.toLowerCase()}): ${truncateLine(goal || changeId, 72)}`;
58
+ }
59
+
60
+ function summarizeGateSection(gates = []) {
61
+ if (!gates.length) {
62
+ return ['- None'];
63
+ }
64
+
65
+ return gates.map((gate) => {
66
+ const duration = typeof gate.durationMs === 'number' ? `${gate.durationMs}ms` : 'n/a';
67
+ return `- ${gate.name}: ${gate.status} (${duration}) via \`${gate.command}\``;
68
+ });
69
+ }
70
+
71
+ async function readLatestCheckpoints(repoRoot, changeId, tasks = []) {
72
+ const checkpoints = [];
73
+
74
+ for (const task of tasks) {
75
+ const checkpoint = await readJson(getCheckpointPath(repoRoot, changeId, task.id), null);
76
+ if (!checkpoint) {
77
+ continue;
78
+ }
79
+
80
+ checkpoints.push({
81
+ taskId: task.id,
82
+ title: task.title,
83
+ status: checkpoint.status,
84
+ timestamp: checkpoint.timestamp,
85
+ summary: checkpoint.summary
86
+ });
87
+ }
88
+
89
+ checkpoints.sort((left, right) => right.timestamp.localeCompare(left.timestamp));
90
+ return checkpoints;
91
+ }
92
+
93
+ async function cleanupLegacyArtifacts(repoRoot, changeId, manifest) {
94
+ const taskIds = (manifest?.tasks || []).map((task) => task.id);
95
+ const change = getChangePaths(repoRoot, changeId);
96
+
97
+ await Promise.all(
98
+ getLegacyIntentProjectionPaths(repoRoot, changeId, taskIds).map((target) => removePath(target))
99
+ );
100
+ await removePath(change.workersDir);
101
+ }
102
+
103
+ async function clearHandoffArtifacts(repoRoot, changeId, keep = null) {
104
+ await Promise.all(
105
+ getIntentHandoffArtifactPaths(repoRoot, changeId)
106
+ .filter((target) => target !== keep)
107
+ .map((target) => removePath(target))
108
+ );
109
+ }
110
+
111
+ async function writeResumeIndex(repoRoot, changeId, state, manifest, report) {
112
+ await ensureIntentScaffold(repoRoot, changeId);
113
+
114
+ const checkpoints = await readLatestCheckpoints(repoRoot, changeId, manifest?.tasks || []);
115
+ const lastGoodCheckpoint = checkpoints.find((checkpoint) => checkpoint.status === 'passed') || checkpoints[0] || null;
116
+ const blockers = [
117
+ ...(manifest?.tasks || [])
118
+ .filter((task) => task.status === 'failed')
119
+ .map((task) => `${task.id}: ${task.lastError || 'Task failed'}`),
120
+ ...(report?.blockingFindings || [])
121
+ ];
122
+ const hasPrBrief = await exists(getIntentPrBriefPath(repoRoot, changeId));
123
+ const hasReleaseNote = await exists(getReleaseNotePath(repoRoot, changeId));
124
+ const stage = deriveLifecycleStage({ state, manifest, report, hasPrBrief });
125
+ const approval = getApprovalState(state, manifest);
126
+ const goal = manifest?.goal || state?.goal || changeId;
127
+ const nextAction = deriveLifecycleNextAction({
128
+ state,
129
+ manifest,
130
+ report,
131
+ hasPrBrief,
132
+ hasReleaseNote
133
+ });
134
+ const resumePath = getIntentResumeIndexPath(repoRoot, changeId);
135
+
136
+ const content = [
137
+ `# Resume Index: ${changeId}`,
138
+ '',
139
+ `- Goal: ${goal}`,
140
+ `- Stage: \`${stage}\``,
141
+ `- Lifecycle: \`${state?.status || 'unknown'}\``,
142
+ `- Approval: \`${approval.status}\``,
143
+ `- Execution Mode: \`${approval.executionMode}\``,
144
+ `- Plan Version: ${manifest?.metadata?.planVersion || 1}`,
145
+ `- Updated At: ${nowIso()}`,
146
+ '',
147
+ '## Last Good Checkpoint',
148
+ '',
149
+ lastGoodCheckpoint
150
+ ? `- \`${lastGoodCheckpoint.taskId}\` ${lastGoodCheckpoint.status} @ ${lastGoodCheckpoint.timestamp} - ${lastGoodCheckpoint.summary}`
151
+ : '- No checkpoint yet',
152
+ '',
153
+ '## Blockers',
154
+ '',
155
+ formatList(blockers, '- None'),
156
+ '',
157
+ '## Next Action',
158
+ '',
159
+ nextAction,
160
+ '',
161
+ '## Durable Truth',
162
+ '',
163
+ formatList([
164
+ `\`devflow/changes/<change>/meta/change-state.json\``,
165
+ `\`devflow/changes/<change>/planning/task-manifest.json\``,
166
+ `\`devflow/changes/<change>/review/report-card.json\``
167
+ ])
168
+ ].join('\n');
169
+
170
+ await clearHandoffArtifacts(repoRoot, changeId, resumePath);
171
+ await writeText(resumePath, `${content}\n`);
172
+
173
+ return {
174
+ goalId: changeId,
175
+ resumePath
176
+ };
177
+ }
178
+
179
+ async function syncIntentPrBrief(repoRoot, changeId) {
180
+ await ensureIntentScaffold(repoRoot, changeId);
181
+
182
+ const [state, manifest, report] = await Promise.all([
183
+ readJson(getRuntimeStatePath(repoRoot, changeId), null),
184
+ readJson(getTaskManifestPath(repoRoot, changeId), null),
185
+ readJson(getReportCardPath(repoRoot, changeId), null)
186
+ ]);
187
+
188
+ if (!manifest) {
189
+ throw new Error(`Cannot prepare PR brief for ${changeId}: task-manifest.json is missing`);
190
+ }
191
+
192
+ if (!report) {
193
+ throw new Error(`Cannot prepare PR brief for ${changeId}: report-card.json is missing`);
194
+ }
195
+
196
+ if (report.overall !== 'pass') {
197
+ throw new Error(`Cannot prepare PR brief for ${changeId}: verification has not passed`);
198
+ }
199
+
200
+ await cleanupLegacyArtifacts(repoRoot, changeId, manifest);
201
+
202
+ const goal = manifest.goal || state?.goal || changeId;
203
+ const summary = summarizeTaskStates(manifest.tasks || []);
204
+ const touchedFiles = [...new Set((manifest.tasks || []).flatMap((task) => task.touches || []))];
205
+ const skippedTasks = (manifest.tasks || []).filter((task) => task.status === 'skipped');
206
+ const checkpointRefs = (manifest.tasks || [])
207
+ .filter((task) => isTaskSettledStatus(task.status))
208
+ .map((task) => `\`${task.id}\` ${task.title} -> \`devflow/changes/<change>/execution/tasks/${task.id}/checkpoint.json\``);
209
+
210
+ const risks = [
211
+ ...((report.review?.status === 'skipped' || report.review?.status === 'blocked')
212
+ ? ['评审门未完全闭环,合并前需要补齐 review 证据。']
213
+ : []),
214
+ ...(skippedTasks.length > 0
215
+ ? [`存在 ${skippedTasks.length} 个 skipped 任务,需要确认是否可接受:${skippedTasks.map((task) => task.id).join(', ')}`]
216
+ : []),
217
+ ...(summary.failed > 0
218
+ ? [`manifest 中仍有 ${summary.failed} 个 failed 任务,PR 前需要重新确认状态一致性。`]
219
+ : []),
220
+ ...(report.blockingFindings || [])
221
+ ];
222
+
223
+ const content = [
224
+ `# PR Brief: ${changeId}`,
225
+ '',
226
+ `- Suggested Title: ${suggestPrTitle(changeId, goal)}`,
227
+ `- Goal: ${goal}`,
228
+ `- Lifecycle: \`${state?.status || 'verified'}\``,
229
+ `- Prepared At: ${nowIso()}`,
230
+ '',
231
+ '## Summary',
232
+ '',
233
+ formatList(
234
+ (manifest.tasks || [])
235
+ .filter((task) => task.status === 'passed')
236
+ .map((task) => `\`${task.id}\` ${task.title}`),
237
+ '- No passed tasks'
238
+ ),
239
+ '',
240
+ '## Verification',
241
+ '',
242
+ `- Verdict: \`${report.verdict || (report.overall === 'pass' ? 'pass' : 'fail')}\``,
243
+ `- Overall: \`${report.overall}\``,
244
+ `- Review: \`${report.review?.status || 'skipped'}\``,
245
+ `- Blocking Findings: ${(report.blockingFindings || []).length}`,
246
+ '',
247
+ '### Quick Gates',
248
+ '',
249
+ ...summarizeGateSection(report.quickGates),
250
+ '',
251
+ '### Strict Gates',
252
+ '',
253
+ ...summarizeGateSection(report.strictGates),
254
+ '',
255
+ '### Review Summary',
256
+ '',
257
+ report.review?.summary || '- None',
258
+ '',
259
+ '## Risks',
260
+ '',
261
+ formatList(risks, '- None captured by verify; remaining risk is merge timing and manual product acceptance.'),
262
+ '',
263
+ '## Rollback',
264
+ '',
265
+ formatList([
266
+ '回滚该变更分支或最终提交栈,然后重新执行 cc-check 的验证命令。',
267
+ touchedFiles.length > 0
268
+ ? `优先检查这些触达文件:${touchedFiles.slice(0, 8).map((file) => `\`${file}\``).join(', ')}${touchedFiles.length > 8 ? ' ...' : ''}`
269
+ : '当前 manifest 未记录触达文件,回滚时以最终 diff 为准。'
270
+ ]),
271
+ '',
272
+ '## Key Artifacts',
273
+ '',
274
+ formatList([
275
+ `\`devflow/changes/<change>/meta/change-state.json\``,
276
+ `\`devflow/changes/<change>/planning/task-manifest.json\``,
277
+ `\`devflow/changes/<change>/review/report-card.json\``,
278
+ ...checkpointRefs
279
+ ]),
280
+ ''
281
+ ].join('\n');
282
+
283
+ const prBriefPath = getIntentPrBriefPath(repoRoot, changeId);
284
+ await clearHandoffArtifacts(repoRoot, changeId, prBriefPath);
285
+ await writeText(prBriefPath, `${content}\n`);
286
+
287
+ return {
288
+ goalId: changeId,
289
+ prBriefPath,
290
+ suggestedTitle: suggestPrTitle(changeId, goal)
291
+ };
292
+ }
293
+
294
+ async function syncIntentMemory(repoRoot, changeId, options = {}) {
295
+ await ensureIntentScaffold(repoRoot, changeId);
296
+
297
+ const [state, manifest, report] = await Promise.all([
298
+ readJson(getRuntimeStatePath(repoRoot, changeId), null),
299
+ readJson(getTaskManifestPath(repoRoot, changeId), null),
300
+ readJson(getReportCardPath(repoRoot, changeId), null)
301
+ ]);
302
+
303
+ await cleanupLegacyArtifacts(repoRoot, changeId, manifest);
304
+
305
+ if (options.handoff === 'resume') {
306
+ return writeResumeIndex(repoRoot, changeId, state, manifest, report);
307
+ }
308
+
309
+ const prBriefPath = getIntentPrBriefPath(repoRoot, changeId);
310
+ const releaseNotePath = getReleaseNotePath(repoRoot, changeId);
311
+ const hasPrBrief = await exists(prBriefPath);
312
+ const hasReleaseNote = await exists(releaseNotePath);
313
+ const stage = deriveLifecycleStage({ state, manifest, report, hasPrBrief });
314
+
315
+ if (hasReleaseNote) {
316
+ await clearHandoffArtifacts(repoRoot, changeId, releaseNotePath);
317
+ } else if (hasPrBrief) {
318
+ await clearHandoffArtifacts(repoRoot, changeId, prBriefPath);
319
+ } else {
320
+ await clearHandoffArtifacts(repoRoot, changeId, null);
321
+ }
322
+
323
+ return {
324
+ goalId: changeId,
325
+ stage,
326
+ resumePath: hasPrBrief || hasReleaseNote ? null : getIntentResumeIndexPath(repoRoot, changeId)
327
+ };
328
+ }
329
+
330
+ module.exports = {
331
+ syncIntentPrBrief,
332
+ syncIntentMemory
333
+ };
@@ -0,0 +1,294 @@
1
+ /**
2
+ * [INPUT]: 依赖 harness-state/task-manifest/report-card 的内存对象,接收 stage 名与任务元数据。
3
+ * [OUTPUT]: 对外提供 lifecycle 阶段判定、approval 解析、下一步动作建议、执行模式归一化与 direct/delegate/team 路由决策。
4
+ * [POS]: skill runtime 的共享生命周期语义层,让 query/intent/autopilot/dispatch 使用同一套运行时词汇与阶段建议。
5
+ * [PROTOCOL]: 变更时更新此头部,然后检查 CLAUDE.md
6
+ */
7
+
8
+ const STAGE_ORDER = [
9
+ 'discover',
10
+ 'converge',
11
+ 'approve',
12
+ 'delegate',
13
+ 'execute',
14
+ 'verify',
15
+ 'document',
16
+ 'prepare-pr',
17
+ 'released'
18
+ ];
19
+
20
+ function normalizeStage(stage) {
21
+ if (!stage) {
22
+ return null;
23
+ }
24
+
25
+ const aliases = {
26
+ init: 'discover',
27
+ snapshot: 'discover',
28
+ plan: 'converge',
29
+ approval: 'approve',
30
+ approved: 'approve',
31
+ 'awaiting-approval': 'approve',
32
+ awaiting_approval: 'approve',
33
+ spec: 'converge',
34
+ dispatch: 'execute',
35
+ resume: 'execute',
36
+ release: 'prepare-pr'
37
+ };
38
+
39
+ return aliases[stage] || stage;
40
+ }
41
+
42
+ function stageIndex(stage) {
43
+ const normalized = normalizeStage(stage);
44
+ if (!normalized) {
45
+ return 0;
46
+ }
47
+
48
+ const index = STAGE_ORDER.indexOf(normalized);
49
+ if (index === -1) {
50
+ throw new Error(`Unknown autopilot stage: ${stage}`);
51
+ }
52
+
53
+ return index;
54
+ }
55
+
56
+ function normalizeExecutionMode(mode) {
57
+ if (['direct', 'delegate', 'team'].includes(mode)) {
58
+ return mode;
59
+ }
60
+
61
+ return 'delegate';
62
+ }
63
+
64
+ function normalizeTaskStatus(status) {
65
+ const aliases = {
66
+ completed: 'passed',
67
+ done: 'passed',
68
+ verified: 'passed'
69
+ };
70
+
71
+ return aliases[status] || status || 'pending';
72
+ }
73
+
74
+ function isTaskCompletedStatus(status) {
75
+ return normalizeTaskStatus(status) === 'passed';
76
+ }
77
+
78
+ function isTaskSettledStatus(status) {
79
+ return isTaskCompletedStatus(status) || status === 'skipped';
80
+ }
81
+
82
+ function summarizeTaskStates(tasks = []) {
83
+ return tasks.reduce(
84
+ (acc, task) => {
85
+ const normalizedStatus = normalizeTaskStatus(task.status);
86
+ acc[normalizedStatus] = (acc[normalizedStatus] || 0) + 1;
87
+ return acc;
88
+ },
89
+ { pending: 0, running: 0, passed: 0, failed: 0, skipped: 0 }
90
+ );
91
+ }
92
+
93
+ function deriveTaskProgress(tasks = []) {
94
+ const summary = summarizeTaskStates(tasks);
95
+
96
+ return {
97
+ totalTasks: tasks.length,
98
+ completedTasks: summary.passed,
99
+ failedTasks: summary.failed,
100
+ pendingTasks: summary.pending,
101
+ runningTasks: summary.running,
102
+ skippedTasks: summary.skipped
103
+ };
104
+ }
105
+
106
+ function listTaskIdsByStatus(tasks = [], status) {
107
+ return tasks
108
+ .filter((task) => task.status === status)
109
+ .map((task) => task.id);
110
+ }
111
+
112
+ function getApprovalState(state, manifest = null) {
113
+ const currentPlanVersion = manifest?.metadata?.planVersion || state?.approval?.planVersion || null;
114
+ const executionMode = normalizeExecutionMode(state?.approval?.executionMode);
115
+ const approvedPlanVersion = state?.approval?.planVersion || null;
116
+ const approved = Boolean(
117
+ currentPlanVersion &&
118
+ state?.approval?.status === 'approved' &&
119
+ approvedPlanVersion === currentPlanVersion
120
+ );
121
+
122
+ return {
123
+ status: approved ? 'approved' : 'pending',
124
+ executionMode,
125
+ planVersion: currentPlanVersion,
126
+ approvedPlanVersion,
127
+ approvedAt: approved ? state?.approval?.approvedAt || null : null
128
+ };
129
+ }
130
+
131
+ function isExecutionApproved(state, manifest) {
132
+ return getApprovalState(state, manifest).status === 'approved';
133
+ }
134
+
135
+ function classifyDelegationMode(task, options = {}) {
136
+ const commandCount = (task.run || []).length + (task.checks || []).length;
137
+ const executionMode = normalizeExecutionMode(
138
+ options.executionMode || options.approval?.executionMode || options.state?.approval?.executionMode
139
+ );
140
+ const teamCandidate = (task.touches || []).length >= 4 || (task.dependsOn || []).length >= 3;
141
+
142
+ if (executionMode === 'direct') {
143
+ return 'direct';
144
+ }
145
+
146
+ if (executionMode === 'team' && teamCandidate) {
147
+ return 'team';
148
+ }
149
+
150
+ if (
151
+ commandCount > 1 ||
152
+ (task.touches || []).length > 1 ||
153
+ (task.dependsOn || []).length > 0 ||
154
+ teamCandidate
155
+ ) {
156
+ return 'delegate';
157
+ }
158
+
159
+ return 'direct';
160
+ }
161
+
162
+ function deriveLifecycleStage({ state, manifest, report, hasPrBrief = false }) {
163
+ const approval = getApprovalState(state, manifest);
164
+
165
+ if (state?.status === 'released') {
166
+ return 'released';
167
+ }
168
+
169
+ if (report?.overall === 'pass' && hasPrBrief) {
170
+ return 'prepare-pr';
171
+ }
172
+
173
+ if (report?.overall === 'pass') {
174
+ return 'document';
175
+ }
176
+
177
+ if (report?.overall === 'fail') {
178
+ return 'verify';
179
+ }
180
+
181
+ if (manifest && approval.status !== 'approved') {
182
+ return 'approve';
183
+ }
184
+
185
+ if (manifest) {
186
+ const summary = summarizeTaskStates(manifest.tasks);
187
+ if (summary.running > 0 || summary.failed > 0 || summary.pending > 0) {
188
+ return state?.status === 'planned' ? 'delegate' : 'execute';
189
+ }
190
+ if (summary.passed > 0 || summary.skipped > 0) {
191
+ return 'verify';
192
+ }
193
+ }
194
+
195
+ if (state?.status === 'planned') {
196
+ return 'delegate';
197
+ }
198
+
199
+ if (state?.status === 'initialized') {
200
+ return 'discover';
201
+ }
202
+
203
+ return 'converge';
204
+ }
205
+
206
+ function describeExecutionNextAction({ failedTaskIds, runningTaskIds, pendingTaskIds, report }) {
207
+ if (failedTaskIds.length > 0) {
208
+ return `优先修复失败任务 ${failedTaskIds.join(', ')},然后从最近稳定 checkpoint 恢复。`;
209
+ }
210
+
211
+ if (runningTaskIds.length > 0) {
212
+ return `检查运行中任务 ${runningTaskIds.join(', ')}。`;
213
+ }
214
+
215
+ if (pendingTaskIds.length > 0) {
216
+ return `继续执行待处理任务 ${pendingTaskIds.join(', ')}。`;
217
+ }
218
+
219
+ if (!report) {
220
+ return '所有任务已完成,进入 cc-check 并同步验证证据。';
221
+ }
222
+
223
+ if (report.overall === 'fail') {
224
+ return '修复 blocking findings 后重新进入 cc-check。';
225
+ }
226
+
227
+ return '验证已通过,按实际路由生成唯一 handoff 文件。';
228
+ }
229
+
230
+ const DEFAULT_NEXT_ACTION = '生成或刷新 task-manifest,然后回到批准闸。';
231
+
232
+ const NEXT_ACTION_RESOLVERS = {
233
+ discover: () => DEFAULT_NEXT_ACTION,
234
+ converge: () => DEFAULT_NEXT_ACTION,
235
+ approve: ({ approval }) => `先批准当前计划版本 ${approval.planVersion || 1},再进入执行。`,
236
+ delegate: describeExecutionNextAction,
237
+ execute: describeExecutionNextAction,
238
+ verify: describeExecutionNextAction,
239
+ document: ({ hasReleaseNote }) => (
240
+ hasReleaseNote
241
+ ? '发布材料已经生成,可归档或启动下一轮增量。'
242
+ : '验证已通过,按实际路由生成唯一 handoff 文件。'
243
+ ),
244
+ 'prepare-pr': ({ hasPrBrief, hasReleaseNote }) => {
245
+ if (hasReleaseNote) {
246
+ return '发布材料已经生成,可归档或启动下一轮增量。';
247
+ }
248
+
249
+ if (hasPrBrief) {
250
+ return 'PR brief 已生成,可直接整理提交并创建 PR。';
251
+ }
252
+
253
+ return '验证已通过,按实际路由生成唯一 handoff 文件。';
254
+ },
255
+ released: () => '发布材料已经生成,可归档或启动下一轮增量。'
256
+ };
257
+
258
+ function deriveLifecycleNextAction({
259
+ state,
260
+ manifest,
261
+ report,
262
+ hasPrBrief = false,
263
+ hasReleaseNote = false
264
+ }) {
265
+ const stage = deriveLifecycleStage({ state, manifest, report, hasPrBrief });
266
+ const resolver = NEXT_ACTION_RESOLVERS[stage] || NEXT_ACTION_RESOLVERS.converge;
267
+
268
+ return resolver({
269
+ approval: getApprovalState(state, manifest),
270
+ report,
271
+ hasPrBrief,
272
+ hasReleaseNote,
273
+ failedTaskIds: listTaskIdsByStatus(manifest?.tasks, 'failed'),
274
+ runningTaskIds: listTaskIdsByStatus(manifest?.tasks, 'running'),
275
+ pendingTaskIds: listTaskIdsByStatus(manifest?.tasks, 'pending')
276
+ });
277
+ }
278
+
279
+ module.exports = {
280
+ STAGE_ORDER,
281
+ normalizeStage,
282
+ stageIndex,
283
+ normalizeExecutionMode,
284
+ normalizeTaskStatus,
285
+ isTaskCompletedStatus,
286
+ isTaskSettledStatus,
287
+ summarizeTaskStates,
288
+ deriveTaskProgress,
289
+ getApprovalState,
290
+ isExecutionApproved,
291
+ classifyDelegationMode,
292
+ deriveLifecycleStage,
293
+ deriveLifecycleNextAction
294
+ };
@@ -0,0 +1,19 @@
1
+ # operations/
2
+ > L2 | 父级: ../CLAUDE.md
3
+
4
+ 阶段分组
5
+ 初始化与快照: `init.js` 创建 runtime 骨架,`snapshot.js` 采集 discover 阶段需要的只读事实。
6
+ 计划与批准: `plan.js` 生成 `task-manifest.json`,`approve.js` 锁定批准版本与执行模式。
7
+ 执行主链: `dispatch.js` 推进当前任务前沿,`resume.js` 从稳定 checkpoint 恢复,`verify.js` 和 `release.js` 负责质量门与发布收口。
8
+ 交接与工人: `prepare-pr.js` 生成唯一 PR brief,`worker.js`/`worker-run.js` 负责本地或 provider worker handoff 与回写。
9
+ 自动驾驶: `autopilot-shared.js`、`autopilot-core.js`、`autopilot-execution.js`、`autopilot.js` 拆开共享语义、阶段判定和执行循环,避免单文件失控。
10
+ 维护类: `janitor.js` 清理过期 runtime 工件,但不改变正在运行任务的真相源。
11
+
12
+ 更新规则
13
+ 这里只记录阶段入口和职责边界,不维护逐文件穷举说明。
14
+ 新增 operation 如果只是归入已有阶段,不改此文档;只有出现新阶段或边界迁移时才更新。
15
+ 阶段入口只保留当前真相源,不为历史别名单独占坑。
16
+
17
+ 法则: 阶段先于文件名·边界先于清单·父级链接稳定
18
+
19
+ [PROTOCOL]: 变更阶段边界或入口约定时更新此头部,然后检查 CLAUDE.md
@@ -0,0 +1,66 @@
1
+ /**
2
+ * [INPUT]: 依赖 change-state/task-manifest 与 handoff memory,同步接收 changeId 与 executionMode。
3
+ * [OUTPUT]: 为当前 plan_version 写入唯一 approval 真相,并返回批准摘要。
4
+ * [POS]: skill runtime 的显式批准入口,专门负责把计划从 converge 推进到可执行态。
5
+ * [PROTOCOL]: 变更时更新此头部,然后检查 CLAUDE.md
6
+ */
7
+
8
+ const {
9
+ nowIso,
10
+ readJson,
11
+ writeJson,
12
+ getRuntimeStatePath,
13
+ getTaskManifestPath
14
+ } = require('../store');
15
+ const { parseRuntimeState, parseManifest } = require('../schemas');
16
+ const { syncIntentMemory } = require('../intent');
17
+ const { normalizeExecutionMode } = require('../lifecycle');
18
+
19
+ async function runApprove({ repoRoot, changeId, executionMode }) {
20
+ const statePath = getRuntimeStatePath(repoRoot, changeId);
21
+ const manifestPath = getTaskManifestPath(repoRoot, changeId);
22
+ const rawState = await readJson(statePath, null);
23
+ const rawManifest = await readJson(manifestPath, null);
24
+
25
+ if (!rawState) {
26
+ throw new Error(`Cannot approve ${changeId}: change-state.json is missing`);
27
+ }
28
+
29
+ if (!rawManifest) {
30
+ throw new Error(`Cannot approve ${changeId}: task-manifest.json is missing`);
31
+ }
32
+
33
+ const state = parseRuntimeState(rawState);
34
+ const manifest = parseManifest(rawManifest);
35
+ const approvedAt = nowIso();
36
+ const nextExecutionMode = normalizeExecutionMode(executionMode || state.approval?.executionMode);
37
+
38
+ await writeJson(statePath, {
39
+ ...state,
40
+ approval: {
41
+ status: 'approved',
42
+ executionMode: nextExecutionMode,
43
+ planVersion: manifest.metadata?.planVersion || 1,
44
+ approvedAt
45
+ },
46
+ updatedAt: approvedAt
47
+ });
48
+
49
+ await syncIntentMemory(repoRoot, changeId, {
50
+ event: 'approval_granted',
51
+ reason: `Plan version ${manifest.metadata?.planVersion || 1} approved for ${nextExecutionMode} execution`
52
+ });
53
+
54
+ return {
55
+ changeId,
56
+ statePath,
57
+ status: 'approved',
58
+ executionMode: nextExecutionMode,
59
+ planVersion: manifest.metadata?.planVersion || 1,
60
+ approvedAt
61
+ };
62
+ }
63
+
64
+ module.exports = {
65
+ runApprove
66
+ };