qualia-framework 2.6.0 → 3.2.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 (321) hide show
  1. package/CLAUDE.md +64 -0
  2. package/README.md +103 -30
  3. package/agents/builder.md +110 -0
  4. package/agents/planner.md +134 -0
  5. package/agents/qa-browser.md +186 -0
  6. package/agents/verifier.md +221 -0
  7. package/bin/cli.js +336 -531
  8. package/bin/install.js +570 -0
  9. package/bin/qualia-ui.js +299 -0
  10. package/bin/state.js +630 -0
  11. package/bin/statusline.js +252 -0
  12. package/guide.md +63 -0
  13. package/hooks/auto-update.js +139 -0
  14. package/hooks/branch-guard.js +47 -0
  15. package/hooks/migration-guard.js +60 -0
  16. package/hooks/pre-compact.js +32 -0
  17. package/hooks/pre-deploy-gate.js +110 -0
  18. package/hooks/pre-push.js +33 -0
  19. package/hooks/session-start.js +170 -0
  20. package/package.json +29 -20
  21. package/rules/design-reference.md +179 -0
  22. package/rules/frontend.md +126 -0
  23. package/skills/qualia/SKILL.md +87 -0
  24. package/skills/qualia-build/SKILL.md +97 -0
  25. package/skills/qualia-debug/SKILL.md +87 -0
  26. package/skills/qualia-design/SKILL.md +93 -0
  27. package/skills/qualia-handoff/SKILL.md +66 -0
  28. package/skills/qualia-idk/SKILL.md +8 -0
  29. package/skills/qualia-learn/SKILL.md +88 -0
  30. package/skills/qualia-new/SKILL.md +323 -0
  31. package/{framework/skills → skills}/qualia-optimize/SKILL.md +1 -1
  32. package/skills/qualia-pause/SKILL.md +63 -0
  33. package/skills/qualia-plan/SKILL.md +101 -0
  34. package/skills/qualia-polish/SKILL.md +157 -0
  35. package/skills/qualia-quick/SKILL.md +37 -0
  36. package/skills/qualia-report/SKILL.md +105 -0
  37. package/skills/qualia-resume/SKILL.md +49 -0
  38. package/skills/qualia-review/SKILL.md +76 -0
  39. package/skills/qualia-ship/SKILL.md +90 -0
  40. package/skills/qualia-skill-new/SKILL.md +167 -0
  41. package/skills/qualia-task/SKILL.md +91 -0
  42. package/skills/qualia-verify/SKILL.md +113 -0
  43. package/templates/DESIGN.md +137 -0
  44. package/templates/plan.md +28 -0
  45. package/templates/project.md +22 -0
  46. package/templates/state.md +27 -0
  47. package/templates/tracking.json +20 -0
  48. package/tests/bin.test.sh +673 -0
  49. package/tests/hooks.test.sh +315 -0
  50. package/tests/state.test.sh +535 -0
  51. package/tests/statusline.test.sh +243 -0
  52. package/bin/collect-metrics.sh +0 -62
  53. package/framework/.claudeignore +0 -51
  54. package/framework/CLAUDE.md +0 -51
  55. package/framework/MCP_SETUP.md +0 -229
  56. package/framework/agents/architecture-strategist.md +0 -53
  57. package/framework/agents/backend-agent.md +0 -150
  58. package/framework/agents/code-simplicity-reviewer.md +0 -86
  59. package/framework/agents/frontend-agent.md +0 -111
  60. package/framework/agents/kieran-typescript-reviewer.md +0 -96
  61. package/framework/agents/performance-oracle.md +0 -111
  62. package/framework/agents/qualia-codebase-mapper.md +0 -761
  63. package/framework/agents/qualia-debugger.md +0 -1204
  64. package/framework/agents/qualia-executor.md +0 -882
  65. package/framework/agents/qualia-integration-checker.md +0 -424
  66. package/framework/agents/qualia-phase-researcher.md +0 -457
  67. package/framework/agents/qualia-plan-checker.md +0 -700
  68. package/framework/agents/qualia-planner.md +0 -1245
  69. package/framework/agents/qualia-project-researcher.md +0 -603
  70. package/framework/agents/qualia-research-synthesizer.md +0 -200
  71. package/framework/agents/qualia-roadmapper.md +0 -606
  72. package/framework/agents/qualia-verifier.md +0 -686
  73. package/framework/agents/red-team-qa.md +0 -130
  74. package/framework/agents/security-auditor.md +0 -72
  75. package/framework/agents/team-orchestrator.md +0 -229
  76. package/framework/agents/teams/framework-audit-team.md +0 -66
  77. package/framework/agents/teams/full-stack-team.md +0 -48
  78. package/framework/agents/teams/optimize-team.md +0 -53
  79. package/framework/agents/teams/review-team.md +0 -70
  80. package/framework/agents/teams/ship-team.md +0 -86
  81. package/framework/agents/test-agent.md +0 -182
  82. package/framework/hooks/auto-format.sh +0 -54
  83. package/framework/hooks/block-env-edit.sh +0 -42
  84. package/framework/hooks/branch-guard.sh +0 -43
  85. package/framework/hooks/confirm-delete.sh +0 -59
  86. package/framework/hooks/migration-validate.sh +0 -77
  87. package/framework/hooks/notification-speak.sh +0 -16
  88. package/framework/hooks/pre-commit.sh +0 -100
  89. package/framework/hooks/pre-compact.sh +0 -56
  90. package/framework/hooks/pre-deploy-gate.sh +0 -160
  91. package/framework/hooks/qualia-colors.sh +0 -32
  92. package/framework/hooks/retention-cleanup.sh +0 -62
  93. package/framework/hooks/save-session-state.sh +0 -185
  94. package/framework/hooks/session-context-loader.sh +0 -96
  95. package/framework/hooks/session-learn.sh +0 -32
  96. package/framework/hooks/skill-announce.sh +0 -123
  97. package/framework/hooks/tool-error-announce.sh +0 -27
  98. package/framework/install.ps1 +0 -323
  99. package/framework/install.sh +0 -313
  100. package/framework/qualia-framework/VERSION +0 -1
  101. package/framework/qualia-framework/assets/qualia-logo.png +0 -0
  102. package/framework/qualia-framework/bin/collect-metrics.sh +0 -67
  103. package/framework/qualia-framework/bin/generate-report-docx.py +0 -429
  104. package/framework/qualia-framework/bin/qualia-tools.js +0 -2201
  105. package/framework/qualia-framework/bin/qualia-tools.test.js +0 -1054
  106. package/framework/qualia-framework/references/checkpoints.md +0 -775
  107. package/framework/qualia-framework/references/completion-checklists.md +0 -359
  108. package/framework/qualia-framework/references/continuation-format.md +0 -249
  109. package/framework/qualia-framework/references/continuation-prompt.md +0 -97
  110. package/framework/qualia-framework/references/decimal-phase-calculation.md +0 -65
  111. package/framework/qualia-framework/references/design-quality.md +0 -56
  112. package/framework/qualia-framework/references/employee-guide.md +0 -167
  113. package/framework/qualia-framework/references/git-integration.md +0 -254
  114. package/framework/qualia-framework/references/git-planning-commit.md +0 -50
  115. package/framework/qualia-framework/references/model-profile-resolution.md +0 -32
  116. package/framework/qualia-framework/references/model-profiles.md +0 -73
  117. package/framework/qualia-framework/references/phase-argument-parsing.md +0 -61
  118. package/framework/qualia-framework/references/planning-config.md +0 -195
  119. package/framework/qualia-framework/references/questioning.md +0 -141
  120. package/framework/qualia-framework/references/tdd.md +0 -263
  121. package/framework/qualia-framework/references/ui-brand.md +0 -160
  122. package/framework/qualia-framework/references/verification-patterns.md +0 -612
  123. package/framework/qualia-framework/templates/DEBUG.md +0 -159
  124. package/framework/qualia-framework/templates/DESIGN.md +0 -81
  125. package/framework/qualia-framework/templates/UAT.md +0 -247
  126. package/framework/qualia-framework/templates/codebase/architecture.md +0 -255
  127. package/framework/qualia-framework/templates/codebase/concerns.md +0 -310
  128. package/framework/qualia-framework/templates/codebase/conventions.md +0 -307
  129. package/framework/qualia-framework/templates/codebase/integrations.md +0 -280
  130. package/framework/qualia-framework/templates/codebase/stack.md +0 -186
  131. package/framework/qualia-framework/templates/codebase/structure.md +0 -285
  132. package/framework/qualia-framework/templates/codebase/testing.md +0 -480
  133. package/framework/qualia-framework/templates/config.json +0 -35
  134. package/framework/qualia-framework/templates/context.md +0 -283
  135. package/framework/qualia-framework/templates/continue-here.md +0 -78
  136. package/framework/qualia-framework/templates/debug-subagent-prompt.md +0 -91
  137. package/framework/qualia-framework/templates/discovery.md +0 -146
  138. package/framework/qualia-framework/templates/lab-notes.md +0 -16
  139. package/framework/qualia-framework/templates/milestone-archive.md +0 -123
  140. package/framework/qualia-framework/templates/milestone.md +0 -115
  141. package/framework/qualia-framework/templates/phase-prompt.md +0 -567
  142. package/framework/qualia-framework/templates/planner-subagent-prompt.md +0 -117
  143. package/framework/qualia-framework/templates/project.md +0 -184
  144. package/framework/qualia-framework/templates/projects/ai-agent.md +0 -156
  145. package/framework/qualia-framework/templates/projects/mobile-app.md +0 -181
  146. package/framework/qualia-framework/templates/projects/voice-agent.md +0 -134
  147. package/framework/qualia-framework/templates/projects/website.md +0 -137
  148. package/framework/qualia-framework/templates/requirements.md +0 -231
  149. package/framework/qualia-framework/templates/research-project/ARCHITECTURE.md +0 -204
  150. package/framework/qualia-framework/templates/research-project/FEATURES.md +0 -147
  151. package/framework/qualia-framework/templates/research-project/PITFALLS.md +0 -200
  152. package/framework/qualia-framework/templates/research-project/STACK.md +0 -120
  153. package/framework/qualia-framework/templates/research-project/SUMMARY.md +0 -170
  154. package/framework/qualia-framework/templates/research.md +0 -552
  155. package/framework/qualia-framework/templates/roadmap.md +0 -206
  156. package/framework/qualia-framework/templates/state.md +0 -179
  157. package/framework/qualia-framework/templates/summary-complex.md +0 -59
  158. package/framework/qualia-framework/templates/summary-minimal.md +0 -41
  159. package/framework/qualia-framework/templates/summary-standard.md +0 -48
  160. package/framework/qualia-framework/templates/summary.md +0 -246
  161. package/framework/qualia-framework/templates/user-setup.md +0 -311
  162. package/framework/qualia-framework/templates/verification-report.md +0 -322
  163. package/framework/qualia-framework/workflows/add-phase.md +0 -179
  164. package/framework/qualia-framework/workflows/add-todo.md +0 -157
  165. package/framework/qualia-framework/workflows/audit-milestone.md +0 -241
  166. package/framework/qualia-framework/workflows/check-todos.md +0 -176
  167. package/framework/qualia-framework/workflows/complete-milestone.md +0 -858
  168. package/framework/qualia-framework/workflows/diagnose-issues.md +0 -219
  169. package/framework/qualia-framework/workflows/discovery-phase.md +0 -289
  170. package/framework/qualia-framework/workflows/discuss-phase.md +0 -534
  171. package/framework/qualia-framework/workflows/execute-phase.md +0 -559
  172. package/framework/qualia-framework/workflows/execute-plan.md +0 -438
  173. package/framework/qualia-framework/workflows/help.md +0 -470
  174. package/framework/qualia-framework/workflows/insert-phase.md +0 -220
  175. package/framework/qualia-framework/workflows/list-phase-assumptions.md +0 -178
  176. package/framework/qualia-framework/workflows/map-codebase.md +0 -327
  177. package/framework/qualia-framework/workflows/new-milestone.md +0 -363
  178. package/framework/qualia-framework/workflows/new-project.md +0 -982
  179. package/framework/qualia-framework/workflows/pause-work.md +0 -122
  180. package/framework/qualia-framework/workflows/plan-milestone-gaps.md +0 -256
  181. package/framework/qualia-framework/workflows/plan-phase.md +0 -422
  182. package/framework/qualia-framework/workflows/progress.md +0 -389
  183. package/framework/qualia-framework/workflows/quick.md +0 -252
  184. package/framework/qualia-framework/workflows/remove-phase.md +0 -326
  185. package/framework/qualia-framework/workflows/research-phase.md +0 -74
  186. package/framework/qualia-framework/workflows/resume-project.md +0 -306
  187. package/framework/qualia-framework/workflows/set-profile.md +0 -80
  188. package/framework/qualia-framework/workflows/settings.md +0 -145
  189. package/framework/qualia-framework/workflows/transition.md +0 -556
  190. package/framework/qualia-framework/workflows/update.md +0 -197
  191. package/framework/qualia-framework/workflows/verify-phase.md +0 -195
  192. package/framework/qualia-framework/workflows/verify-work.md +0 -625
  193. package/framework/rules/context7.md +0 -14
  194. package/framework/rules/frontend.md +0 -33
  195. package/framework/rules/speed.md +0 -23
  196. package/framework/scripts/__pycache__/say.cpython-314.pyc +0 -0
  197. package/framework/scripts/apply-retention.sh +0 -120
  198. package/framework/scripts/bootstrap-pop-os.sh +0 -354
  199. package/framework/scripts/claude-voice +0 -13
  200. package/framework/scripts/cleanup.sh +0 -131
  201. package/framework/scripts/cowork-mode.sh +0 -141
  202. package/framework/scripts/generate-project-claude-md.sh +0 -153
  203. package/framework/scripts/load-test-webhook.js +0 -172
  204. package/framework/scripts/say.py +0 -236
  205. package/framework/scripts/showcase-video-recorder/ffmpeg-builder.js +0 -167
  206. package/framework/scripts/showcase-video-recorder/playwright-helpers.js +0 -216
  207. package/framework/scripts/speak.py +0 -55
  208. package/framework/scripts/speak.sh +0 -18
  209. package/framework/scripts/status.sh +0 -138
  210. package/framework/scripts/sync-to-framework.sh +0 -65
  211. package/framework/scripts/voice-hotkey.py +0 -227
  212. package/framework/scripts/voice-input.sh +0 -51
  213. package/framework/skills/animate/SKILL.md +0 -202
  214. package/framework/skills/bolder/SKILL.md +0 -144
  215. package/framework/skills/browser-qa/SKILL.md +0 -536
  216. package/framework/skills/clarify/SKILL.md +0 -179
  217. package/framework/skills/client-handoff/SKILL.md +0 -135
  218. package/framework/skills/collab-onboard/SKILL.md +0 -111
  219. package/framework/skills/colorize/SKILL.md +0 -170
  220. package/framework/skills/critique/SKILL.md +0 -126
  221. package/framework/skills/deep-research/SKILL.md +0 -240
  222. package/framework/skills/delight/SKILL.md +0 -329
  223. package/framework/skills/deploy/SKILL.md +0 -261
  224. package/framework/skills/deploy-verify/SKILL.md +0 -377
  225. package/framework/skills/deploy-verify/scripts/canary-check.sh +0 -206
  226. package/framework/skills/deploy-verify/scripts/check-console-errors.js +0 -147
  227. package/framework/skills/deploy-verify/scripts/check-cwv.js +0 -139
  228. package/framework/skills/deploy-verify/scripts/project-detect.sh +0 -84
  229. package/framework/skills/deploy-verify/scripts/verify.sh +0 -548
  230. package/framework/skills/design-quieter/SKILL.md +0 -130
  231. package/framework/skills/distill/SKILL.md +0 -149
  232. package/framework/skills/docs-lookup/SKILL.md +0 -79
  233. package/framework/skills/fcm-notifications/SKILL.md +0 -125
  234. package/framework/skills/financial-ledger/SKILL.md +0 -1039
  235. package/framework/skills/frontend-master/NOTICE.md +0 -4
  236. package/framework/skills/frontend-master/SKILL.md +0 -127
  237. package/framework/skills/frontend-master/reference/color-and-contrast.md +0 -132
  238. package/framework/skills/frontend-master/reference/interaction-design.md +0 -123
  239. package/framework/skills/frontend-master/reference/motion-design.md +0 -99
  240. package/framework/skills/frontend-master/reference/responsive-design.md +0 -114
  241. package/framework/skills/frontend-master/reference/spatial-design.md +0 -100
  242. package/framework/skills/frontend-master/reference/typography.md +0 -131
  243. package/framework/skills/frontend-master/reference/ux-writing.md +0 -107
  244. package/framework/skills/harden/SKILL.md +0 -357
  245. package/framework/skills/i18n-rtl/SKILL.md +0 -752
  246. package/framework/skills/learn/SKILL.md +0 -95
  247. package/framework/skills/memory/SKILL.md +0 -50
  248. package/framework/skills/mobile-expo/SKILL.md +0 -977
  249. package/framework/skills/mobile-expo/references/store-checklist.md +0 -550
  250. package/framework/skills/nestjs-backend/README.md +0 -73
  251. package/framework/skills/nestjs-backend/SKILL.md +0 -446
  252. package/framework/skills/nestjs-backend/references/templates.md +0 -1173
  253. package/framework/skills/normalize/SKILL.md +0 -79
  254. package/framework/skills/onboard/SKILL.md +0 -242
  255. package/framework/skills/openrouter-agent/SKILL.md +0 -922
  256. package/framework/skills/polish/SKILL.md +0 -209
  257. package/framework/skills/pr/SKILL.md +0 -66
  258. package/framework/skills/qualia/SKILL.md +0 -199
  259. package/framework/skills/qualia-add-todo/SKILL.md +0 -68
  260. package/framework/skills/qualia-audit-milestone/SKILL.md +0 -95
  261. package/framework/skills/qualia-check-todos/SKILL.md +0 -55
  262. package/framework/skills/qualia-complete-milestone/SKILL.md +0 -134
  263. package/framework/skills/qualia-debug/SKILL.md +0 -149
  264. package/framework/skills/qualia-design/SKILL.md +0 -203
  265. package/framework/skills/qualia-discuss-phase/SKILL.md +0 -72
  266. package/framework/skills/qualia-evolve/SKILL.md +0 -200
  267. package/framework/skills/qualia-execute-phase/SKILL.md +0 -89
  268. package/framework/skills/qualia-framework-audit/SKILL.md +0 -604
  269. package/framework/skills/qualia-guide/SKILL.md +0 -32
  270. package/framework/skills/qualia-help/SKILL.md +0 -114
  271. package/framework/skills/qualia-idk/SKILL.md +0 -352
  272. package/framework/skills/qualia-list-phase-assumptions/SKILL.md +0 -67
  273. package/framework/skills/qualia-new-milestone/SKILL.md +0 -72
  274. package/framework/skills/qualia-new-project/SKILL.md +0 -232
  275. package/framework/skills/qualia-pause-work/SKILL.md +0 -96
  276. package/framework/skills/qualia-plan-milestone-gaps/SKILL.md +0 -57
  277. package/framework/skills/qualia-plan-phase/SKILL.md +0 -104
  278. package/framework/skills/qualia-production-check/SKILL.md +0 -0
  279. package/framework/skills/qualia-progress/SKILL.md +0 -53
  280. package/framework/skills/qualia-quick/SKILL.md +0 -89
  281. package/framework/skills/qualia-report/SKILL.md +0 -166
  282. package/framework/skills/qualia-research-phase/SKILL.md +0 -88
  283. package/framework/skills/qualia-resume-work/SKILL.md +0 -62
  284. package/framework/skills/qualia-review/SKILL.md +0 -263
  285. package/framework/skills/qualia-start/SKILL.md +0 -161
  286. package/framework/skills/qualia-verify-work/SKILL.md +0 -132
  287. package/framework/skills/rag/SKILL.md +0 -750
  288. package/framework/skills/responsive/SKILL.md +0 -231
  289. package/framework/skills/retro/SKILL.md +0 -284
  290. package/framework/skills/sakani-conventions/SKILL.md +0 -136
  291. package/framework/skills/sakani-conventions/evals/evals.json +0 -23
  292. package/framework/skills/sakani-conventions/references/entities.md +0 -365
  293. package/framework/skills/sakani-conventions/references/error-codes.md +0 -95
  294. package/framework/skills/seo-master/SKILL.md +0 -490
  295. package/framework/skills/seo-master/references/checklist.md +0 -199
  296. package/framework/skills/seo-master/references/structured-data.md +0 -609
  297. package/framework/skills/ship/SKILL.md +0 -239
  298. package/framework/skills/stack-researcher/SKILL.md +0 -215
  299. package/framework/skills/status/SKILL.md +0 -154
  300. package/framework/skills/status/scripts/health-check.sh +0 -562
  301. package/framework/skills/subscription-payments/SKILL.md +0 -250
  302. package/framework/skills/supabase/SKILL.md +0 -973
  303. package/framework/skills/supabase/references/templates.md +0 -159
  304. package/framework/skills/team/SKILL.md +0 -67
  305. package/framework/skills/test-runner/SKILL.md +0 -202
  306. package/framework/skills/voice-agent/SKILL.md +0 -1312
  307. package/framework/skills/zoho-workflow/SKILL.md +0 -51
  308. package/framework/statusline-command.sh +0 -117
  309. package/framework/teams/default/inboxes/plan-04.json +0 -9
  310. package/framework/teams/review-team.md +0 -75
  311. package/framework/teams/ship-team.md +0 -86
  312. package/profiles/fawzi.json +0 -16
  313. package/profiles/hasan.json +0 -16
  314. package/profiles/moayad.json +0 -16
  315. package/templates/CLAUDE-owner.md +0 -52
  316. package/templates/CLAUDE.md.hbs +0 -58
  317. package/templates/env.claude.template +0 -12
  318. package/templates/settings.json +0 -172
  319. package/uninstall.sh +0 -90
  320. /package/{framework/rules → rules}/deployment.md +0 -0
  321. /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>