@howlil/ez-agents 3.5.0 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (382) hide show
  1. package/README.md +735 -537
  2. package/agents/ez-architect-agent.md +267 -0
  3. package/agents/ez-backend-agent.md +303 -0
  4. package/agents/ez-chief-strategist.md +271 -0
  5. package/agents/ez-codebase-mapper.md +770 -770
  6. package/agents/ez-context-manager.md +319 -0
  7. package/agents/ez-debugger.md +1255 -1255
  8. package/agents/ez-design-expert.md +347 -0
  9. package/agents/ez-devops-agent.md +331 -0
  10. package/agents/ez-executor.md +487 -487
  11. package/agents/ez-frontend-agent.md +322 -0
  12. package/agents/ez-phase-researcher.md +553 -553
  13. package/agents/ez-planner.md +1307 -1307
  14. package/agents/ez-product-engineer.md +435 -0
  15. package/agents/ez-project-researcher.md +629 -629
  16. package/agents/ez-qa-agent.md +320 -0
  17. package/agents/ez-release-agent.md +333 -333
  18. package/agents/ez-requirements-agent.md +377 -377
  19. package/agents/ez-roadmapper.md +650 -650
  20. package/agents/ez-technical-writer.md +551 -0
  21. package/agents/ez-ux-expert.md +393 -0
  22. package/agents/ez-verifier.md +579 -579
  23. package/bin/guards/autonomy-guard.cjs +346 -0
  24. package/bin/guards/context-budget-guard.cjs +278 -0
  25. package/bin/guards/hallucination-guard.cjs +380 -0
  26. package/bin/guards/hidden-state-guard.cjs +182 -0
  27. package/bin/guards/team-overhead-guard.cjs +266 -0
  28. package/bin/guards/tool-sprawl-guard.cjs +271 -0
  29. package/bin/lib/analytics/analytics-collector.cjs +86 -0
  30. package/bin/lib/analytics/analytics-reporter.cjs +130 -0
  31. package/bin/lib/analytics/cohort-analyzer.cjs +138 -0
  32. package/bin/lib/analytics/funnel-analyzer.cjs +147 -0
  33. package/bin/lib/analytics/nps-tracker.cjs +147 -0
  34. package/bin/lib/archetype-detector.cjs +289 -0
  35. package/bin/lib/assistant-adapter.cjs +361 -0
  36. package/bin/lib/audit-exec.cjs +175 -0
  37. package/bin/lib/auth.cjs +176 -0
  38. package/bin/lib/backup-service.cjs +422 -0
  39. package/bin/lib/bdd-validator.cjs +622 -0
  40. package/bin/lib/business-flow-mapper.cjs +429 -0
  41. package/bin/lib/circuit-breaker.cjs +276 -0
  42. package/bin/lib/code-complexity-analyzer.cjs +360 -0
  43. package/bin/lib/codebase-analyzer.cjs +241 -0
  44. package/bin/lib/commands.cjs +691 -0
  45. package/bin/lib/config.cjs +236 -0
  46. package/bin/lib/constraint-extractor.cjs +526 -0
  47. package/bin/lib/content-scanner.cjs +238 -0
  48. package/bin/lib/context-cache.cjs +154 -0
  49. package/bin/lib/context-compressor.cjs +102 -0
  50. package/bin/lib/context-deduplicator.cjs +105 -0
  51. package/bin/lib/context-errors.cjs +78 -0
  52. package/bin/lib/context-manager.cjs +338 -0
  53. package/bin/lib/context-metadata-tracker.cjs +140 -0
  54. package/bin/lib/context-relevance-scorer.cjs +99 -0
  55. package/bin/lib/core.cjs +507 -0
  56. package/bin/lib/cost-alerts.cjs +174 -0
  57. package/bin/lib/cost-tracker.cjs +275 -0
  58. package/bin/lib/crash-recovery.cjs +220 -0
  59. package/bin/lib/dependency-graph.cjs +319 -0
  60. package/bin/lib/deploy/deploy-audit-log.cjs +76 -0
  61. package/bin/lib/deploy/deploy-detector.cjs +69 -0
  62. package/bin/lib/deploy/deploy-env-manager.cjs +109 -0
  63. package/bin/lib/deploy/deploy-health-check.cjs +88 -0
  64. package/bin/lib/deploy/deploy-pre-flight.cjs +57 -0
  65. package/bin/lib/deploy/deploy-rollback.cjs +72 -0
  66. package/bin/lib/deploy/deploy-runner.cjs +97 -0
  67. package/bin/lib/deploy/deploy-status.cjs +74 -0
  68. package/bin/lib/discussion-synthesizer.cjs +439 -0
  69. package/bin/lib/error-cache.cjs +114 -0
  70. package/bin/lib/error-registry.cjs +177 -0
  71. package/bin/lib/file-access.cjs +207 -0
  72. package/bin/lib/file-lock.cjs +236 -0
  73. package/bin/lib/finops/budget-enforcer.cjs +126 -0
  74. package/bin/lib/finops/cost-reporter.cjs +132 -0
  75. package/bin/lib/finops/finops-analyzer.cjs +112 -0
  76. package/bin/lib/finops/spot-manager.cjs +118 -0
  77. package/bin/lib/framework-detector.cjs +396 -0
  78. package/bin/lib/frontmatter.cjs +313 -0
  79. package/bin/lib/fs-utils.cjs +153 -0
  80. package/bin/lib/gate-executor.cjs +272 -0
  81. package/bin/lib/gates/README.md +374 -0
  82. package/bin/lib/gates/gate-01-requirement.cjs +303 -0
  83. package/bin/lib/gates/gate-02-architecture.cjs +555 -0
  84. package/bin/lib/gates/gate-03-code.cjs +635 -0
  85. package/bin/lib/gates/gate-04-security.cjs +829 -0
  86. package/bin/lib/git-errors.cjs +83 -0
  87. package/bin/lib/git-utils.cjs +321 -0
  88. package/bin/lib/git-workflow-engine.cjs +1157 -0
  89. package/bin/lib/health-check.cjs +227 -0
  90. package/bin/lib/index.cjs +279 -0
  91. package/bin/lib/init.cjs +725 -0
  92. package/bin/lib/lock-logger.cjs +194 -0
  93. package/bin/lib/lock-state.cjs +263 -0
  94. package/bin/lib/lockfile-validator.cjs +227 -0
  95. package/bin/lib/log-rotation.cjs +71 -0
  96. package/bin/lib/logger.cjs +125 -0
  97. package/bin/lib/memory-compression.cjs +256 -0
  98. package/bin/lib/milestone.cjs +247 -0
  99. package/bin/lib/model-provider.cjs +241 -0
  100. package/bin/lib/package-manager-detector.cjs +203 -0
  101. package/bin/lib/package-manager-executor.cjs +385 -0
  102. package/bin/lib/package-manager-service.cjs +216 -0
  103. package/bin/lib/perf/api-monitor.cjs +88 -0
  104. package/bin/lib/perf/db-optimizer.cjs +78 -0
  105. package/bin/lib/perf/frontend-performance.cjs +56 -0
  106. package/bin/lib/perf/perf-analyzer.cjs +77 -0
  107. package/bin/lib/perf/perf-baseline.cjs +102 -0
  108. package/bin/lib/perf/perf-reporter.cjs +117 -0
  109. package/bin/lib/perf/regression-detector.cjs +92 -0
  110. package/bin/lib/phase.cjs +963 -0
  111. package/bin/lib/planning-write.cjs +123 -0
  112. package/bin/lib/project-reporter.cjs +565 -0
  113. package/bin/lib/quality-gate.cjs +332 -0
  114. package/bin/lib/quality-metrics.cjs +324 -0
  115. package/bin/lib/recovery-manager.cjs +98 -0
  116. package/bin/lib/release-validator.cjs +617 -0
  117. package/bin/lib/retry.cjs +119 -0
  118. package/bin/lib/roadmap.cjs +309 -0
  119. package/bin/lib/safe-exec.cjs +173 -0
  120. package/bin/lib/safe-path.cjs +130 -0
  121. package/bin/lib/security-errors.cjs +62 -0
  122. package/bin/lib/session-chain.cjs +304 -0
  123. package/bin/lib/session-errors.cjs +81 -0
  124. package/bin/lib/session-export.cjs +251 -0
  125. package/bin/lib/session-import.cjs +262 -0
  126. package/bin/lib/session-manager.cjs +280 -0
  127. package/bin/lib/skill-context.cjs +148 -0
  128. package/bin/lib/skill-matcher.cjs +236 -0
  129. package/bin/lib/skill-registry.cjs +360 -0
  130. package/bin/lib/skill-resolver.cjs +449 -0
  131. package/bin/lib/skill-triggers.cjs +90 -0
  132. package/bin/lib/skill-validator.cjs +270 -0
  133. package/bin/lib/skill-versioning.cjs +355 -0
  134. package/bin/lib/stack-detector.cjs +399 -0
  135. package/bin/lib/state.cjs +736 -0
  136. package/bin/lib/tech-debt-analyzer.cjs +309 -0
  137. package/bin/lib/temp-file.cjs +239 -0
  138. package/bin/lib/template.cjs +223 -0
  139. package/bin/lib/test-file-lock.cjs +112 -0
  140. package/bin/lib/test-graceful.cjs +93 -0
  141. package/bin/lib/test-logger.cjs +60 -0
  142. package/bin/lib/test-safe-exec.cjs +38 -0
  143. package/bin/lib/test-safe-path.cjs +33 -0
  144. package/bin/lib/test-temp-file.cjs +125 -0
  145. package/bin/lib/tier-manager.cjs +428 -0
  146. package/bin/lib/timeout-exec.cjs +63 -0
  147. package/bin/lib/tradeoff-analyzer.cjs +284 -0
  148. package/bin/lib/url-fetch.cjs +170 -0
  149. package/bin/lib/verify.cjs +863 -0
  150. package/bin/update.js +217 -214
  151. package/commands/deploy.cjs +53 -0
  152. package/commands/ez/add-tests.md +41 -41
  153. package/commands/ez/audit-milestone.md +36 -36
  154. package/commands/ez/complete-milestone.md +136 -136
  155. package/commands/ez/discuss-phase.md +90 -90
  156. package/commands/ez/execute-phase.md +52 -52
  157. package/commands/ez/help.md +22 -22
  158. package/commands/ez/map-codebase.md +71 -71
  159. package/commands/ez/new-milestone.md +44 -44
  160. package/commands/ez/new-project.md +51 -42
  161. package/commands/ez/plan-phase.md +53 -53
  162. package/commands/ez/progress.md +36 -36
  163. package/commands/ez/quick.md +45 -45
  164. package/commands/ez/resume-work.md +40 -40
  165. package/commands/ez/run-phase.md +580 -0
  166. package/commands/ez/settings.md +36 -36
  167. package/commands/ez/update.md +37 -37
  168. package/commands/ez/verify-work.md +402 -38
  169. package/commands/health-check.cjs +44 -0
  170. package/commands/rollback.cjs +47 -0
  171. package/ez-agents/bin/ez-tools.cjs +599 -2
  172. package/ez-agents/bin/guards/autonomy-guard.cjs +346 -0
  173. package/ez-agents/bin/guards/context-budget-guard.cjs +247 -0
  174. package/ez-agents/bin/guards/hallucination-guard.cjs +271 -0
  175. package/ez-agents/bin/guards/hidden-state-guard.cjs +182 -0
  176. package/ez-agents/bin/guards/team-overhead-guard.cjs +266 -0
  177. package/ez-agents/bin/guards/tool-sprawl-guard.cjs +271 -0
  178. package/ez-agents/bin/lib/analytics/analytics-collector.cjs +86 -0
  179. package/ez-agents/bin/lib/analytics/analytics-reporter.cjs +130 -0
  180. package/ez-agents/bin/lib/analytics/cohort-analyzer.cjs +138 -0
  181. package/ez-agents/bin/lib/analytics/funnel-analyzer.cjs +147 -0
  182. package/ez-agents/bin/lib/analytics/nps-tracker.cjs +147 -0
  183. package/ez-agents/bin/lib/archetype-detector.cjs +289 -0
  184. package/ez-agents/bin/lib/audit-exec.cjs +166 -167
  185. package/ez-agents/bin/lib/auth.cjs +176 -176
  186. package/ez-agents/bin/lib/backup-service.cjs +422 -0
  187. package/ez-agents/bin/lib/bdd-validator.cjs +622 -622
  188. package/ez-agents/bin/lib/business-flow-mapper.cjs +429 -0
  189. package/ez-agents/bin/lib/code-complexity-analyzer.cjs +360 -0
  190. package/ez-agents/bin/lib/codebase-analyzer.cjs +241 -0
  191. package/ez-agents/bin/lib/commands.cjs +685 -685
  192. package/ez-agents/bin/lib/config.cjs +41 -1
  193. package/ez-agents/bin/lib/constraint-extractor.cjs +526 -0
  194. package/ez-agents/bin/lib/content-scanner.cjs +238 -238
  195. package/ez-agents/bin/lib/context-cache.cjs +154 -154
  196. package/ez-agents/bin/lib/context-errors.cjs +71 -71
  197. package/ez-agents/bin/lib/context-manager.cjs +220 -220
  198. package/ez-agents/bin/lib/core.cjs +507 -512
  199. package/ez-agents/bin/lib/cost-tracker.cjs +243 -0
  200. package/ez-agents/bin/lib/crash-recovery.cjs +172 -0
  201. package/ez-agents/bin/lib/dependency-graph.cjs +319 -0
  202. package/ez-agents/bin/lib/deploy/deploy-audit-log.cjs +76 -0
  203. package/ez-agents/bin/lib/deploy/deploy-detector.cjs +69 -0
  204. package/ez-agents/bin/lib/deploy/deploy-env-manager.cjs +109 -0
  205. package/ez-agents/bin/lib/deploy/deploy-health-check.cjs +88 -0
  206. package/ez-agents/bin/lib/deploy/deploy-pre-flight.cjs +57 -0
  207. package/ez-agents/bin/lib/deploy/deploy-rollback.cjs +72 -0
  208. package/ez-agents/bin/lib/deploy/deploy-runner.cjs +97 -0
  209. package/ez-agents/bin/lib/deploy/deploy-status.cjs +74 -0
  210. package/ez-agents/bin/lib/file-access.cjs +207 -207
  211. package/ez-agents/bin/lib/finops/budget-enforcer.cjs +126 -0
  212. package/ez-agents/bin/lib/finops/cost-reporter.cjs +132 -0
  213. package/ez-agents/bin/lib/finops/finops-analyzer.cjs +112 -0
  214. package/ez-agents/bin/lib/finops/spot-manager.cjs +118 -0
  215. package/ez-agents/bin/lib/framework-detector.cjs +396 -0
  216. package/ez-agents/bin/lib/frontmatter.cjs +3 -1
  217. package/ez-agents/bin/lib/gates/README.md +374 -0
  218. package/ez-agents/bin/lib/gates/gate-01-requirement.cjs +303 -0
  219. package/ez-agents/bin/lib/gates/gate-02-architecture.cjs +555 -0
  220. package/ez-agents/bin/lib/gates/gate-03-code.cjs +635 -0
  221. package/ez-agents/bin/lib/gates/gate-04-security.cjs +829 -0
  222. package/ez-agents/bin/lib/git-errors.cjs +83 -83
  223. package/ez-agents/bin/lib/git-utils.cjs +321 -321
  224. package/ez-agents/bin/lib/git-workflow-engine.cjs +1157 -1157
  225. package/ez-agents/bin/lib/health-check.cjs +162 -162
  226. package/ez-agents/bin/lib/index.cjs +2 -8
  227. package/ez-agents/bin/lib/init.cjs +0 -2
  228. package/ez-agents/bin/lib/lockfile-validator.cjs +227 -227
  229. package/ez-agents/bin/lib/log-rotation.cjs +71 -0
  230. package/ez-agents/bin/lib/logger.cjs +22 -47
  231. package/ez-agents/bin/lib/memory-compression.cjs +256 -256
  232. package/ez-agents/bin/lib/package-manager-detector.cjs +203 -203
  233. package/ez-agents/bin/lib/package-manager-executor.cjs +385 -385
  234. package/ez-agents/bin/lib/package-manager-service.cjs +216 -216
  235. package/ez-agents/bin/lib/perf/api-monitor.cjs +88 -0
  236. package/ez-agents/bin/lib/perf/db-optimizer.cjs +78 -0
  237. package/ez-agents/bin/lib/perf/frontend-performance.cjs +56 -0
  238. package/ez-agents/bin/lib/perf/perf-analyzer.cjs +77 -0
  239. package/ez-agents/bin/lib/perf/perf-baseline.cjs +102 -0
  240. package/ez-agents/bin/lib/perf/perf-reporter.cjs +117 -0
  241. package/ez-agents/bin/lib/perf/regression-detector.cjs +92 -0
  242. package/ez-agents/bin/lib/project-reporter.cjs +502 -0
  243. package/ez-agents/bin/lib/quality-gate.cjs +332 -0
  244. package/ez-agents/bin/lib/recovery-manager.cjs +98 -0
  245. package/ez-agents/bin/lib/release-validator.cjs +617 -614
  246. package/ez-agents/bin/lib/security-errors.cjs +62 -0
  247. package/ez-agents/bin/lib/session-chain.cjs +304 -304
  248. package/ez-agents/bin/lib/session-errors.cjs +81 -81
  249. package/ez-agents/bin/lib/session-export.cjs +251 -251
  250. package/ez-agents/bin/lib/session-import.cjs +262 -262
  251. package/ez-agents/bin/lib/session-manager.cjs +280 -280
  252. package/ez-agents/bin/lib/skill-context.cjs +148 -0
  253. package/ez-agents/bin/lib/skill-matcher.cjs +236 -0
  254. package/ez-agents/bin/lib/skill-registry.cjs +341 -0
  255. package/ez-agents/bin/lib/skill-resolver.cjs +449 -0
  256. package/ez-agents/bin/lib/skill-triggers.cjs +90 -0
  257. package/ez-agents/bin/lib/skill-validator.cjs +270 -0
  258. package/ez-agents/bin/lib/skill-versioning.cjs +355 -0
  259. package/ez-agents/bin/lib/stack-detector.cjs +399 -0
  260. package/ez-agents/bin/lib/tech-debt-analyzer.cjs +309 -0
  261. package/ez-agents/bin/lib/tier-manager.cjs +428 -428
  262. package/ez-agents/bin/lib/tradeoff-analyzer.cjs +284 -0
  263. package/ez-agents/bin/lib/url-fetch.cjs +170 -170
  264. package/ez-agents/bin/lib/verify.cjs +863 -863
  265. package/ez-agents/references/decimal-phase-calculation.md +65 -65
  266. package/ez-agents/references/git-integration.md +248 -248
  267. package/ez-agents/references/git-planning-commit.md +38 -38
  268. package/ez-agents/references/metrics-schema.md +118 -118
  269. package/ez-agents/references/model-profile-resolution.md +34 -34
  270. package/ez-agents/references/model-profiles.md +93 -93
  271. package/ez-agents/references/phase-argument-parsing.md +61 -61
  272. package/ez-agents/references/planning-config.md +340 -340
  273. package/ez-agents/references/tier-strategy.md +103 -103
  274. package/ez-agents/references/ui-brand.md +160 -160
  275. package/ez-agents/references/verification-patterns.md +612 -612
  276. package/ez-agents/templates/DEBUG.md +164 -164
  277. package/ez-agents/templates/UAT.md +247 -247
  278. package/ez-agents/templates/agent-output-format.md +404 -0
  279. package/ez-agents/templates/bdd-feature.md +173 -173
  280. package/ez-agents/templates/codebase/architecture.md +255 -255
  281. package/ez-agents/templates/codebase/structure.md +285 -285
  282. package/ez-agents/templates/copilot-instructions.md +7 -7
  283. package/ez-agents/templates/debug-subagent-prompt.md +91 -91
  284. package/ez-agents/templates/discovery.md +146 -146
  285. package/ez-agents/templates/discussion.md +68 -68
  286. package/ez-agents/templates/handoff-protocol.md +294 -0
  287. package/ez-agents/templates/incident-runbook.md +205 -205
  288. package/ez-agents/templates/mode-workflow-templates.md +301 -0
  289. package/ez-agents/templates/phase-prompt.md +610 -610
  290. package/ez-agents/templates/planner-subagent-prompt.md +117 -117
  291. package/ez-agents/templates/project.md +184 -184
  292. package/ez-agents/templates/release-checklist.md +136 -133
  293. package/ez-agents/templates/research.md +552 -552
  294. package/ez-agents/templates/rollback-plan.md +201 -201
  295. package/ez-agents/templates/security-user-setup.md +244 -0
  296. package/ez-agents/templates/skill-validation-rules.md +476 -0
  297. package/ez-agents/templates/state.md +180 -176
  298. package/ez-agents/templates/summary-complex.md +59 -59
  299. package/ez-agents/tests/gates/gate-01-02.test.cjs +812 -0
  300. package/ez-agents/tests/gates/gate-03-04.test.cjs +762 -0
  301. package/ez-agents/tests/gates/gate-05-validator.test.cjs +145 -0
  302. package/ez-agents/tests/gates/gate-06-docs-validator.test.cjs +244 -0
  303. package/ez-agents/tests/gates/gate-07-release-validator.test.cjs +219 -0
  304. package/ez-agents/tests/guards/context-budget-guard.test.cjs +145 -0
  305. package/ez-agents/tests/guards/edge-case-guards.test.cjs +238 -0
  306. package/ez-agents/tests/guards/hallucination-guard.test.cjs +124 -0
  307. package/ez-agents/workflows/audit-milestone.md +1 -1
  308. package/ez-agents/workflows/autonomous.md +844 -844
  309. package/ez-agents/workflows/complete-milestone.md +1 -1
  310. package/ez-agents/workflows/discuss-phase.md +1 -1
  311. package/ez-agents/workflows/execute-phase.md +124 -3
  312. package/ez-agents/workflows/help.md +42 -181
  313. package/ez-agents/workflows/hotfix.md +291 -291
  314. package/ez-agents/workflows/new-milestone.md +713 -713
  315. package/ez-agents/workflows/new-project.md +1089 -1107
  316. package/ez-agents/workflows/plan-phase.md +0 -40
  317. package/ez-agents/workflows/release.md +253 -253
  318. package/ez-agents/workflows/resume-session.md +215 -215
  319. package/ez-agents/workflows/run-phase.md +531 -0
  320. package/ez-agents/workflows/settings.md +2 -35
  321. package/hooks/dist/ez-check-update.js +81 -81
  322. package/hooks/dist/ez-context-monitor.js +148 -141
  323. package/hooks/dist/ez-statusline.js +115 -115
  324. package/package.json +78 -71
  325. package/scripts/fix-qwen-installation.js +144 -144
  326. package/agents/ez-integration-checker.md +0 -443
  327. package/agents/ez-nyquist-auditor.md +0 -176
  328. package/agents/ez-observer-agent.md +0 -260
  329. package/agents/ez-plan-checker.md +0 -706
  330. package/agents/ez-research-synthesizer.md +0 -247
  331. package/agents/ez-scrum-master-agent.md +0 -242
  332. package/agents/ez-tech-lead-agent.md +0 -267
  333. package/agents/ez-ui-auditor.md +0 -439
  334. package/agents/ez-ui-checker.md +0 -300
  335. package/agents/ez-ui-researcher.md +0 -353
  336. package/commands/ez/add-phase.md +0 -43
  337. package/commands/ez/add-todo.md +0 -47
  338. package/commands/ez/arch-review.md +0 -102
  339. package/commands/ez/auth.md +0 -87
  340. package/commands/ez/autonomous.md +0 -41
  341. package/commands/ez/check-todos.md +0 -45
  342. package/commands/ez/cleanup.md +0 -18
  343. package/commands/ez/debug.md +0 -168
  344. package/commands/ez/export-session.md +0 -79
  345. package/commands/ez/gather-requirements.md +0 -117
  346. package/commands/ez/git-workflow.md +0 -72
  347. package/commands/ez/health.md +0 -22
  348. package/commands/ez/hotfix.md +0 -120
  349. package/commands/ez/import-session.md +0 -82
  350. package/commands/ez/insert-phase.md +0 -32
  351. package/commands/ez/join-discord.md +0 -18
  352. package/commands/ez/list-phase-assumptions.md +0 -46
  353. package/commands/ez/list-sessions.md +0 -96
  354. package/commands/ez/package-manager.md +0 -316
  355. package/commands/ez/pause-work.md +0 -38
  356. package/commands/ez/plan-milestone-gaps.md +0 -34
  357. package/commands/ez/preflight.md +0 -79
  358. package/commands/ez/reapply-patches.md +0 -124
  359. package/commands/ez/release.md +0 -153
  360. package/commands/ez/remove-phase.md +0 -31
  361. package/commands/ez/research-phase.md +0 -190
  362. package/commands/ez/resume.md +0 -107
  363. package/commands/ez/set-profile.md +0 -34
  364. package/commands/ez/standup.md +0 -85
  365. package/commands/ez/stats.md +0 -18
  366. package/commands/ez/ui-phase.md +0 -34
  367. package/commands/ez/ui-review.md +0 -32
  368. package/commands/ez/validate-phase.md +0 -35
  369. package/ez-agents/bin/lib/metrics-tracker.cjs +0 -406
  370. package/ez-agents/templates/UI-SPEC.md +0 -100
  371. package/ez-agents/templates/VALIDATION.md +0 -76
  372. package/ez-agents/templates/context.md +0 -352
  373. package/ez-agents/templates/verification-report.md +0 -322
  374. package/ez-agents/workflows/arch-review.md +0 -54
  375. package/ez-agents/workflows/export-session.md +0 -255
  376. package/ez-agents/workflows/gather-requirements.md +0 -206
  377. package/ez-agents/workflows/import-session.md +0 -303
  378. package/ez-agents/workflows/research-phase.md +0 -74
  379. package/ez-agents/workflows/standup.md +0 -64
  380. package/ez-agents/workflows/ui-phase.md +0 -290
  381. package/ez-agents/workflows/ui-review.md +0 -157
  382. package/ez-agents/workflows/validate-phase.md +0 -167
