qualia-framework 2.5.1 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (327) hide show
  1. package/CLAUDE.md +63 -0
  2. package/README.md +108 -30
  3. package/agents/builder.md +110 -0
  4. package/agents/planner.md +186 -0
  5. package/agents/qa-browser.md +186 -0
  6. package/agents/verifier.md +369 -0
  7. package/bin/cli.js +706 -417
  8. package/bin/install.js +622 -0
  9. package/bin/qualia-ui.js +284 -0
  10. package/bin/state.js +824 -0
  11. package/bin/statusline.js +252 -0
  12. package/docs/erp-contract.md +161 -0
  13. package/guide.md +63 -0
  14. package/hooks/auto-update.js +117 -0
  15. package/hooks/block-env-edit.js +52 -0
  16. package/hooks/branch-guard.js +68 -0
  17. package/hooks/migration-guard.js +83 -0
  18. package/hooks/pre-compact.js +52 -0
  19. package/hooks/pre-deploy-gate.js +149 -0
  20. package/hooks/pre-push.js +53 -0
  21. package/hooks/session-start.js +126 -0
  22. package/package.json +31 -17
  23. package/rules/design-reference.md +179 -0
  24. package/rules/frontend.md +126 -0
  25. package/rules/infrastructure.md +87 -0
  26. package/skills/qualia/SKILL.md +88 -0
  27. package/skills/qualia-build/SKILL.md +115 -0
  28. package/skills/qualia-debug/SKILL.md +87 -0
  29. package/skills/qualia-design/SKILL.md +99 -0
  30. package/skills/qualia-handoff/SKILL.md +66 -0
  31. package/skills/qualia-help/SKILL.md +60 -0
  32. package/skills/qualia-idk/SKILL.md +8 -0
  33. package/skills/qualia-learn/SKILL.md +111 -0
  34. package/skills/qualia-new/SKILL.md +323 -0
  35. package/skills/qualia-pause/SKILL.md +63 -0
  36. package/skills/qualia-plan/SKILL.md +101 -0
  37. package/skills/qualia-polish/SKILL.md +207 -0
  38. package/skills/qualia-quick/SKILL.md +37 -0
  39. package/skills/qualia-report/SKILL.md +114 -0
  40. package/skills/qualia-resume/SKILL.md +49 -0
  41. package/skills/qualia-review/SKILL.md +161 -0
  42. package/skills/qualia-ship/SKILL.md +90 -0
  43. package/skills/qualia-skill-new/SKILL.md +167 -0
  44. package/skills/qualia-task/SKILL.md +91 -0
  45. package/skills/qualia-test/SKILL.md +134 -0
  46. package/skills/qualia-verify/SKILL.md +113 -0
  47. package/templates/DESIGN.md +475 -0
  48. package/templates/help.html +476 -0
  49. package/templates/plan.md +42 -0
  50. package/templates/project.md +22 -0
  51. package/templates/state.md +27 -0
  52. package/templates/tracking.json +20 -0
  53. package/tests/bin.test.sh +687 -0
  54. package/tests/hooks.test.sh +384 -0
  55. package/tests/runner.js +1956 -0
  56. package/tests/state.test.sh +713 -0
  57. package/tests/statusline.test.sh +243 -0
  58. package/bin/collect-metrics.sh +0 -62
  59. package/framework/.claudeignore +0 -51
  60. package/framework/CLAUDE.md +0 -51
  61. package/framework/MCP_SETUP.md +0 -229
  62. package/framework/agents/architecture-strategist.md +0 -53
  63. package/framework/agents/backend-agent.md +0 -150
  64. package/framework/agents/code-simplicity-reviewer.md +0 -86
  65. package/framework/agents/frontend-agent.md +0 -111
  66. package/framework/agents/kieran-typescript-reviewer.md +0 -96
  67. package/framework/agents/performance-oracle.md +0 -111
  68. package/framework/agents/qualia-codebase-mapper.md +0 -761
  69. package/framework/agents/qualia-debugger.md +0 -1204
  70. package/framework/agents/qualia-executor.md +0 -882
  71. package/framework/agents/qualia-integration-checker.md +0 -424
  72. package/framework/agents/qualia-phase-researcher.md +0 -457
  73. package/framework/agents/qualia-plan-checker.md +0 -700
  74. package/framework/agents/qualia-planner.md +0 -1245
  75. package/framework/agents/qualia-project-researcher.md +0 -603
  76. package/framework/agents/qualia-research-synthesizer.md +0 -200
  77. package/framework/agents/qualia-roadmapper.md +0 -606
  78. package/framework/agents/qualia-verifier.md +0 -686
  79. package/framework/agents/red-team-qa.md +0 -130
  80. package/framework/agents/security-auditor.md +0 -72
  81. package/framework/agents/team-orchestrator.md +0 -229
  82. package/framework/agents/teams/framework-audit-team.md +0 -66
  83. package/framework/agents/teams/full-stack-team.md +0 -48
  84. package/framework/agents/teams/optimize-team.md +0 -53
  85. package/framework/agents/teams/review-team.md +0 -70
  86. package/framework/agents/teams/ship-team.md +0 -86
  87. package/framework/agents/test-agent.md +0 -182
  88. package/framework/hooks/auto-format.sh +0 -54
  89. package/framework/hooks/block-env-edit.sh +0 -42
  90. package/framework/hooks/branch-guard.sh +0 -43
  91. package/framework/hooks/confirm-delete.sh +0 -59
  92. package/framework/hooks/migration-validate.sh +0 -77
  93. package/framework/hooks/notification-speak.sh +0 -16
  94. package/framework/hooks/pre-commit.sh +0 -100
  95. package/framework/hooks/pre-compact.sh +0 -56
  96. package/framework/hooks/pre-deploy-gate.sh +0 -160
  97. package/framework/hooks/qualia-colors.sh +0 -32
  98. package/framework/hooks/retention-cleanup.sh +0 -62
  99. package/framework/hooks/save-session-state.sh +0 -185
  100. package/framework/hooks/session-context-loader.sh +0 -96
  101. package/framework/hooks/session-learn.sh +0 -32
  102. package/framework/hooks/skill-announce.sh +0 -123
  103. package/framework/hooks/tool-error-announce.sh +0 -27
  104. package/framework/install.ps1 +0 -323
  105. package/framework/install.sh +0 -313
  106. package/framework/qualia-framework/VERSION +0 -1
  107. package/framework/qualia-framework/assets/qualia-logo.png +0 -0
  108. package/framework/qualia-framework/bin/collect-metrics.sh +0 -67
  109. package/framework/qualia-framework/bin/generate-report-docx.py +0 -429
  110. package/framework/qualia-framework/bin/qualia-tools.js +0 -2201
  111. package/framework/qualia-framework/bin/qualia-tools.test.js +0 -1054
  112. package/framework/qualia-framework/references/checkpoints.md +0 -775
  113. package/framework/qualia-framework/references/completion-checklists.md +0 -359
  114. package/framework/qualia-framework/references/continuation-format.md +0 -249
  115. package/framework/qualia-framework/references/continuation-prompt.md +0 -97
  116. package/framework/qualia-framework/references/decimal-phase-calculation.md +0 -65
  117. package/framework/qualia-framework/references/design-quality.md +0 -56
  118. package/framework/qualia-framework/references/employee-guide.md +0 -167
  119. package/framework/qualia-framework/references/git-integration.md +0 -254
  120. package/framework/qualia-framework/references/git-planning-commit.md +0 -50
  121. package/framework/qualia-framework/references/model-profile-resolution.md +0 -32
  122. package/framework/qualia-framework/references/model-profiles.md +0 -73
  123. package/framework/qualia-framework/references/phase-argument-parsing.md +0 -61
  124. package/framework/qualia-framework/references/planning-config.md +0 -195
  125. package/framework/qualia-framework/references/questioning.md +0 -141
  126. package/framework/qualia-framework/references/tdd.md +0 -263
  127. package/framework/qualia-framework/references/ui-brand.md +0 -160
  128. package/framework/qualia-framework/references/verification-patterns.md +0 -612
  129. package/framework/qualia-framework/templates/DEBUG.md +0 -159
  130. package/framework/qualia-framework/templates/DESIGN.md +0 -81
  131. package/framework/qualia-framework/templates/UAT.md +0 -247
  132. package/framework/qualia-framework/templates/codebase/architecture.md +0 -255
  133. package/framework/qualia-framework/templates/codebase/concerns.md +0 -310
  134. package/framework/qualia-framework/templates/codebase/conventions.md +0 -307
  135. package/framework/qualia-framework/templates/codebase/integrations.md +0 -280
  136. package/framework/qualia-framework/templates/codebase/stack.md +0 -186
  137. package/framework/qualia-framework/templates/codebase/structure.md +0 -285
  138. package/framework/qualia-framework/templates/codebase/testing.md +0 -480
  139. package/framework/qualia-framework/templates/config.json +0 -35
  140. package/framework/qualia-framework/templates/context.md +0 -283
  141. package/framework/qualia-framework/templates/continue-here.md +0 -78
  142. package/framework/qualia-framework/templates/debug-subagent-prompt.md +0 -91
  143. package/framework/qualia-framework/templates/discovery.md +0 -146
  144. package/framework/qualia-framework/templates/lab-notes.md +0 -16
  145. package/framework/qualia-framework/templates/milestone-archive.md +0 -123
  146. package/framework/qualia-framework/templates/milestone.md +0 -115
  147. package/framework/qualia-framework/templates/phase-prompt.md +0 -567
  148. package/framework/qualia-framework/templates/planner-subagent-prompt.md +0 -117
  149. package/framework/qualia-framework/templates/project.md +0 -184
  150. package/framework/qualia-framework/templates/projects/ai-agent.md +0 -156
  151. package/framework/qualia-framework/templates/projects/mobile-app.md +0 -181
  152. package/framework/qualia-framework/templates/projects/voice-agent.md +0 -134
  153. package/framework/qualia-framework/templates/projects/website.md +0 -137
  154. package/framework/qualia-framework/templates/requirements.md +0 -231
  155. package/framework/qualia-framework/templates/research-project/ARCHITECTURE.md +0 -204
  156. package/framework/qualia-framework/templates/research-project/FEATURES.md +0 -147
  157. package/framework/qualia-framework/templates/research-project/PITFALLS.md +0 -200
  158. package/framework/qualia-framework/templates/research-project/STACK.md +0 -120
  159. package/framework/qualia-framework/templates/research-project/SUMMARY.md +0 -170
  160. package/framework/qualia-framework/templates/research.md +0 -552
  161. package/framework/qualia-framework/templates/roadmap.md +0 -206
  162. package/framework/qualia-framework/templates/state.md +0 -179
  163. package/framework/qualia-framework/templates/summary-complex.md +0 -59
  164. package/framework/qualia-framework/templates/summary-minimal.md +0 -41
  165. package/framework/qualia-framework/templates/summary-standard.md +0 -48
  166. package/framework/qualia-framework/templates/summary.md +0 -246
  167. package/framework/qualia-framework/templates/user-setup.md +0 -311
  168. package/framework/qualia-framework/templates/verification-report.md +0 -322
  169. package/framework/qualia-framework/workflows/add-phase.md +0 -179
  170. package/framework/qualia-framework/workflows/add-todo.md +0 -157
  171. package/framework/qualia-framework/workflows/audit-milestone.md +0 -241
  172. package/framework/qualia-framework/workflows/check-todos.md +0 -176
  173. package/framework/qualia-framework/workflows/complete-milestone.md +0 -858
  174. package/framework/qualia-framework/workflows/diagnose-issues.md +0 -219
  175. package/framework/qualia-framework/workflows/discovery-phase.md +0 -289
  176. package/framework/qualia-framework/workflows/discuss-phase.md +0 -534
  177. package/framework/qualia-framework/workflows/execute-phase.md +0 -559
  178. package/framework/qualia-framework/workflows/execute-plan.md +0 -438
  179. package/framework/qualia-framework/workflows/help.md +0 -470
  180. package/framework/qualia-framework/workflows/insert-phase.md +0 -220
  181. package/framework/qualia-framework/workflows/list-phase-assumptions.md +0 -178
  182. package/framework/qualia-framework/workflows/map-codebase.md +0 -327
  183. package/framework/qualia-framework/workflows/new-milestone.md +0 -363
  184. package/framework/qualia-framework/workflows/new-project.md +0 -982
  185. package/framework/qualia-framework/workflows/pause-work.md +0 -122
  186. package/framework/qualia-framework/workflows/plan-milestone-gaps.md +0 -256
  187. package/framework/qualia-framework/workflows/plan-phase.md +0 -422
  188. package/framework/qualia-framework/workflows/progress.md +0 -389
  189. package/framework/qualia-framework/workflows/quick.md +0 -252
  190. package/framework/qualia-framework/workflows/remove-phase.md +0 -326
  191. package/framework/qualia-framework/workflows/research-phase.md +0 -74
  192. package/framework/qualia-framework/workflows/resume-project.md +0 -306
  193. package/framework/qualia-framework/workflows/set-profile.md +0 -80
  194. package/framework/qualia-framework/workflows/settings.md +0 -145
  195. package/framework/qualia-framework/workflows/transition.md +0 -556
  196. package/framework/qualia-framework/workflows/update.md +0 -197
  197. package/framework/qualia-framework/workflows/verify-phase.md +0 -195
  198. package/framework/qualia-framework/workflows/verify-work.md +0 -625
  199. package/framework/rules/context7.md +0 -14
  200. package/framework/rules/frontend.md +0 -33
  201. package/framework/rules/speed.md +0 -23
  202. package/framework/scripts/__pycache__/say.cpython-314.pyc +0 -0
  203. package/framework/scripts/apply-retention.sh +0 -120
  204. package/framework/scripts/bootstrap-pop-os.sh +0 -354
  205. package/framework/scripts/claude-voice +0 -13
  206. package/framework/scripts/cleanup.sh +0 -131
  207. package/framework/scripts/cowork-mode.sh +0 -141
  208. package/framework/scripts/generate-project-claude-md.sh +0 -153
  209. package/framework/scripts/load-test-webhook.js +0 -172
  210. package/framework/scripts/say.py +0 -236
  211. package/framework/scripts/showcase-video-recorder/ffmpeg-builder.js +0 -167
  212. package/framework/scripts/showcase-video-recorder/playwright-helpers.js +0 -216
  213. package/framework/scripts/speak.py +0 -55
  214. package/framework/scripts/speak.sh +0 -18
  215. package/framework/scripts/status.sh +0 -138
  216. package/framework/scripts/sync-to-framework.sh +0 -65
  217. package/framework/scripts/voice-hotkey.py +0 -227
  218. package/framework/scripts/voice-input.sh +0 -51
  219. package/framework/skills/animate/SKILL.md +0 -202
  220. package/framework/skills/bolder/SKILL.md +0 -144
  221. package/framework/skills/browser-qa/SKILL.md +0 -536
  222. package/framework/skills/clarify/SKILL.md +0 -179
  223. package/framework/skills/client-handoff/SKILL.md +0 -135
  224. package/framework/skills/collab-onboard/SKILL.md +0 -111
  225. package/framework/skills/colorize/SKILL.md +0 -170
  226. package/framework/skills/critique/SKILL.md +0 -126
  227. package/framework/skills/deep-research/SKILL.md +0 -240
  228. package/framework/skills/delight/SKILL.md +0 -329
  229. package/framework/skills/deploy/SKILL.md +0 -261
  230. package/framework/skills/deploy-verify/SKILL.md +0 -377
  231. package/framework/skills/deploy-verify/scripts/canary-check.sh +0 -206
  232. package/framework/skills/deploy-verify/scripts/check-console-errors.js +0 -147
  233. package/framework/skills/deploy-verify/scripts/check-cwv.js +0 -139
  234. package/framework/skills/deploy-verify/scripts/project-detect.sh +0 -84
  235. package/framework/skills/deploy-verify/scripts/verify.sh +0 -548
  236. package/framework/skills/design-quieter/SKILL.md +0 -130
  237. package/framework/skills/distill/SKILL.md +0 -149
  238. package/framework/skills/docs-lookup/SKILL.md +0 -79
  239. package/framework/skills/fcm-notifications/SKILL.md +0 -125
  240. package/framework/skills/financial-ledger/SKILL.md +0 -1039
  241. package/framework/skills/frontend-master/NOTICE.md +0 -4
  242. package/framework/skills/frontend-master/SKILL.md +0 -127
  243. package/framework/skills/frontend-master/reference/color-and-contrast.md +0 -132
  244. package/framework/skills/frontend-master/reference/interaction-design.md +0 -123
  245. package/framework/skills/frontend-master/reference/motion-design.md +0 -99
  246. package/framework/skills/frontend-master/reference/responsive-design.md +0 -114
  247. package/framework/skills/frontend-master/reference/spatial-design.md +0 -100
  248. package/framework/skills/frontend-master/reference/typography.md +0 -131
  249. package/framework/skills/frontend-master/reference/ux-writing.md +0 -107
  250. package/framework/skills/harden/SKILL.md +0 -357
  251. package/framework/skills/i18n-rtl/SKILL.md +0 -752
  252. package/framework/skills/learn/SKILL.md +0 -95
  253. package/framework/skills/memory/SKILL.md +0 -50
  254. package/framework/skills/mobile-expo/SKILL.md +0 -977
  255. package/framework/skills/mobile-expo/references/store-checklist.md +0 -550
  256. package/framework/skills/nestjs-backend/README.md +0 -73
  257. package/framework/skills/nestjs-backend/SKILL.md +0 -446
  258. package/framework/skills/nestjs-backend/references/templates.md +0 -1173
  259. package/framework/skills/normalize/SKILL.md +0 -79
  260. package/framework/skills/onboard/SKILL.md +0 -242
  261. package/framework/skills/openrouter-agent/SKILL.md +0 -922
  262. package/framework/skills/polish/SKILL.md +0 -209
  263. package/framework/skills/pr/SKILL.md +0 -66
  264. package/framework/skills/qualia/SKILL.md +0 -199
  265. package/framework/skills/qualia-add-todo/SKILL.md +0 -68
  266. package/framework/skills/qualia-audit-milestone/SKILL.md +0 -95
  267. package/framework/skills/qualia-check-todos/SKILL.md +0 -55
  268. package/framework/skills/qualia-complete-milestone/SKILL.md +0 -134
  269. package/framework/skills/qualia-debug/SKILL.md +0 -149
  270. package/framework/skills/qualia-design/SKILL.md +0 -203
  271. package/framework/skills/qualia-discuss-phase/SKILL.md +0 -72
  272. package/framework/skills/qualia-evolve/SKILL.md +0 -200
  273. package/framework/skills/qualia-execute-phase/SKILL.md +0 -89
  274. package/framework/skills/qualia-framework-audit/SKILL.md +0 -604
  275. package/framework/skills/qualia-guide/SKILL.md +0 -32
  276. package/framework/skills/qualia-help/SKILL.md +0 -114
  277. package/framework/skills/qualia-idk/SKILL.md +0 -352
  278. package/framework/skills/qualia-list-phase-assumptions/SKILL.md +0 -67
  279. package/framework/skills/qualia-new-milestone/SKILL.md +0 -72
  280. package/framework/skills/qualia-new-project/SKILL.md +0 -232
  281. package/framework/skills/qualia-optimize/SKILL.md +0 -417
  282. package/framework/skills/qualia-pause-work/SKILL.md +0 -96
  283. package/framework/skills/qualia-plan-milestone-gaps/SKILL.md +0 -57
  284. package/framework/skills/qualia-plan-phase/SKILL.md +0 -104
  285. package/framework/skills/qualia-production-check/SKILL.md +0 -0
  286. package/framework/skills/qualia-progress/SKILL.md +0 -53
  287. package/framework/skills/qualia-quick/SKILL.md +0 -89
  288. package/framework/skills/qualia-report/SKILL.md +0 -166
  289. package/framework/skills/qualia-research-phase/SKILL.md +0 -88
  290. package/framework/skills/qualia-resume-work/SKILL.md +0 -62
  291. package/framework/skills/qualia-review/SKILL.md +0 -263
  292. package/framework/skills/qualia-start/SKILL.md +0 -161
  293. package/framework/skills/qualia-verify-work/SKILL.md +0 -132
  294. package/framework/skills/rag/SKILL.md +0 -750
  295. package/framework/skills/responsive/SKILL.md +0 -231
  296. package/framework/skills/retro/SKILL.md +0 -284
  297. package/framework/skills/sakani-conventions/SKILL.md +0 -136
  298. package/framework/skills/sakani-conventions/evals/evals.json +0 -23
  299. package/framework/skills/sakani-conventions/references/entities.md +0 -365
  300. package/framework/skills/sakani-conventions/references/error-codes.md +0 -95
  301. package/framework/skills/seo-master/SKILL.md +0 -490
  302. package/framework/skills/seo-master/references/checklist.md +0 -199
  303. package/framework/skills/seo-master/references/structured-data.md +0 -609
  304. package/framework/skills/ship/SKILL.md +0 -239
  305. package/framework/skills/stack-researcher/SKILL.md +0 -215
  306. package/framework/skills/status/SKILL.md +0 -154
  307. package/framework/skills/status/scripts/health-check.sh +0 -562
  308. package/framework/skills/subscription-payments/SKILL.md +0 -250
  309. package/framework/skills/supabase/SKILL.md +0 -973
  310. package/framework/skills/supabase/references/templates.md +0 -159
  311. package/framework/skills/team/SKILL.md +0 -67
  312. package/framework/skills/test-runner/SKILL.md +0 -202
  313. package/framework/skills/voice-agent/SKILL.md +0 -1312
  314. package/framework/skills/zoho-workflow/SKILL.md +0 -51
  315. package/framework/statusline-command.sh +0 -117
  316. package/framework/teams/default/inboxes/plan-04.json +0 -9
  317. package/framework/teams/review-team.md +0 -75
  318. package/framework/teams/ship-team.md +0 -86
  319. package/profiles/fawzi.json +0 -16
  320. package/profiles/hasan.json +0 -16
  321. package/profiles/moayad.json +0 -16
  322. package/templates/CLAUDE-owner.md +0 -52
  323. package/templates/CLAUDE.md.hbs +0 -58
  324. package/templates/env.claude.template +0 -12
  325. package/templates/settings.json +0 -172
  326. /package/{framework/rules → rules}/deployment.md +0 -0
  327. /package/{framework/rules → rules}/security.md +0 -0
@@ -1,422 +0,0 @@
1
- <purpose>
2
- Create executable phase prompts (PLAN.md files) for a roadmap phase with integrated research and verification. Default flow: Research (if needed) -> Plan -> Verify -> Done. Orchestrates qualia-phase-researcher, qualia-planner, and qualia-plan-checker agents with a revision loop (max 3 iterations).
3
- </purpose>
4
-
5
- <required_reading>
6
- Read all files referenced by the invoking prompt's execution_context before starting.
7
-
8
- @/home/qualia/.claude/qualia-framework/references/ui-brand.md
9
- </required_reading>
10
-
11
- <process>
12
-
13
- ## 1. Initialize
14
-
15
- Load all context in one call:
16
-
17
- ```bash
18
- INIT=$(node /home/qualia/.claude/qualia-framework/bin/qualia-tools.js init plan-phase "$PHASE")
19
- ```
20
-
21
- Parse JSON for: `researcher_model`, `planner_model`, `checker_model`, `research_enabled`, `plan_checker_enabled`, `commit_docs`, `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `phase_slug`, `padded_phase`, `has_research`, `has_context`, `has_plans`, `plan_count`, `planning_exists`, `roadmap_exists`.
22
-
23
- **If `planning_exists` is false:** Error — run `/qualia:new-project` first.
24
-
25
- ## 2. Parse and Normalize Arguments
26
-
27
- Extract from $ARGUMENTS: phase number (integer or decimal like `2.1`), flags (`--research`, `--skip-research`, `--gaps`, `--skip-verify`).
28
-
29
- **If no phase number:** Detect next unplanned phase from roadmap.
30
-
31
- **If `phase_found` is false:** Validate phase exists in ROADMAP.md. If valid, create the directory using `phase_slug` and `padded_phase` from init:
32
- ```bash
33
- mkdir -p ".planning/phases/${padded_phase}-${phase_slug}"
34
- ```
35
-
36
- **Existing artifacts from init:** `has_research`, `has_plans`, `plan_count`.
37
-
38
- ## 3. Validate Phase
39
-
40
- ```bash
41
- PHASE_INFO=$(node /home/qualia/.claude/qualia-framework/bin/qualia-tools.js roadmap get-phase "${PHASE}")
42
- ```
43
-
44
- **If `found` is false:** Error with available phases. **If `found` is true:** Extract `phase_number`, `phase_name`, `goal` from JSON.
45
-
46
- ## 4. Load CONTEXT.md
47
-
48
- ```bash
49
- CONTEXT_CONTENT=$(cat "${PHASE_DIR}"/*-CONTEXT.md 2>/dev/null)
50
- ```
51
-
52
- **CRITICAL:** Store `CONTEXT_CONTENT` now — pass to researcher, planner, checker, and revision agents.
53
-
54
- If CONTEXT.md exists, display: `Using phase context from: ${PHASE_DIR}/*-CONTEXT.md`
55
-
56
- ## 5. Handle Research
57
-
58
- **Skip if:** `--gaps` flag, `--skip-research` flag, or `research_enabled` is false (from init) without `--research` override.
59
-
60
- **If `has_research` is true (from init) AND no `--research` flag:** Use existing, skip to step 6.
61
-
62
- **If RESEARCH.md missing OR `--research` flag:**
63
-
64
- Display banner:
65
- ```
66
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
67
- Qualia ► RESEARCHING PHASE {X}
68
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
69
-
70
- ◆ Spawning researcher...
71
- ```
72
-
73
- ### Spawn qualia-phase-researcher
74
-
75
- ```bash
76
- PHASE_DESC=$(node /home/qualia/.claude/qualia-framework/bin/qualia-tools.js roadmap get-phase "${PHASE}" | jq -r '.section')
77
- REQUIREMENTS=$(cat .planning/REQUIREMENTS.md 2>/dev/null | grep -A100 "## Requirements" | head -50)
78
- STATE_SNAP=$(node /home/qualia/.claude/qualia-framework/bin/qualia-tools.js state-snapshot)
79
- # Extract decisions from state-snapshot JSON: jq '.decisions[] | "\(.phase): \(.summary) - \(.rationale)"'
80
- ```
81
-
82
- Research prompt:
83
-
84
- ```markdown
85
- <objective>
86
- Research how to implement Phase {phase_number}: {phase_name}
87
- Answer: "What do I need to know to PLAN this phase well?"
88
- </objective>
89
-
90
- <phase_context>
91
- IMPORTANT: If CONTEXT.md exists below, it contains user decisions from /qualia:discuss-phase.
92
- - **Decisions** = Locked — research THESE deeply, no alternatives
93
- - **Claude's Discretion** = Freedom areas — research options, recommend
94
- - **Deferred Ideas** = Out of scope — ignore
95
-
96
- {context_content}
97
- </phase_context>
98
-
99
- <additional_context>
100
- **Phase description:** {phase_description}
101
- **Requirements:** {requirements}
102
- **Prior decisions:** {decisions}
103
- </additional_context>
104
-
105
- <output>
106
- Write to: {phase_dir}/{phase}-RESEARCH.md
107
- </output>
108
- ```
109
-
110
- ```
111
- Task(
112
- prompt="First, read /home/qualia/.claude/agents/qualia-phase-researcher.md for your role and instructions.\n\n" + research_prompt,
113
- subagent_type="general-purpose",
114
- model="{researcher_model}",
115
- description="Research Phase {phase}"
116
- )
117
- ```
118
-
119
- ### Handle Researcher Return
120
-
121
- - **`## RESEARCH COMPLETE`:** Display confirmation, continue to step 6
122
- - **`## RESEARCH BLOCKED`:** Display blocker, offer: 1) Provide context, 2) Skip research, 3) Abort
123
-
124
- ## 6. Check Existing Plans
125
-
126
- ```bash
127
- ls "${PHASE_DIR}"/*-PLAN.md 2>/dev/null
128
- ```
129
-
130
- **If exists:** Offer: 1) Add more plans, 2) View existing, 3) Replan from scratch.
131
-
132
- ## 7. Read Context Files
133
-
134
- Read and store for planner agent (`@` syntax doesn't work across Task() boundaries):
135
-
136
- ```bash
137
- STATE_CONTENT=$(cat .planning/STATE.md)
138
- ROADMAP_CONTENT=$(cat .planning/ROADMAP.md)
139
- REQUIREMENTS_CONTENT=$(cat .planning/REQUIREMENTS.md 2>/dev/null)
140
- RESEARCH_CONTENT=$(cat "${PHASE_DIR}"/*-RESEARCH.md 2>/dev/null)
141
- VERIFICATION_CONTENT=$(cat "${PHASE_DIR}"/*-VERIFICATION.md 2>/dev/null)
142
- UAT_CONTENT=$(cat "${PHASE_DIR}"/*-UAT.md 2>/dev/null)
143
- ```
144
-
145
- ## 8. Spawn qualia-planner Agent
146
-
147
- Display banner:
148
- ```
149
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
150
- Qualia ► PLANNING PHASE {X}
151
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
152
-
153
- ◆ Spawning planner...
154
- ```
155
-
156
- Planner prompt:
157
-
158
- ```markdown
159
- <planning_context>
160
- **Phase:** {phase_number}
161
- **Mode:** {standard | gap_closure}
162
-
163
- **Project State:** {state_content}
164
- **Roadmap:** {roadmap_content}
165
- **Requirements:** {requirements_content}
166
-
167
- **Phase Context:**
168
- IMPORTANT: If context exists below, it contains USER DECISIONS from /qualia:discuss-phase.
169
- - **Decisions** = LOCKED — honor exactly, do not revisit
170
- - **Claude's Discretion** = Freedom — make implementation choices
171
- - **Deferred Ideas** = Out of scope — do NOT include
172
-
173
- {context_content}
174
-
175
- **Research:** {research_content}
176
- **Gap Closure (if --gaps):** {verification_content} {uat_content}
177
- </planning_context>
178
-
179
- <downstream_consumer>
180
- Output consumed by /qualia:execute-phase. Plans need:
181
- - Frontmatter (wave, depends_on, files_modified, autonomous)
182
- - Tasks in XML format
183
- - Verification criteria
184
- - must_haves for goal-backward verification
185
- </downstream_consumer>
186
-
187
- <quality_gate>
188
- - [ ] PLAN.md files created in phase directory
189
- - [ ] Each plan has valid frontmatter
190
- - [ ] Tasks are specific and actionable
191
- - [ ] Dependencies correctly identified
192
- - [ ] Waves assigned for parallel execution
193
- - [ ] must_haves derived from phase goal
194
- </quality_gate>
195
- ```
196
-
197
- ```
198
- Task(
199
- prompt="First, read /home/qualia/.claude/agents/qualia-planner.md for your role and instructions.\n\n" + filled_prompt,
200
- subagent_type="general-purpose",
201
- model="{planner_model}",
202
- description="Plan Phase {phase}"
203
- )
204
- ```
205
-
206
- ## 9. Handle Planner Return
207
-
208
- - **`## PLANNING COMPLETE`:** Display plan count. If `--skip-verify` or `plan_checker_enabled` is false (from init): skip to step 13. Otherwise: step 10.
209
- - **`## CHECKPOINT REACHED`:** Present to user, get response, spawn continuation (step 12)
210
- - **`## PLANNING INCONCLUSIVE`:** Show attempts, offer: Add context / Retry / Manual
211
-
212
- ## 9.5. Check files_modified Overlap
213
-
214
- Before running the plan-checker, scan ALL existing PLAN files across the project for `files_modified` overlap with the new plan(s).
215
-
216
- ```bash
217
- # Collect files_modified from the NEW plans in this phase
218
- NEW_FILES=$(grep -h '^files_modified:' "${PHASE_DIR}"/*-PLAN.md 2>/dev/null | sed 's/^files_modified:\s*//' | tr -d '[]"' | tr ',' '\n' | sed 's/^ *//;s/ *$//' | sort -u)
219
-
220
- # Collect files_modified from ALL OTHER phase plans
221
- OTHER_FILES=$(find .planning/phases -maxdepth 3 -name '*-PLAN.md' -not -path "${PHASE_DIR}/*" 2>/dev/null | while read f; do
222
- grep -h '^files_modified:' "$f" 2>/dev/null | sed 's/^files_modified:\s*//' | tr -d '[]"' | tr ',' '\n' | sed 's/^ *//;s/ *$//' | while read file; do
223
- echo "$file|$(basename "$(dirname "$f")")|$(basename "$f")"
224
- done
225
- done | sort)
226
- ```
227
-
228
- Compare overlaps:
229
-
230
- ```bash
231
- # For each file in the new plan, check if it appears in other plans
232
- OVERLAPS=""
233
- while IFS= read -r new_file; do
234
- [ -z "$new_file" ] && continue
235
- MATCHES=$(echo "$OTHER_FILES" | grep "^${new_file}|" || true)
236
- if [ -n "$MATCHES" ]; then
237
- OVERLAPS="${OVERLAPS}\n- \`${new_file}\` also modified in: $(echo "$MATCHES" | cut -d'|' -f2-3 | tr '\n' ', ')"
238
- fi
239
- done <<< "$NEW_FILES"
240
- ```
241
-
242
- **If overlaps found:** Present warning and require user acknowledgment before continuing:
243
-
244
- ```
245
- ## ⚠ files_modified Overlap Detected
246
-
247
- The following files appear in plans from BOTH this phase and other phases:
248
-
249
- {OVERLAPS}
250
-
251
- This may cause merge conflicts or unintended overwrites during execution.
252
- ```
253
-
254
- Use AskUserQuestion:
255
- - "Acknowledged — proceed to plan verification" (continue to step 10)
256
- - "Review plans first" (display conflicting plans, then re-ask)
257
- - "Abort — fix plans manually" (exit)
258
-
259
- **If no overlaps:** Continue silently to step 10.
260
-
261
- ## 10. Spawn qualia-plan-checker Agent
262
-
263
- Display banner:
264
- ```
265
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
266
- Qualia ► VERIFYING PLANS
267
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
268
-
269
- ◆ Spawning plan checker...
270
- ```
271
-
272
- ```bash
273
- PLANS_CONTENT=$(cat "${PHASE_DIR}"/*-PLAN.md 2>/dev/null)
274
- ```
275
-
276
- Checker prompt:
277
-
278
- ```markdown
279
- <verification_context>
280
- **Phase:** {phase_number}
281
- **Phase Goal:** {goal from ROADMAP}
282
-
283
- **Plans to verify:** {plans_content}
284
- **Requirements:** {requirements_content}
285
-
286
- **Phase Context:**
287
- IMPORTANT: Plans MUST honor user decisions. Flag as issue if plans contradict.
288
- - **Decisions** = LOCKED — plans must implement exactly
289
- - **Claude's Discretion** = Freedom areas — plans can choose approach
290
- - **Deferred Ideas** = Out of scope — plans must NOT include
291
-
292
- {context_content}
293
- </verification_context>
294
-
295
- <expected_output>
296
- - ## VERIFICATION PASSED — all checks pass
297
- - ## ISSUES FOUND — structured issue list
298
- </expected_output>
299
- ```
300
-
301
- ```
302
- Task(
303
- prompt=checker_prompt,
304
- subagent_type="qualia-plan-checker",
305
- model="{checker_model}",
306
- description="Verify Phase {phase} plans"
307
- )
308
- ```
309
-
310
- ## 11. Handle Checker Return
311
-
312
- - **`## VERIFICATION PASSED`:** Display confirmation, proceed to step 13.
313
- - **`## ISSUES FOUND`:** Display issues, check iteration count, proceed to step 12.
314
-
315
- ## 12. Revision Loop (Max 3 Iterations)
316
-
317
- Track `iteration_count` (starts at 1 after initial plan + check).
318
-
319
- **If iteration_count < 3:**
320
-
321
- Display: `Sending back to planner for revision... (iteration {N}/3)`
322
-
323
- ```bash
324
- PLANS_CONTENT=$(cat "${PHASE_DIR}"/*-PLAN.md 2>/dev/null)
325
- ```
326
-
327
- Revision prompt:
328
-
329
- ```markdown
330
- <revision_context>
331
- **Phase:** {phase_number}
332
- **Mode:** revision
333
-
334
- **Existing plans:** {plans_content}
335
- **Checker issues:** {structured_issues_from_checker}
336
-
337
- **Phase Context:**
338
- Revisions MUST still honor user decisions.
339
- {context_content}
340
- </revision_context>
341
-
342
- <instructions>
343
- Make targeted updates to address checker issues.
344
- Do NOT replan from scratch unless issues are fundamental.
345
- Return what changed.
346
- </instructions>
347
- ```
348
-
349
- ```
350
- Task(
351
- prompt="First, read /home/qualia/.claude/agents/qualia-planner.md for your role and instructions.\n\n" + revision_prompt,
352
- subagent_type="general-purpose",
353
- model="{planner_model}",
354
- description="Revise Phase {phase} plans"
355
- )
356
- ```
357
-
358
- After planner returns -> spawn checker again (step 10), increment iteration_count.
359
-
360
- **If iteration_count >= 3:**
361
-
362
- Display: `Max iterations reached. {N} issues remain:` + issue list
363
-
364
- Offer: 1) Force proceed, 2) Provide guidance and retry, 3) Abandon
365
-
366
- ## 13. Present Final Status
367
-
368
- Route to `<offer_next>`.
369
-
370
- </process>
371
-
372
- <offer_next>
373
- Output this markdown directly (not as a code block):
374
-
375
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
376
- Qualia ► PHASE {X} PLANNED ✓
377
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
378
-
379
- **Phase {X}: {Name}** — {N} plan(s) in {M} wave(s)
380
-
381
- | Wave | Plans | What it builds |
382
- |------|-------|----------------|
383
- | 1 | 01, 02 | [objectives] |
384
- | 2 | 03 | [objective] |
385
-
386
- Research: {Completed | Used existing | Skipped}
387
- Verification: {Passed | Passed with override | Skipped}
388
-
389
- ───────────────────────────────────────────────────────────────
390
-
391
- ## ▶ Next Up
392
-
393
- **Execute Phase {X}** — run all {N} plans
394
-
395
- /qualia:execute-phase {X}
396
-
397
- <sub>/clear first → fresh context window</sub>
398
-
399
- ───────────────────────────────────────────────────────────────
400
-
401
- **Also available:**
402
- - cat .planning/phases/{phase-dir}/*-PLAN.md — review plans
403
- - /qualia:plan-phase {X} --research — re-research first
404
-
405
- ───────────────────────────────────────────────────────────────
406
- </offer_next>
407
-
408
- <success_criteria>
409
- - [ ] .planning/ directory validated
410
- - [ ] Phase validated against roadmap
411
- - [ ] Phase directory created if needed
412
- - [ ] CONTEXT.md loaded early (step 4) and passed to ALL agents
413
- - [ ] Research completed (unless --skip-research or --gaps or exists)
414
- - [ ] qualia-phase-researcher spawned with CONTEXT.md
415
- - [ ] Existing plans checked
416
- - [ ] qualia-planner spawned with CONTEXT.md + RESEARCH.md
417
- - [ ] Plans created (PLANNING COMPLETE or CHECKPOINT handled)
418
- - [ ] qualia-plan-checker spawned with CONTEXT.md
419
- - [ ] Verification passed OR user override OR max iterations with user decision
420
- - [ ] User sees status between agent spawns
421
- - [ ] User knows next steps
422
- </success_criteria>