@@ -1,844 +1,844 @@
1
- <purpose>
2
-
3
- Drive all remaining milestone phases autonomously. For each incomplete phase: discuss → plan → execute **ALL tasks in loop** using Skill() flat invocations. Pauses only for explicit user decisions (grey area acceptance, blockers, validation requests). Re-reads ROADMAP.md after each phase to catch dynamically inserted phases.
4
-
5
- **Key:** Execute-phase loops through ALL task plans within a phase, not just the phase as a whole.
6
-
7
- </purpose>
8
-
9
- <required_reading>
10
-
11
- Read all files referenced by the invoking prompt's execution_context before starting.
12
-
13
- </required_reading>
14
-
15
- <process>
16
-
17
- <step name="initialize" priority="first">
18
-
19
- ## 1. Initialize
20
-
21
- Parse `$ARGUMENTS` for `--from N` flag:
22
-
23
- ```bash
24
- FROM_PHASE=""
25
- if echo "$ARGUMENTS" | grep -qE '\-\-from\s+[0-9]'; then
26
- FROM_PHASE=$(echo "$ARGUMENTS" | grep -oE '\-\-from\s+[0-9]+\.?[0-9]*' | awk '{print $2}')
27
- fi
28
- ```
29
-
30
- Bootstrap via milestone-level init:
31
-
32
- ```bash
33
- INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init milestone-op)
34
- ```
35
-
36
- Parse JSON for: `milestone_version`, `milestone_name`, `phase_count`, `completed_phases`, `roadmap_exists`, `state_exists`, `commit_docs`.
37
-
38
- **If `roadmap_exists` is false:** Error — "No ROADMAP.md found. Run `/ez:new-milestone` first."
39
- **If `state_exists` is false:** Error — "No STATE.md found. Run `/ez:new-milestone` first."
40
-
41
- Display startup banner:
42
-
43
- ```
44
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
45
- EZ ► AUTONOMOUS
46
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
47
-
48
- Milestone: {milestone_version} — {milestone_name}
49
- Phases: {phase_count} total, {completed_phases} complete
50
- ```
51
-
52
- If `FROM_PHASE` is set, display: `Starting from phase ${FROM_PHASE}`
53
-
54
- </step>
55
-
56
- <step name="discover_phases">
57
-
58
- ## 2. Discover Phases
59
-
60
- Run phase discovery:
61
-
62
- ```bash
63
- ROADMAP=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap analyze)
64
- ```
65
-
66
- Parse the JSON `phases` array.
67
-
68
- **Filter to incomplete phases:** Keep only phases where `disk_status !== "complete"` OR `roadmap_complete === false`.
69
-
70
- **Apply `--from N` filter:** If `FROM_PHASE` was provided, additionally filter out phases where `number < FROM_PHASE` (use numeric comparison — handles decimal phases like "5.1").
71
-
72
- **Sort by `number`** in numeric ascending order.
73
-
74
- **If no incomplete phases remain:**
75
-
76
- ```
77
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
78
- EZ ► AUTONOMOUS ▸ COMPLETE 🎉
79
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
80
-
81
- All phases complete! Nothing left to do.
82
- ```
83
-
84
- Exit cleanly.
85
-
86
- **Display phase plan:**
87
-
88
- ```
89
- ## Phase Plan
90
-
91
- | # | Phase | Status | Tasks |
92
- |---|-------|--------|-------|
93
- | 5 | Skill Scaffolding & Phase Discovery | In Progress | [count] |
94
- | 6 | Smart Discuss | Not Started | [count] |
95
- | 7 | Auto-Chain Refinements | Not Started | [count] |
96
- | 8 | Lifecycle Orchestration | Not Started | [count] |
97
- ```
98
-
99
- **Fetch details for each phase:**
100
-
101
- ```bash
102
- DETAIL=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap get-phase ${PHASE_NUM})
103
- ```
104
-
105
- Extract `phase_name`, `goal`, `success_criteria`, `task_count` from each. Store for use in execute_phase and transition messages.
106
-
107
- </step>
108
-
109
- <step name="execute_phase">
110
-
111
- ## 3. Execute Phase (with Task Loop)
112
-
113
- For the current phase, display the progress banner:
114
-
115
- ```
116
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
117
- EZ ► AUTONOMOUS ▸ Phase {N}/{T}: {Name} [████░░░░] {P}%
118
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
119
-
120
- Phase {N} has {task_count} tasks to execute
121
- ```
122
-
123
- Where N = current phase number (from the ROADMAP, e.g., 6), T = total milestone phases (from `phase_count` parsed in initialize step, e.g., 8), P = percentage of all milestone phases completed so far.
124
-
125
- **3a. Smart Discuss**
126
-
127
- Check if CONTEXT.md already exists for this phase:
128
-
129
- ```bash
130
- PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
131
- ```
132
-
133
- Parse `has_context` from JSON.
134
-
135
- **If has_context is true:** Skip discuss — context already gathered. Display:
136
-
137
- ```
138
- Phase ${PHASE_NUM}: Context exists — skipping discuss.
139
- ```
140
-
141
- Proceed to 3b.
142
-
143
- **If has_context is false:** Execute the smart_discuss step for this phase.
144
-
145
- After smart_discuss completes, verify context was written:
146
-
147
- ```bash
148
- PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
149
- ```
150
-
151
- Check `has_context`. If false → go to handle_blocker: "Smart discuss for phase ${PHASE_NUM} did not produce CONTEXT.md."
152
-
153
- **3b. Plan**
154
-
155
- ```
156
- Skill(skill="ez:plan-phase", args="${PHASE_NUM}")
157
- ```
158
-
159
- Verify plan produced output — re-run `init phase-op` and check `has_plans`. If false → go to handle_blocker: "Plan phase ${PHASE_NUM} did not produce any plans."
160
-
161
- **Get task list for loop:**
162
-
163
- ```bash
164
- PLANS=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-list-plans ${PHASE_NUM})
165
- ```
166
-
167
- Parse JSON for: `plans` array with `plan_number`, `plan_name`, `task_description`, `status` for each plan.
168
-
169
- **Filter to incomplete plans:** Keep only plans where `status !== "complete"`.
170
-
171
- **Store for task loop:** `plan_list` = array of incomplete plans.
172
-
173
- **3c. Execute ALL Tasks in Loop**
174
-
175
- Display task execution banner:
176
-
177
- ```
178
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
179
- EZ ► AUTONOMOUS ▸ Phase {N} Task Execution
180
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
181
-
182
- {task_count} tasks to execute in Phase {N}
183
- ```
184
-
185
- **For each plan in `plan_list` (loop through ALL tasks):**
186
-
187
- ```
188
- FOR EACH plan IN plan_list:
189
- ```
190
-
191
- **3c-i. Display task progress:**
192
-
193
- ```
194
- Task {plan.plan_number}/{task_count}: {plan.plan_name}
195
- [████░░░░] {completed_tasks}/{total_tasks} completed
196
- ```
197
-
198
- **3c-ii. Execute single task:**
199
-
200
- ```
201
- Skill(skill="ez:execute-phase", args="${PHASE_NUM} --plan ${plan.plan_number} --no-transition")
202
- ```
203
-
204
- **3c-iii. Verify task completion:**
205
-
206
- ```bash
207
- TASK_STATUS=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-get-task-status ${PHASE_NUM} ${plan.plan_number})
208
- ```
209
-
210
- Parse `status` from JSON (values: "complete", "in_progress", "blocked", "failed").
211
-
212
- **If `complete`:**
213
- - Display: `✅ Task ${plan.plan_number}: ${plan.plan_name} — Complete`
214
- - Mark task as completed in local tracking
215
- - Continue to next task in loop
216
-
217
- **If `in_progress`:**
218
- - Display: `⚠ Task ${plan.plan_number}: ${plan.plan_name} — Still in progress`
219
- - Retry status check once (wait 30 seconds)
220
- - If still `in_progress` → go to handle_blocker: "Task ${plan.plan_number} did not complete"
221
-
222
- **If `blocked` or `failed`:**
223
- - Read error/blocker details from task status
224
- - Go to handle_blocker with: "Task ${plan.plan_number} (${plan.plan_name}) ${status}: {details}"
225
-
226
- **3c-iv. After each task completes, update phase progress:**
227
-
228
- ```bash
229
- node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-update-progress ${PHASE_NUM}
230
- ```
231
-
232
- **End loop** (continue to next plan in plan_list)
233
-
234
- **After ALL tasks complete:**
235
-
236
- Display phase completion banner:
237
-
238
- ```
239
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
240
- EZ ► AUTONOMOUS ▸ Phase {N} Complete ✅
241
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
242
-
243
- All {task_count} tasks completed successfully
244
- Phase {N}: {phase_name} — DONE
245
- ```
246
-
247
- **3d. Post-Execution Verification**
248
-
249
- After all tasks in the phase complete, read the verification result:
250
-
251
- ```bash
252
- VERIFY_STATUS=$(grep "^status:" "${PHASE_DIR}"/*-VERIFICATION.md 2>/dev/null | head -1 | cut -d: -f2 | tr -d ' ')
253
- ```
254
-
255
- Where `PHASE_DIR` comes from the `init phase-op` call already made in step 3a. If the variable is not in scope, re-fetch:
256
-
257
- ```bash
258
- PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
259
- ```
260
-
261
- Parse `phase_dir` from the JSON.
262
-
263
- **If VERIFY_STATUS is empty** (no VERIFICATION.md or no status field):
264
-
265
- Go to handle_blocker: "Execute phase ${PHASE_NUM} did not produce verification results."
266
-
267
- **If `passed`:**
268
-
269
- Display:
270
- ```
271
- Phase ${PHASE_NUM} ✅ ${PHASE_NAME} — Verification passed
272
- All {task_count} tasks verified
273
- ```
274
-
275
- Proceed to iterate step.
276
-
277
- **If `human_needed`:**
278
-
279
- Read the human_verification section from VERIFICATION.md to get the count and items requiring manual testing.
280
-
281
- Display the items, then ask user via AskUserQuestion:
282
- - **question:** "Phase ${PHASE_NUM} has {N} items needing manual verification. Validate now or continue to next phase?"
283
- - **options:** "Validate now" / "Continue without validation"
284
-
285
- On **"Validate now"**: Present the specific items from VERIFICATION.md's human_verification section. After user reviews, ask:
286
- - **question:** "Validation result?"
287
- - **options:** "All good — continue" / "Found issues"
288
-
289
- On "All good — continue": Display `Phase ${PHASE_NUM} ✅ Human validation passed` and proceed to iterate step.
290
-
291
- On "Found issues": Go to handle_blocker with the user's reported issues as the description.
292
-
293
- On **"Continue without validation"**: Display `Phase ${PHASE_NUM} ⏭ Human validation deferred` and proceed to iterate step.
294
-
295
- **If `gaps_found`:**
296
-
297
- Read gap summary from VERIFICATION.md (score and missing items). Display:
298
- ```
299
- ⚠ Phase ${PHASE_NUM}: ${PHASE_NAME} — Gaps Found
300
- Score: {N}/{M} must-haves verified
301
- {gap_count} tasks have gaps
302
- ```
303
-
304
- Ask user via AskUserQuestion:
305
- - **question:** "Gaps found in phase ${PHASE_NUM}. How to proceed?"
306
- - **options:** "Run gap closure" / "Continue without fixing" / "Stop autonomous mode"
307
-
308
- On **"Run gap closure"**: Execute gap closure cycle (limit: 1 attempt):
309
-
310
- ```
311
- Skill(skill="ez:plan-phase", args="${PHASE_NUM} --gaps")
312
- ```
313
-
314
- Verify gap plans were created — re-run `init phase-op ${PHASE_NUM}` and check `has_plans`. If no new gap plans → go to handle_blocker: "Gap closure planning for phase ${PHASE_NUM} did not produce plans."
315
-
316
- **Re-execute ALL gap tasks in loop:**
317
-
318
- ```bash
319
- GAP_PLANS=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-list-plans ${PHASE_NUM} --gap-only)
320
- ```
321
-
322
- For each gap plan in GAP_PLANS:
323
- ```
324
- Skill(skill="ez:execute-phase", args="${PHASE_NUM} --plan ${gap_plan.number} --no-transition")
325
- ```
326
-
327
- Re-read verification status:
328
- ```bash
329
- VERIFY_STATUS=$(grep "^status:" "${PHASE_DIR}"/*-VERIFICATION.md 2>/dev/null | head -1 | cut -d: -f2 | tr -d ' ')
330
- ```
331
-
332
- If `passed` or `human_needed`: Route normally (continue or ask user as above).
333
-
334
- If still `gaps_found` after this retry: Display "Gaps persist after closure attempt." and ask via AskUserQuestion:
335
- - **question:** "Gap closure did not fully resolve issues. How to proceed?"
336
- - **options:** "Continue anyway" / "Stop autonomous mode"
337
-
338
- On "Continue anyway": Proceed to iterate step.
339
- On "Stop autonomous mode": Go to handle_blocker.
340
-
341
- This limits gap closure to 1 automatic retry to prevent infinite loops.
342
-
343
- On **"Continue without fixing"**: Display `Phase ${PHASE_NUM} ⏭ Gaps deferred` and proceed to iterate step.
344
-
345
- On **"Stop autonomous mode"**: Go to handle_blocker with "User stopped — gaps remain in phase ${PHASE_NUM}".
346
-
347
- </step>
348
-
349
- <step name="smart_discuss">
350
-
351
- ## Smart Discuss
352
-
353
- Run smart discuss for the current phase. Proposes grey area answers in batch tables — the user accepts or overrides per area. Produces identical CONTEXT.md output to regular discuss-phase.
354
-
355
- > **Note:** Smart discuss is an autonomous-optimized variant of the `ez:discuss-phase` skill. It produces identical CONTEXT.md output but uses batch table proposals instead of sequential questioning. The original `discuss-phase` skill remains unchanged (per CTRL-03). Future milestones may extract this to a separate skill file.
356
-
357
- **Inputs:** `PHASE_NUM` from execute_phase. Run init to get phase paths:
358
-
359
- ```bash
360
- PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
361
- ```
362
-
363
- Parse from JSON: `phase_dir`, `phase_slug`, `padded_phase`, `phase_name`.
364
-
365
- ---
366
-
367
- ### Sub-step 1: Load prior context
368
-
369
- Read project-level and prior phase context to avoid re-asking decided questions.
370
-
371
- **Read project files:**
372
-
373
- ```bash
374
- cat .planning/PROJECT.md 2>/dev/null
375
- cat .planning/REQUIREMENTS.md 2>/dev/null
376
- cat .planning/STATE.md 2>/dev/null
377
- ```
378
-
379
- Extract from these:
380
- - **PROJECT.md** — Vision, principles, non-negotiables, user preferences
381
- - **REQUIREMENTS.md** — Acceptance criteria, constraints, must-haves vs nice-to-haves
382
- - **STATE.md** — Current progress, decisions logged so far
383
-
384
- **Read all prior CONTEXT.md files:**
385
-
386
- ```bash
387
- find .planning/phases -name "*-CONTEXT.md" 2>/dev/null | sort
388
- ```
389
-
390
- For each CONTEXT.md where phase number < current phase:
391
- - Read the `<decisions>` section — these are locked preferences
392
- - Read `<specifics>` — particular references or "I want it like X" moments
393
- - Note patterns (e.g., "user consistently prefers minimal UI", "user rejected verbose output")
394
-
395
- **Build internal prior_decisions context** (do not write to file):
396
-
397
- ```
398
- <prior_decisions>
399
- ## Project-Level
400
- - [Key principle or constraint from PROJECT.md]
401
- - [Requirement affecting this phase from REQUIREMENTS.md]
402
-
403
- ## From Prior Phases
404
- ### Phase N: [Name]
405
- - [Decision relevant to current phase]
406
- - [Preference that establishes a pattern]
407
- </prior_decisions>
408
- ```
409
-
410
- If no prior context exists, continue without — expected for early phases.
411
-
412
- ---
413
-
414
- ### Sub-step 2: Scout Codebase
415
-
416
- Lightweight codebase scan to inform grey area identification and proposals. Keep under ~5% context.
417
-
418
- **Check for existing codebase maps:**
419
-
420
- ```bash
421
- ls .planning/codebase/*.md 2>/dev/null
422
- ```
423
-
424
- **If codebase maps exist:** Read the most relevant ones (CONVENTIONS.md, STRUCTURE.md, STACK.md based on phase type). Extract reusable components, established patterns, integration points. Skip to building context below.
425
-
426
- **If no codebase maps, do targeted grep:**
427
-
428
- Extract key terms from the phase goal. Search for related files:
429
-
430
- ```bash
431
- grep -rl "{term1}\|{term2}" src/ app/ --include="*.ts" --include="*.tsx" --include="*.js" --include="*.jsx" 2>/dev/null | head -10
432
- ls src/components/ src/hooks/ src/lib/ src/utils/ 2>/dev/null
433
- ```
434
-
435
- Read the 3-5 most relevant files to understand existing patterns.
436
-
437
- **Build internal codebase_context** (do not write to file):
438
- - **Reusable assets** — existing components, hooks, utilities usable in this phase
439
- - **Established patterns** — how the codebase does state management, styling, data fetching
440
- - **Integration points** — where new code connects (routes, nav, providers)
441
-
442
- ---
443
-
444
- ### Sub-step 3: Analyze Phase and Generate Proposals
445
-
446
- **Get phase details:**
447
-
448
- ```bash
449
- DETAIL=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap get-phase ${PHASE_NUM})
450
- ```
451
-
452
- Extract `goal`, `requirements`, `success_criteria`, `task_count` from the JSON response.
453
-
454
- **Infrastructure detection — check FIRST before generating grey areas:**
455
-
456
- A phase is pure infrastructure when ALL of these are true:
457
- 1. Goal keywords match: "scaffolding", "plumbing", "setup", "configuration", "migration", "refactor", "rename", "restructure", "upgrade", "infrastructure"
458
- 2. AND success criteria are all technical: "file exists", "test passes", "config valid", "command runs"
459
- 3. AND no user-facing behavior is described (no "users can", "displays", "shows", "presents")
460
-
461
- **If infrastructure-only:** Skip Sub-step 4. Jump directly to Sub-step 5 with minimal CONTEXT.md. Display:
462
-
463
- ```
464
- Phase ${PHASE_NUM}: Infrastructure phase — skipping discuss, writing minimal context.
465
- ```
466
-
467
- Use these defaults for the CONTEXT.md:
468
- - `<domain>`: Phase boundary from ROADMAP goal
469
- - `<decisions>`: Single "### Claude's Discretion" subsection — "All implementation choices are at Claude's discretion — pure infrastructure phase"
470
- - `<code_context>`: Whatever the codebase scout found
471
- - `<specifics>`: "No specific requirements — infrastructure phase"
472
- - `<deferred>`: "None"
473
-
474
- **If NOT infrastructure — generate grey area proposals:**
475
-
476
- Determine domain type from the phase goal:
477
- - Something users **SEE** → visual: layout, interactions, states, density
478
- - Something users **CALL** → interface: contracts, responses, errors, auth
479
- - Something users **RUN** → execution: invocation, output, behavior modes, flags
480
- - Something users **READ** → content: structure, tone, depth, flow
481
- - Something being **ORGANIZED** → organization: criteria, grouping, exceptions, naming
482
-
483
- Check prior_decisions — skip grey areas already decided in prior phases.
484
-
485
- Generate **3-4 grey areas** with **~4 questions each**. For each question:
486
- - **Pre-select a recommended answer** based on: prior decisions (consistency), codebase patterns (reuse), domain conventions (standard approaches), ROADMAP success criteria
487
- - Generate **1-2 alternatives** per question
488
- - **Annotate** with prior decision context ("You decided X in Phase N") and code context ("Component Y exists with Z variants") where relevant
489
-
490
- ---
491
-
492
- ### Sub-step 4: Present Proposals Per Area
493
-
494
- Present grey areas **one at a time**. For each area (M of N):
495
-
496
- Display a table:
497
-
498
- ```
499
- ### Grey Area {M}/{N}: {Area Name}
500
-
501
- | # | Question | ✅ Recommended | Alternative(s) |
502
- |---|----------|---------------|-----------------|
503
- | 1 | {question} | {answer} — {rationale} | {alt1}; {alt2} |
504
- | 2 | {question} | {answer} — {rationale} | {alt1} |
505
- | 3 | {question} | {answer} — {rationale} | {alt1}; {alt2} |
506
- | 4 | {question} | {answer} — {rationale} | {alt1} |
507
- ```
508
-
509
- Then prompt the user via **AskUserQuestion**:
510
- - **header:** "Area {M}/{N}"
511
- - **question:** "Accept these answers for {Area Name}?"
512
- - **options:** Build dynamically — always "Accept all" first, then "Change Q1" through "Change QN" for each question (up to 4), then "Discuss deeper" last. Cap at 6 explicit options max (AskUserQuestion adds "Other" automatically).
513
-
514
- **On "Accept all":** Record all recommended answers for this area. Move to next area.
515
-
516
- **On "Change QN":** Use AskUserQuestion with the alternatives for that specific question:
517
- - **header:** "{Area Name}"
518
- - **question:** "Q{N}: {question text}"
519
- - **options:** List the 1-2 alternatives plus "You decide" (maps to Claude's Discretion)
520
-
521
- Record the user's choice. Re-display the updated table with the change reflected. Re-present the full acceptance prompt so the user can make additional changes or accept.
522
-
523
- **On "Discuss deeper":** Switch to interactive mode for this area only — ask questions one at a time using AskUserQuestion with 2-3 concrete options per question plus "You decide". After 4 questions, prompt:
524
- - **header:** "{Area Name}"
525
- - **question:** "More questions about {area name}, or move to next?"
526
- - **options:** "More questions" / "Next area"
527
-
528
- If "More questions", ask 4 more. If "Next area", display final summary table of captured answers for this area and move on.
529
-
530
- **On "Other" (free text):** Interpret as either a specific change request or general feedback. Incorporate into the area's decisions, re-display updated table, re-present acceptance prompt.
531
-
532
- **Scope creep handling:** If user mentions something outside the phase domain:
533
-
534
- ```
535
- "{Feature} sounds like a new capability — that belongs in its own phase.
536
- I'll note it as a deferred idea.
537
-
538
- Back to {current area}: {return to current question}"
539
- ```
540
-
541
- Track deferred ideas internally for inclusion in CONTEXT.md.
542
-
543
- ---
544
-
545
- ### Sub-step 5: Write CONTEXT.md
546
-
547
- After all areas are resolved (or infrastructure skip), write the CONTEXT.md file.
548
-
549
- **File path:** `${phase_dir}/${padded_phase}-CONTEXT.md`
550
-
551
- Use **exactly** this structure (identical to discuss-phase output):
552
-
553
- ```markdown
554
- # Phase {PHASE_NUM}: {Phase Name} - Context
555
-
556
- **Gathered:** {date}
557
- **Status:** Ready for planning
558
-
559
- <domain>
560
- ## Phase Boundary
561
-
562
- {Domain boundary statement from analysis — what this phase delivers}
563
-
564
- </domain>
565
-
566
- <decisions>
567
- ## Implementation Decisions
568
-
569
- ### {Area 1 Name}
570
- - {Accepted/chosen answer for Q1}
571
- - {Accepted/chosen answer for Q2}
572
- - {Accepted/chosen answer for Q3}
573
- - {Accepted/chosen answer for Q4}
574
-
575
- ### {Area 2 Name}
576
- - {Accepted/chosen answer for Q1}
577
- - {Accepted/chosen answer for Q2}
578
- ...
579
-
580
- ### Claude's Discretion
581
- {Any "You decide" answers collected — note Claude has flexibility here}
582
-
583
- </decisions>
584
-
585
- <code_context>
586
- ## Existing Code Insights
587
-
588
- ### Reusable Assets
589
- - {From codebase scout — components, hooks, utilities}
590
-
591
- ### Established Patterns
592
- - {From codebase scout — state management, styling, data fetching}
593
-
594
- ### Integration Points
595
- - {From codebase scout — where new code connects}
596
-
597
- </code_context>
598
-
599
- <specifics>
600
- ## Specific Ideas
601
-
602
- {Any specific references or "I want it like X" from discussion}
603
- {If none: "No specific requirements — open to standard approaches"}
604
-
605
- </specifics>
606
-
607
- <deferred>
608
- ## Deferred Ideas
609
-
610
- {Ideas captured but out of scope for this phase}
611
- {If none: "None — discussion stayed within phase scope"}
612
-
613
- </deferred>
614
- ```
615
-
616
- Write the file.
617
-
618
- **Commit:**
619
-
620
- ```bash
621
- node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" commit "docs(${PADDED_PHASE}): smart discuss context" --files "${phase_dir}/${padded_phase}-CONTEXT.md"
622
- ```
623
-
624
- Display confirmation:
625
-
626
- ```
627
- Created: {path}
628
- Decisions captured: {count} across {area_count} areas
629
- ```
630
-
631
- </step>
632
-
633
- <step name="iterate">
634
-
635
- ## 4. Iterate
636
-
637
- After each phase completes (ALL tasks executed), re-read ROADMAP.md to catch phases inserted mid-execution (decimal phases like 5.1):
638
-
639
- ```bash
640
- ROADMAP=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap analyze)
641
- ```
642
-
643
- Re-filter incomplete phases using the same logic as discover_phases:
644
- - Keep phases where `disk_status !== "complete"` OR `roadmap_complete === false`
645
- - Apply `--from N` filter if originally provided
646
- - Sort by number ascending
647
-
648
- Read STATE.md fresh:
649
-
650
- ```bash
651
- cat .planning/STATE.md
652
- ```
653
-
654
- Check for blockers in the Blockers/Concerns section. If blockers are found, go to handle_blocker with the blocker description.
655
-
656
- If incomplete phases remain: proceed to next phase, loop back to execute_phase.
657
-
658
- If all phases complete: proceed to lifecycle step.
659
-
660
- </step>
661
-
662
- <step name="lifecycle">
663
-
664
- ## 5. Lifecycle
665
-
666
- After all phases complete, run the milestone lifecycle sequence: audit → complete → cleanup.
667
-
668
- Display lifecycle transition banner:
669
-
670
- ```
671
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
672
- EZ ► AUTONOMOUS ▸ LIFECYCLE
673
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
674
-
675
- All phases complete → Starting lifecycle: audit → complete → cleanup
676
- Milestone: {milestone_version} — {milestone_name}
677
- ```
678
-
679
- **5a. Audit**
680
-
681
- ```
682
- Skill(skill="ez:audit-milestone")
683
- ```
684
-
685
- After audit completes, detect the result:
686
-
687
- ```bash
688
- AUDIT_FILE=".planning/v${milestone_version}-MILESTONE-AUDIT.md"
689
- AUDIT_STATUS=$(grep "^status:" "${AUDIT_FILE}" 2>/dev/null | head -1 | cut -d: -f2 | tr -d ' ')
690
- ```
691
-
692
- **If AUDIT_STATUS is empty** (no audit file or no status field):
693
-
694
- Go to handle_blocker: "Audit did not produce results — audit file missing or malformed."
695
-
696
- **If `passed`:**
697
-
698
- Display:
699
- ```
700
- Audit ✅ passed — proceeding to complete milestone
701
- ```
702
-
703
- Proceed to 5b (no user pause — per CTRL-01).
704
-
705
- **If `gaps_found`:**
706
-
707
- Read the gaps summary from the audit file. Display:
708
- ```
709
- ⚠ Audit: Gaps Found
710
- ```
711
-
712
- Ask user via AskUserQuestion:
713
- - **question:** "Milestone audit found gaps. How to proceed?"
714
- - **options:** "Continue anyway — accept gaps" / "Stop — fix gaps manually"
715
-
716
- On **"Continue anyway"**: Display `Audit ⏭ Gaps accepted — proceeding to complete milestone` and proceed to 5b.
717
-
718
- On **"Stop"**: Go to handle_blocker with "User stopped — audit gaps remain. Run /ez:audit-milestone to review, then /ez:complete-milestone when ready."
719
-
720
- **If `tech_debt`:**
721
-
722
- Read the tech debt summary from the audit file. Display:
723
- ```
724
- ⚠ Audit: Tech Debt Identified
725
- ```
726
-
727
- Show the summary, then ask user via AskUserQuestion:
728
- - **question:** "Milestone audit found tech debt. How to proceed?"
729
- - **options:** "Continue with tech debt" / "Stop — address debt first"
730
-
731
- On **"Continue with tech debt"**: Display `Audit ⏭ Tech debt acknowledged — proceeding to complete milestone` and proceed to 5b.
732
-
733
- On **"Stop"**: Go to handle_blocker with "User stopped — tech debt to address. Run /ez:audit-milestone to review details."
734
-
735
- **5b. Complete Milestone**
736
-
737
- ```
738
- Skill(skill="ez:complete-milestone", args="${milestone_version}")
739
- ```
740
-
741
- After complete-milestone returns, verify it produced output:
742
-
743
- ```bash
744
- ls .planning/milestones/v${milestone_version}-ROADMAP.md 2>/dev/null
745
- ```
746
-
747
- If the archive file does not exist, go to handle_blocker: "Complete milestone did not produce expected archive files."
748
-
749
- **5c. Cleanup**
750
-
751
- ```
752
- Skill(skill="ez:cleanup")
753
- ```
754
-
755
- Cleanup shows its own dry-run and asks user for approval internally — this is an acceptable pause per CTRL-01 since it's an explicit decision about file deletion.
756
-
757
- **5d. Final Completion**
758
-
759
- Display final completion banner:
760
-
761
- ```
762
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
763
- EZ ► AUTONOMOUS ▸ COMPLETE 🎉
764
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
765
-
766
- Milestone: {milestone_version} — {milestone_name}
767
- Status: Complete ✅
768
- Lifecycle: audit ✅ → complete ✅ → cleanup ✅
769
- All Tasks: {total_tasks} executed across {phase_count} phases
770
-
771
- Ship it! 🚀
772
- ```
773
-
774
- </step>
775
-
776
- <step name="handle_blocker">
777
-
778
- ## 6. Handle Blocker
779
-
780
- When any phase operation fails or a blocker is detected, present 3 options via AskUserQuestion:
781
-
782
- **Prompt:** "Phase {N} ({Name}), Task {task_num} encountered an issue: {description}"
783
-
784
- **Options:**
785
- 1. **"Fix and retry"** — Re-run the failed step (discuss, plan, or execute) for this task
786
- 2. **"Skip this task"** — Mark task as skipped, continue to next task in same phase
787
- 3. **"Stop autonomous mode"** — Display summary of progress so far and exit cleanly
788
-
789
- **On "Fix and retry":** Loop back to the failed step within execute_phase. If the same step fails again after retry, re-present these options.
790
-
791
- **On "Skip this task":** Log `Phase {N}, Task {task_num} ⏭ {task_name} — Skipped by user` and continue to next task in the phase loop.
792
-
793
- **On "Stop autonomous mode":** Display progress summary:
794
-
795
- ```
796
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
797
- EZ ► AUTONOMOUS ▸ STOPPED
798
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
799
-
800
- Completed Phases: {list of completed phases}
801
- In Progress: Phase {N}, Task {task_num}
802
- Skipped Tasks: {list of skipped tasks}
803
- Remaining Tasks: {count} tasks in {count} phases
804
-
805
- Resume with: /ez:autonomous --from {current_phase}
806
- ```
807
-
808
- </step>
809
-
810
- </process>
811
-
812
- <success_criteria>
813
- - [ ] All incomplete phases executed in order (smart discuss → plan → execute each)
814
- - [ ] Smart discuss proposes grey area answers in tables, user accepts or overrides per area
815
- - [ ] Progress banners displayed between phases
816
- - [ ] Execute-phase loops through ALL task plans within each phase
817
- - [ ] Each task plan executed individually with --plan {N} flag
818
- - [ ] Task progress displayed during loop ([████░░░░] X/Y completed)
819
- - [ ] Task completion verified after each execution
820
- - [ ] Failed/blocked tasks route to handle_blocker
821
- - [ ] After ALL tasks complete, phase verification runs
822
- - [ ] Post-execution verification reads VERIFICATION.md and routes on status
823
- - [ ] Passed verification → automatic continue to next phase
824
- - [ ] Human-needed verification → user prompted to validate or skip
825
- - [ ] Gaps-found → user offered gap closure, continue, or stop
826
- - [ ] Gap closure re-executes ALL gap tasks in loop
827
- - [ ] Gap closure limited to 1 retry (prevents infinite loops)
828
- - [ ] Plan-phase and execute-phase failures route to handle_blocker
829
- - [ ] ROADMAP.md re-read after each phase (catches inserted phases)
830
- - [ ] STATE.md checked for blockers before each phase
831
- - [ ] Blockers handled via user choice (retry / skip / stop)
832
- - [ ] Task-level blocker handling (skip task vs skip phase)
833
- - [ ] Final completion or stop summary displayed
834
- - [ ] After all phases complete, lifecycle step is invoked (not manual suggestion)
835
- - [ ] Lifecycle transition banner displayed before audit
836
- - [ ] Audit invoked via Skill(skill="ez:audit-milestone")
837
- - [ ] Audit result routing: passed → auto-continue, gaps_found → user decides, tech_debt → user decides
838
- - [ ] Audit technical failure (no file/no status) routes to handle_blocker
839
- - [ ] Complete-milestone invoked via Skill() with ${milestone_version} arg
840
- - [ ] Cleanup invoked via Skill() — internal confirmation is acceptable (CTRL-01)
841
- - [ ] Final completion banner displays total task count
842
- - [ ] Progress bar uses phase number / total milestone phases (not position among incomplete)
843
- - [ ] Smart discuss documents relationship to discuss-phase with CTRL-03 note
844
- </success_criteria>
1
+ <purpose>
2
+
3
+ Drive all remaining milestone phases autonomously. For each incomplete phase: discuss → plan → execute **ALL tasks in loop** using Skill() flat invocations. Pauses only for explicit user decisions (grey area acceptance, blockers, validation requests). Re-reads ROADMAP.md after each phase to catch dynamically inserted phases.
4
+
5
+ **Key:** Execute-phase loops through ALL task plans within a phase, not just the phase as a whole.
6
+
7
+ </purpose>
8
+
9
+ <required_reading>
10
+
11
+ Read all files referenced by the invoking prompt's execution_context before starting.
12
+
13
+ </required_reading>
14
+
15
+ <process>
16
+
17
+ <step name="initialize" priority="first">
18
+
19
+ ## 1. Initialize
20
+
21
+ Parse `$ARGUMENTS` for `--from N` flag:
22
+
23
+ ```bash
24
+ FROM_PHASE=""
25
+ if echo "$ARGUMENTS" | grep -qE '\-\-from\s+[0-9]'; then
26
+ FROM_PHASE=$(echo "$ARGUMENTS" | grep -oE '\-\-from\s+[0-9]+\.?[0-9]*' | awk '{print $2}')
27
+ fi
28
+ ```
29
+
30
+ Bootstrap via milestone-level init:
31
+
32
+ ```bash
33
+ INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init milestone-op)
34
+ ```
35
+
36
+ Parse JSON for: `milestone_version`, `milestone_name`, `phase_count`, `completed_phases`, `roadmap_exists`, `state_exists`, `commit_docs`.
37
+
38
+ **If `roadmap_exists` is false:** Error — "No ROADMAP.md found. Run `/ez:new-milestone` first."
39
+ **If `state_exists` is false:** Error — "No STATE.md found. Run `/ez:new-milestone` first."
40
+
41
+ Display startup banner:
42
+
43
+ ```
44
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
45
+ EZ ► AUTONOMOUS
46
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
47
+
48
+ Milestone: {milestone_version} — {milestone_name}
49
+ Phases: {phase_count} total, {completed_phases} complete
50
+ ```
51
+
52
+ If `FROM_PHASE` is set, display: `Starting from phase ${FROM_PHASE}`
53
+
54
+ </step>
55
+
56
+ <step name="discover_phases">
57
+
58
+ ## 2. Discover Phases
59
+
60
+ Run phase discovery:
61
+
62
+ ```bash
63
+ ROADMAP=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap analyze)
64
+ ```
65
+
66
+ Parse the JSON `phases` array.
67
+
68
+ **Filter to incomplete phases:** Keep only phases where `disk_status !== "complete"` OR `roadmap_complete === false`.
69
+
70
+ **Apply `--from N` filter:** If `FROM_PHASE` was provided, additionally filter out phases where `number < FROM_PHASE` (use numeric comparison — handles decimal phases like "5.1").
71
+
72
+ **Sort by `number`** in numeric ascending order.
73
+
74
+ **If no incomplete phases remain:**
75
+
76
+ ```
77
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
78
+ EZ ► AUTONOMOUS ▸ COMPLETE 🎉
79
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
80
+
81
+ All phases complete! Nothing left to do.
82
+ ```
83
+
84
+ Exit cleanly.
85
+
86
+ **Display phase plan:**
87
+
88
+ ```
89
+ ## Phase Plan
90
+
91
+ | # | Phase | Status | Tasks |
92
+ |---|-------|--------|-------|
93
+ | 5 | Skill Scaffolding & Phase Discovery | In Progress | [count] |
94
+ | 6 | Smart Discuss | Not Started | [count] |
95
+ | 7 | Auto-Chain Refinements | Not Started | [count] |
96
+ | 8 | Lifecycle Orchestration | Not Started | [count] |
97
+ ```
98
+
99
+ **Fetch details for each phase:**
100
+
101
+ ```bash
102
+ DETAIL=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap get-phase ${PHASE_NUM})
103
+ ```
104
+
105
+ Extract `phase_name`, `goal`, `success_criteria`, `task_count` from each. Store for use in execute_phase and transition messages.
106
+
107
+ </step>
108
+
109
+ <step name="execute_phase">
110
+
111
+ ## 3. Execute Phase (with Task Loop)
112
+
113
+ For the current phase, display the progress banner:
114
+
115
+ ```
116
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
117
+ EZ ► AUTONOMOUS ▸ Phase {N}/{T}: {Name} [████░░░░] {P}%
118
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
119
+
120
+ Phase {N} has {task_count} tasks to execute
121
+ ```
122
+
123
+ Where N = current phase number (from the ROADMAP, e.g., 6), T = total milestone phases (from `phase_count` parsed in initialize step, e.g., 8), P = percentage of all milestone phases completed so far.
124
+
125
+ **3a. Smart Discuss**
126
+
127
+ Check if CONTEXT.md already exists for this phase:
128
+
129
+ ```bash
130
+ PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
131
+ ```
132
+
133
+ Parse `has_context` from JSON.
134
+
135
+ **If has_context is true:** Skip discuss — context already gathered. Display:
136
+
137
+ ```
138
+ Phase ${PHASE_NUM}: Context exists — skipping discuss.
139
+ ```
140
+
141
+ Proceed to 3b.
142
+
143
+ **If has_context is false:** Execute the smart_discuss step for this phase.
144
+
145
+ After smart_discuss completes, verify context was written:
146
+
147
+ ```bash
148
+ PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
149
+ ```
150
+
151
+ Check `has_context`. If false → go to handle_blocker: "Smart discuss for phase ${PHASE_NUM} did not produce CONTEXT.md."
152
+
153
+ **3b. Plan**
154
+
155
+ ```
156
+ Skill(skill="ez:plan-phase", args="${PHASE_NUM}")
157
+ ```
158
+
159
+ Verify plan produced output — re-run `init phase-op` and check `has_plans`. If false → go to handle_blocker: "Plan phase ${PHASE_NUM} did not produce any plans."
160
+
161
+ **Get task list for loop:**
162
+
163
+ ```bash
164
+ PLANS=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-list-plans ${PHASE_NUM})
165
+ ```
166
+
167
+ Parse JSON for: `plans` array with `plan_number`, `plan_name`, `task_description`, `status` for each plan.
168
+
169
+ **Filter to incomplete plans:** Keep only plans where `status !== "complete"`.
170
+
171
+ **Store for task loop:** `plan_list` = array of incomplete plans.
172
+
173
+ **3c. Execute ALL Tasks in Loop**
174
+
175
+ Display task execution banner:
176
+
177
+ ```
178
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
179
+ EZ ► AUTONOMOUS ▸ Phase {N} Task Execution
180
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
181
+
182
+ {task_count} tasks to execute in Phase {N}
183
+ ```
184
+
185
+ **For each plan in `plan_list` (loop through ALL tasks):**
186
+
187
+ ```
188
+ FOR EACH plan IN plan_list:
189
+ ```
190
+
191
+ **3c-i. Display task progress:**
192
+
193
+ ```
194
+ Task {plan.plan_number}/{task_count}: {plan.plan_name}
195
+ [████░░░░] {completed_tasks}/{total_tasks} completed
196
+ ```
197
+
198
+ **3c-ii. Execute single task:**
199
+
200
+ ```
201
+ Skill(skill="ez:execute-phase", args="${PHASE_NUM} --plan ${plan.plan_number} --no-transition")
202
+ ```
203
+
204
+ **3c-iii. Verify task completion:**
205
+
206
+ ```bash
207
+ TASK_STATUS=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-get-task-status ${PHASE_NUM} ${plan.plan_number})
208
+ ```
209
+
210
+ Parse `status` from JSON (values: "complete", "in_progress", "blocked", "failed").
211
+
212
+ **If `complete`:**
213
+ - Display: `✅ Task ${plan.plan_number}: ${plan.plan_name} — Complete`
214
+ - Mark task as completed in local tracking
215
+ - Continue to next task in loop
216
+
217
+ **If `in_progress`:**
218
+ - Display: `⚠ Task ${plan.plan_number}: ${plan.plan_name} — Still in progress`
219
+ - Retry status check once (wait 30 seconds)
220
+ - If still `in_progress` → go to handle_blocker: "Task ${plan.plan_number} did not complete"
221
+
222
+ **If `blocked` or `failed`:**
223
+ - Read error/blocker details from task status
224
+ - Go to handle_blocker with: "Task ${plan.plan_number} (${plan.plan_name}) ${status}: {details}"
225
+
226
+ **3c-iv. After each task completes, update phase progress:**
227
+
228
+ ```bash
229
+ node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-update-progress ${PHASE_NUM}
230
+ ```
231
+
232
+ **End loop** (continue to next plan in plan_list)
233
+
234
+ **After ALL tasks complete:**
235
+
236
+ Display phase completion banner:
237
+
238
+ ```
239
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
240
+ EZ ► AUTONOMOUS ▸ Phase {N} Complete ✅
241
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
242
+
243
+ All {task_count} tasks completed successfully
244
+ Phase {N}: {phase_name} — DONE
245
+ ```
246
+
247
+ **3d. Post-Execution Verification**
248
+
249
+ After all tasks in the phase complete, read the verification result:
250
+
251
+ ```bash
252
+ VERIFY_STATUS=$(grep "^status:" "${PHASE_DIR}"/*-VERIFICATION.md 2>/dev/null | head -1 | cut -d: -f2 | tr -d ' ')
253
+ ```
254
+
255
+ Where `PHASE_DIR` comes from the `init phase-op` call already made in step 3a. If the variable is not in scope, re-fetch:
256
+
257
+ ```bash
258
+ PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
259
+ ```
260
+
261
+ Parse `phase_dir` from the JSON.
262
+
263
+ **If VERIFY_STATUS is empty** (no VERIFICATION.md or no status field):
264
+
265
+ Go to handle_blocker: "Execute phase ${PHASE_NUM} did not produce verification results."
266
+
267
+ **If `passed`:**
268
+
269
+ Display:
270
+ ```
271
+ Phase ${PHASE_NUM} ✅ ${PHASE_NAME} — Verification passed
272
+ All {task_count} tasks verified
273
+ ```
274
+
275
+ Proceed to iterate step.
276
+
277
+ **If `human_needed`:**
278
+
279
+ Read the human_verification section from VERIFICATION.md to get the count and items requiring manual testing.
280
+
281
+ Display the items, then ask user via AskUserQuestion:
282
+ - **question:** "Phase ${PHASE_NUM} has {N} items needing manual verification. Validate now or continue to next phase?"
283
+ - **options:** "Validate now" / "Continue without validation"
284
+
285
+ On **"Validate now"**: Present the specific items from VERIFICATION.md's human_verification section. After user reviews, ask:
286
+ - **question:** "Validation result?"
287
+ - **options:** "All good — continue" / "Found issues"
288
+
289
+ On "All good — continue": Display `Phase ${PHASE_NUM} ✅ Human validation passed` and proceed to iterate step.
290
+
291
+ On "Found issues": Go to handle_blocker with the user's reported issues as the description.
292
+
293
+ On **"Continue without validation"**: Display `Phase ${PHASE_NUM} ⏭ Human validation deferred` and proceed to iterate step.
294
+
295
+ **If `gaps_found`:**
296
+
297
+ Read gap summary from VERIFICATION.md (score and missing items). Display:
298
+ ```
299
+ ⚠ Phase ${PHASE_NUM}: ${PHASE_NAME} — Gaps Found
300
+ Score: {N}/{M} must-haves verified
301
+ {gap_count} tasks have gaps
302
+ ```
303
+
304
+ Ask user via AskUserQuestion:
305
+ - **question:** "Gaps found in phase ${PHASE_NUM}. How to proceed?"
306
+ - **options:** "Run gap closure" / "Continue without fixing" / "Stop autonomous mode"
307
+
308
+ On **"Run gap closure"**: Execute gap closure cycle (limit: 1 attempt):
309
+
310
+ ```
311
+ Skill(skill="ez:plan-phase", args="${PHASE_NUM} --gaps")
312
+ ```
313
+
314
+ Verify gap plans were created — re-run `init phase-op ${PHASE_NUM}` and check `has_plans`. If no new gap plans → go to handle_blocker: "Gap closure planning for phase ${PHASE_NUM} did not produce plans."
315
+
316
+ **Re-execute ALL gap tasks in loop:**
317
+
318
+ ```bash
319
+ GAP_PLANS=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" phase-list-plans ${PHASE_NUM} --gap-only)
320
+ ```
321
+
322
+ For each gap plan in GAP_PLANS:
323
+ ```
324
+ Skill(skill="ez:execute-phase", args="${PHASE_NUM} --plan ${gap_plan.number} --no-transition")
325
+ ```
326
+
327
+ Re-read verification status:
328
+ ```bash
329
+ VERIFY_STATUS=$(grep "^status:" "${PHASE_DIR}"/*-VERIFICATION.md 2>/dev/null | head -1 | cut -d: -f2 | tr -d ' ')
330
+ ```
331
+
332
+ If `passed` or `human_needed`: Route normally (continue or ask user as above).
333
+
334
+ If still `gaps_found` after this retry: Display "Gaps persist after closure attempt." and ask via AskUserQuestion:
335
+ - **question:** "Gap closure did not fully resolve issues. How to proceed?"
336
+ - **options:** "Continue anyway" / "Stop autonomous mode"
337
+
338
+ On "Continue anyway": Proceed to iterate step.
339
+ On "Stop autonomous mode": Go to handle_blocker.
340
+
341
+ This limits gap closure to 1 automatic retry to prevent infinite loops.
342
+
343
+ On **"Continue without fixing"**: Display `Phase ${PHASE_NUM} ⏭ Gaps deferred` and proceed to iterate step.
344
+
345
+ On **"Stop autonomous mode"**: Go to handle_blocker with "User stopped — gaps remain in phase ${PHASE_NUM}".
346
+
347
+ </step>
348
+
349
+ <step name="smart_discuss">
350
+
351
+ ## Smart Discuss
352
+
353
+ Run smart discuss for the current phase. Proposes grey area answers in batch tables — the user accepts or overrides per area. Produces identical CONTEXT.md output to regular discuss-phase.
354
+
355
+ > **Note:** Smart discuss is an autonomous-optimized variant of the `ez:discuss-phase` skill. It produces identical CONTEXT.md output but uses batch table proposals instead of sequential questioning. The original `discuss-phase` skill remains unchanged (per CTRL-03). Future milestones may extract this to a separate skill file.
356
+
357
+ **Inputs:** `PHASE_NUM` from execute_phase. Run init to get phase paths:
358
+
359
+ ```bash
360
+ PHASE_STATE=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op ${PHASE_NUM})
361
+ ```
362
+
363
+ Parse from JSON: `phase_dir`, `phase_slug`, `padded_phase`, `phase_name`.
364
+
365
+ ---
366
+
367
+ ### Sub-step 1: Load prior context
368
+
369
+ Read project-level and prior phase context to avoid re-asking decided questions.
370
+
371
+ **Read project files:**
372
+
373
+ ```bash
374
+ cat .planning/PROJECT.md 2>/dev/null
375
+ cat .planning/REQUIREMENTS.md 2>/dev/null
376
+ cat .planning/STATE.md 2>/dev/null
377
+ ```
378
+
379
+ Extract from these:
380
+ - **PROJECT.md** — Vision, principles, non-negotiables, user preferences
381
+ - **REQUIREMENTS.md** — Acceptance criteria, constraints, must-haves vs nice-to-haves
382
+ - **STATE.md** — Current progress, decisions logged so far
383
+
384
+ **Read all prior CONTEXT.md files:**
385
+
386
+ ```bash
387
+ find .planning/phases -name "*-CONTEXT.md" 2>/dev/null | sort
388
+ ```
389
+
390
+ For each CONTEXT.md where phase number < current phase:
391
+ - Read the `<decisions>` section — these are locked preferences
392
+ - Read `<specifics>` — particular references or "I want it like X" moments
393
+ - Note patterns (e.g., "user consistently prefers minimal UI", "user rejected verbose output")
394
+
395
+ **Build internal prior_decisions context** (do not write to file):
396
+
397
+ ```
398
+ <prior_decisions>
399
+ ## Project-Level
400
+ - [Key principle or constraint from PROJECT.md]
401
+ - [Requirement affecting this phase from REQUIREMENTS.md]
402
+
403
+ ## From Prior Phases
404
+ ### Phase N: [Name]
405
+ - [Decision relevant to current phase]
406
+ - [Preference that establishes a pattern]
407
+ </prior_decisions>
408
+ ```
409
+
410
+ If no prior context exists, continue without — expected for early phases.
411
+
412
+ ---
413
+
414
+ ### Sub-step 2: Scout Codebase
415
+
416
+ Lightweight codebase scan to inform grey area identification and proposals. Keep under ~5% context.
417
+
418
+ **Check for existing codebase maps:**
419
+
420
+ ```bash
421
+ ls .planning/codebase/*.md 2>/dev/null
422
+ ```
423
+
424
+ **If codebase maps exist:** Read the most relevant ones (CONVENTIONS.md, STRUCTURE.md, STACK.md based on phase type). Extract reusable components, established patterns, integration points. Skip to building context below.
425
+
426
+ **If no codebase maps, do targeted grep:**
427
+
428
+ Extract key terms from the phase goal. Search for related files:
429
+
430
+ ```bash
431
+ grep -rl "{term1}\|{term2}" src/ app/ --include="*.ts" --include="*.tsx" --include="*.js" --include="*.jsx" 2>/dev/null | head -10
432
+ ls src/components/ src/hooks/ src/lib/ src/utils/ 2>/dev/null
433
+ ```
434
+
435
+ Read the 3-5 most relevant files to understand existing patterns.
436
+
437
+ **Build internal codebase_context** (do not write to file):
438
+ - **Reusable assets** — existing components, hooks, utilities usable in this phase
439
+ - **Established patterns** — how the codebase does state management, styling, data fetching
440
+ - **Integration points** — where new code connects (routes, nav, providers)
441
+
442
+ ---
443
+
444
+ ### Sub-step 3: Analyze Phase and Generate Proposals
445
+
446
+ **Get phase details:**
447
+
448
+ ```bash
449
+ DETAIL=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap get-phase ${PHASE_NUM})
450
+ ```
451
+
452
+ Extract `goal`, `requirements`, `success_criteria`, `task_count` from the JSON response.
453
+
454
+ **Infrastructure detection — check FIRST before generating grey areas:**
455
+
456
+ A phase is pure infrastructure when ALL of these are true:
457
+ 1. Goal keywords match: "scaffolding", "plumbing", "setup", "configuration", "migration", "refactor", "rename", "restructure", "upgrade", "infrastructure"
458
+ 2. AND success criteria are all technical: "file exists", "test passes", "config valid", "command runs"
459
+ 3. AND no user-facing behavior is described (no "users can", "displays", "shows", "presents")
460
+
461
+ **If infrastructure-only:** Skip Sub-step 4. Jump directly to Sub-step 5 with minimal CONTEXT.md. Display:
462
+
463
+ ```
464
+ Phase ${PHASE_NUM}: Infrastructure phase — skipping discuss, writing minimal context.
465
+ ```
466
+
467
+ Use these defaults for the CONTEXT.md:
468
+ - `<domain>`: Phase boundary from ROADMAP goal
469
+ - `<decisions>`: Single "### Claude's Discretion" subsection — "All implementation choices are at Claude's discretion — pure infrastructure phase"
470
+ - `<code_context>`: Whatever the codebase scout found
471
+ - `<specifics>`: "No specific requirements — infrastructure phase"
472
+ - `<deferred>`: "None"
473
+
474
+ **If NOT infrastructure — generate grey area proposals:**
475
+
476
+ Determine domain type from the phase goal:
477
+ - Something users **SEE** → visual: layout, interactions, states, density
478
+ - Something users **CALL** → interface: contracts, responses, errors, auth
479
+ - Something users **RUN** → execution: invocation, output, behavior modes, flags
480
+ - Something users **READ** → content: structure, tone, depth, flow
481
+ - Something being **ORGANIZED** → organization: criteria, grouping, exceptions, naming
482
+
483
+ Check prior_decisions — skip grey areas already decided in prior phases.
484
+
485
+ Generate **3-4 grey areas** with **~4 questions each**. For each question:
486
+ - **Pre-select a recommended answer** based on: prior decisions (consistency), codebase patterns (reuse), domain conventions (standard approaches), ROADMAP success criteria
487
+ - Generate **1-2 alternatives** per question
488
+ - **Annotate** with prior decision context ("You decided X in Phase N") and code context ("Component Y exists with Z variants") where relevant
489
+
490
+ ---
491
+
492
+ ### Sub-step 4: Present Proposals Per Area
493
+
494
+ Present grey areas **one at a time**. For each area (M of N):
495
+
496
+ Display a table:
497
+
498
+ ```
499
+ ### Grey Area {M}/{N}: {Area Name}
500
+
501
+ | # | Question | ✅ Recommended | Alternative(s) |
502
+ |---|----------|---------------|-----------------|
503
+ | 1 | {question} | {answer} — {rationale} | {alt1}; {alt2} |
504
+ | 2 | {question} | {answer} — {rationale} | {alt1} |
505
+ | 3 | {question} | {answer} — {rationale} | {alt1}; {alt2} |
506
+ | 4 | {question} | {answer} — {rationale} | {alt1} |
507
+ ```
508
+
509
+ Then prompt the user via **AskUserQuestion**:
510
+ - **header:** "Area {M}/{N}"
511
+ - **question:** "Accept these answers for {Area Name}?"
512
+ - **options:** Build dynamically — always "Accept all" first, then "Change Q1" through "Change QN" for each question (up to 4), then "Discuss deeper" last. Cap at 6 explicit options max (AskUserQuestion adds "Other" automatically).
513
+
514
+ **On "Accept all":** Record all recommended answers for this area. Move to next area.
515
+
516
+ **On "Change QN":** Use AskUserQuestion with the alternatives for that specific question:
517
+ - **header:** "{Area Name}"
518
+ - **question:** "Q{N}: {question text}"
519
+ - **options:** List the 1-2 alternatives plus "You decide" (maps to Claude's Discretion)
520
+
521
+ Record the user's choice. Re-display the updated table with the change reflected. Re-present the full acceptance prompt so the user can make additional changes or accept.
522
+
523
+ **On "Discuss deeper":** Switch to interactive mode for this area only — ask questions one at a time using AskUserQuestion with 2-3 concrete options per question plus "You decide". After 4 questions, prompt:
524
+ - **header:** "{Area Name}"
525
+ - **question:** "More questions about {area name}, or move to next?"
526
+ - **options:** "More questions" / "Next area"
527
+
528
+ If "More questions", ask 4 more. If "Next area", display final summary table of captured answers for this area and move on.
529
+
530
+ **On "Other" (free text):** Interpret as either a specific change request or general feedback. Incorporate into the area's decisions, re-display updated table, re-present acceptance prompt.
531
+
532
+ **Scope creep handling:** If user mentions something outside the phase domain:
533
+
534
+ ```
535
+ "{Feature} sounds like a new capability — that belongs in its own phase.
536
+ I'll note it as a deferred idea.
537
+
538
+ Back to {current area}: {return to current question}"
539
+ ```
540
+
541
+ Track deferred ideas internally for inclusion in CONTEXT.md.
542
+
543
+ ---
544
+
545
+ ### Sub-step 5: Write CONTEXT.md
546
+
547
+ After all areas are resolved (or infrastructure skip), write the CONTEXT.md file.
548
+
549
+ **File path:** `${phase_dir}/${padded_phase}-CONTEXT.md`
550
+
551
+ Use **exactly** this structure (identical to discuss-phase output):
552
+
553
+ ```markdown
554
+ # Phase {PHASE_NUM}: {Phase Name} - Context
555
+
556
+ **Gathered:** {date}
557
+ **Status:** Ready for planning
558
+
559
+ <domain>
560
+ ## Phase Boundary
561
+
562
+ {Domain boundary statement from analysis — what this phase delivers}
563
+
564
+ </domain>
565
+
566
+ <decisions>
567
+ ## Implementation Decisions
568
+
569
+ ### {Area 1 Name}
570
+ - {Accepted/chosen answer for Q1}
571
+ - {Accepted/chosen answer for Q2}
572
+ - {Accepted/chosen answer for Q3}
573
+ - {Accepted/chosen answer for Q4}
574
+
575
+ ### {Area 2 Name}
576
+ - {Accepted/chosen answer for Q1}
577
+ - {Accepted/chosen answer for Q2}
578
+ ...
579
+
580
+ ### Claude's Discretion
581
+ {Any "You decide" answers collected — note Claude has flexibility here}
582
+
583
+ </decisions>
584
+
585
+ <code_context>
586
+ ## Existing Code Insights
587
+
588
+ ### Reusable Assets
589
+ - {From codebase scout — components, hooks, utilities}
590
+
591
+ ### Established Patterns
592
+ - {From codebase scout — state management, styling, data fetching}
593
+
594
+ ### Integration Points
595
+ - {From codebase scout — where new code connects}
596
+
597
+ </code_context>
598
+
599
+ <specifics>
600
+ ## Specific Ideas
601
+
602
+ {Any specific references or "I want it like X" from discussion}
603
+ {If none: "No specific requirements — open to standard approaches"}
604
+
605
+ </specifics>
606
+
607
+ <deferred>
608
+ ## Deferred Ideas
609
+
610
+ {Ideas captured but out of scope for this phase}
611
+ {If none: "None — discussion stayed within phase scope"}
612
+
613
+ </deferred>
614
+ ```
615
+
616
+ Write the file.
617
+
618
+ **Commit:**
619
+
620
+ ```bash
621
+ node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" commit "docs(${PADDED_PHASE}): smart discuss context" --files "${phase_dir}/${padded_phase}-CONTEXT.md"
622
+ ```
623
+
624
+ Display confirmation:
625
+
626
+ ```
627
+ Created: {path}
628
+ Decisions captured: {count} across {area_count} areas
629
+ ```
630
+
631
+ </step>
632
+
633
+ <step name="iterate">
634
+
635
+ ## 4. Iterate
636
+
637
+ After each phase completes (ALL tasks executed), re-read ROADMAP.md to catch phases inserted mid-execution (decimal phases like 5.1):
638
+
639
+ ```bash
640
+ ROADMAP=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" roadmap analyze)
641
+ ```
642
+
643
+ Re-filter incomplete phases using the same logic as discover_phases:
644
+ - Keep phases where `disk_status !== "complete"` OR `roadmap_complete === false`
645
+ - Apply `--from N` filter if originally provided
646
+ - Sort by number ascending
647
+
648
+ Read STATE.md fresh:
649
+
650
+ ```bash
651
+ cat .planning/STATE.md
652
+ ```
653
+
654
+ Check for blockers in the Blockers/Concerns section. If blockers are found, go to handle_blocker with the blocker description.
655
+
656
+ If incomplete phases remain: proceed to next phase, loop back to execute_phase.
657
+
658
+ If all phases complete: proceed to lifecycle step.
659
+
660
+ </step>
661
+
662
+ <step name="lifecycle">
663
+
664
+ ## 5. Lifecycle
665
+
666
+ After all phases complete, run the milestone lifecycle sequence: audit → complete → cleanup.
667
+
668
+ Display lifecycle transition banner:
669
+
670
+ ```
671
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
672
+ EZ ► AUTONOMOUS ▸ LIFECYCLE
673
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
674
+
675
+ All phases complete → Starting lifecycle: audit → complete → cleanup
676
+ Milestone: {milestone_version} — {milestone_name}
677
+ ```
678
+
679
+ **5a. Audit**
680
+
681
+ ```
682
+ Skill(skill="ez:audit-milestone")
683
+ ```
684
+
685
+ After audit completes, detect the result:
686
+
687
+ ```bash
688
+ AUDIT_FILE=".planning/v${milestone_version}-MILESTONE-AUDIT.md"
689
+ AUDIT_STATUS=$(grep "^status:" "${AUDIT_FILE}" 2>/dev/null | head -1 | cut -d: -f2 | tr -d ' ')
690
+ ```
691
+
692
+ **If AUDIT_STATUS is empty** (no audit file or no status field):
693
+
694
+ Go to handle_blocker: "Audit did not produce results — audit file missing or malformed."
695
+
696
+ **If `passed`:**
697
+
698
+ Display:
699
+ ```
700
+ Audit ✅ passed — proceeding to complete milestone
701
+ ```
702
+
703
+ Proceed to 5b (no user pause — per CTRL-01).
704
+
705
+ **If `gaps_found`:**
706
+
707
+ Read the gaps summary from the audit file. Display:
708
+ ```
709
+ ⚠ Audit: Gaps Found
710
+ ```
711
+
712
+ Ask user via AskUserQuestion:
713
+ - **question:** "Milestone audit found gaps. How to proceed?"
714
+ - **options:** "Continue anyway — accept gaps" / "Stop — fix gaps manually"
715
+
716
+ On **"Continue anyway"**: Display `Audit ⏭ Gaps accepted — proceeding to complete milestone` and proceed to 5b.
717
+
718
+ On **"Stop"**: Go to handle_blocker with "User stopped — audit gaps remain. Run /ez:audit-milestone to review, then /ez:complete-milestone when ready."
719
+
720
+ **If `tech_debt`:**
721
+
722
+ Read the tech debt summary from the audit file. Display:
723
+ ```
724
+ ⚠ Audit: Tech Debt Identified
725
+ ```
726
+
727
+ Show the summary, then ask user via AskUserQuestion:
728
+ - **question:** "Milestone audit found tech debt. How to proceed?"
729
+ - **options:** "Continue with tech debt" / "Stop — address debt first"
730
+
731
+ On **"Continue with tech debt"**: Display `Audit ⏭ Tech debt acknowledged — proceeding to complete milestone` and proceed to 5b.
732
+
733
+ On **"Stop"**: Go to handle_blocker with "User stopped — tech debt to address. Run /ez:audit-milestone to review details."
734
+
735
+ **5b. Complete Milestone**
736
+
737
+ ```
738
+ Skill(skill="ez:complete-milestone", args="${milestone_version}")
739
+ ```
740
+
741
+ After complete-milestone returns, verify it produced output:
742
+
743
+ ```bash
744
+ ls .planning/milestones/v${milestone_version}-ROADMAP.md 2>/dev/null
745
+ ```
746
+
747
+ If the archive file does not exist, go to handle_blocker: "Complete milestone did not produce expected archive files."
748
+
749
+ **5c. Cleanup**
750
+
751
+ ```
752
+ Skill(skill="ez:cleanup")
753
+ ```
754
+
755
+ Cleanup shows its own dry-run and asks user for approval internally — this is an acceptable pause per CTRL-01 since it's an explicit decision about file deletion.
756
+
757
+ **5d. Final Completion**
758
+
759
+ Display final completion banner:
760
+
761
+ ```
762
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
763
+ EZ ► AUTONOMOUS ▸ COMPLETE 🎉
764
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
765
+
766
+ Milestone: {milestone_version} — {milestone_name}
767
+ Status: Complete ✅
768
+ Lifecycle: audit ✅ → complete ✅ → cleanup ✅
769
+ All Tasks: {total_tasks} executed across {phase_count} phases
770
+
771
+ Ship it! 🚀
772
+ ```
773
+
774
+ </step>
775
+
776
+ <step name="handle_blocker">
777
+
778
+ ## 6. Handle Blocker
779
+
780
+ When any phase operation fails or a blocker is detected, present 3 options via AskUserQuestion:
781
+
782
+ **Prompt:** "Phase {N} ({Name}), Task {task_num} encountered an issue: {description}"
783
+
784
+ **Options:**
785
+ 1. **"Fix and retry"** — Re-run the failed step (discuss, plan, or execute) for this task
786
+ 2. **"Skip this task"** — Mark task as skipped, continue to next task in same phase
787
+ 3. **"Stop autonomous mode"** — Display summary of progress so far and exit cleanly
788
+
789
+ **On "Fix and retry":** Loop back to the failed step within execute_phase. If the same step fails again after retry, re-present these options.
790
+
791
+ **On "Skip this task":** Log `Phase {N}, Task {task_num} ⏭ {task_name} — Skipped by user` and continue to next task in the phase loop.
792
+
793
+ **On "Stop autonomous mode":** Display progress summary:
794
+
795
+ ```
796
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
797
+ EZ ► AUTONOMOUS ▸ STOPPED
798
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
799
+
800
+ Completed Phases: {list of completed phases}
801
+ In Progress: Phase {N}, Task {task_num}
802
+ Skipped Tasks: {list of skipped tasks}
803
+ Remaining Tasks: {count} tasks in {count} phases
804
+
805
+ Resume with: /ez:autonomous --from {current_phase}
806
+ ```
807
+
808
+ </step>
809
+
810
+ </process>
811
+
812
+ <success_criteria>
813
+ - [ ] All incomplete phases executed in order (smart discuss → plan → execute each)
814
+ - [ ] Smart discuss proposes grey area answers in tables, user accepts or overrides per area
815
+ - [ ] Progress banners displayed between phases
816
+ - [ ] Execute-phase loops through ALL task plans within each phase
817
+ - [ ] Each task plan executed individually with --plan {N} flag
818
+ - [ ] Task progress displayed during loop ([████░░░░] X/Y completed)
819
+ - [ ] Task completion verified after each execution
820
+ - [ ] Failed/blocked tasks route to handle_blocker
821
+ - [ ] After ALL tasks complete, phase verification runs
822
+ - [ ] Post-execution verification reads VERIFICATION.md and routes on status
823
+ - [ ] Passed verification → automatic continue to next phase
824
+ - [ ] Human-needed verification → user prompted to validate or skip
825
+ - [ ] Gaps-found → user offered gap closure, continue, or stop
826
+ - [ ] Gap closure re-executes ALL gap tasks in loop
827
+ - [ ] Gap closure limited to 1 retry (prevents infinite loops)
828
+ - [ ] Plan-phase and execute-phase failures route to handle_blocker
829
+ - [ ] ROADMAP.md re-read after each phase (catches inserted phases)
830
+ - [ ] STATE.md checked for blockers before each phase
831
+ - [ ] Blockers handled via user choice (retry / skip / stop)
832
+ - [ ] Task-level blocker handling (skip task vs skip phase)
833
+ - [ ] Final completion or stop summary displayed
834
+ - [ ] After all phases complete, lifecycle step is invoked (not manual suggestion)
835
+ - [ ] Lifecycle transition banner displayed before audit
836
+ - [ ] Audit invoked via Skill(skill="ez:audit-milestone")
837
+ - [ ] Audit result routing: passed → auto-continue, gaps_found → user decides, tech_debt → user decides
838
+ - [ ] Audit technical failure (no file/no status) routes to handle_blocker
839
+ - [ ] Complete-milestone invoked via Skill() with ${milestone_version} arg
840
+ - [ ] Cleanup invoked via Skill() — internal confirmation is acceptable (CTRL-01)
841
+ - [ ] Final completion banner displays total task count
842
+ - [ ] Progress bar uses phase number / total milestone phases (not position among incomplete)
843
+ - [ ] Smart discuss documents relationship to discuss-phase with CTRL-03 note
844
+ </success_criteria>