qualia-framework 2.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.
- package/README.md +50 -0
- package/bin/cli.js +519 -0
- package/framework/agents/architecture-strategist.md +53 -0
- package/framework/agents/backend-agent.md +150 -0
- package/framework/agents/code-simplicity-reviewer.md +86 -0
- package/framework/agents/frontend-agent.md +111 -0
- package/framework/agents/kieran-typescript-reviewer.md +96 -0
- package/framework/agents/performance-oracle.md +111 -0
- package/framework/agents/qualia-codebase-mapper.md +760 -0
- package/framework/agents/qualia-debugger.md +1203 -0
- package/framework/agents/qualia-executor.md +881 -0
- package/framework/agents/qualia-integration-checker.md +423 -0
- package/framework/agents/qualia-phase-researcher.md +453 -0
- package/framework/agents/qualia-plan-checker.md +699 -0
- package/framework/agents/qualia-planner.md +1241 -0
- package/framework/agents/qualia-project-researcher.md +602 -0
- package/framework/agents/qualia-research-synthesizer.md +236 -0
- package/framework/agents/qualia-roadmapper.md +605 -0
- package/framework/agents/qualia-verifier.md +685 -0
- package/framework/agents/team-orchestrator.md +228 -0
- package/framework/agents/teams/full-stack-team.md +48 -0
- package/framework/agents/teams/optimize-team.md +53 -0
- package/framework/agents/teams/review-team.md +62 -0
- package/framework/agents/teams/ship-team.md +86 -0
- package/framework/agents/test-agent.md +182 -0
- package/framework/askpass.sh +2 -0
- package/framework/commands/design.md +53 -0
- package/framework/commands/quick-db.md +22 -0
- package/framework/config/retention.json +35 -0
- package/framework/core/PRINCIPLES.md +77 -0
- package/framework/hooks/auto-format.sh +45 -0
- package/framework/hooks/block-env-edit.sh +42 -0
- package/framework/hooks/branch-guard.sh +46 -0
- package/framework/hooks/confirm-delete.sh +56 -0
- package/framework/hooks/migration-validate.sh +68 -0
- package/framework/hooks/notification-speak.sh +15 -0
- package/framework/hooks/pre-commit.sh +80 -0
- package/framework/hooks/pre-compact.sh +55 -0
- package/framework/hooks/pre-deploy-gate.sh +151 -0
- package/framework/hooks/qualia-colors.sh +32 -0
- package/framework/hooks/retention-cleanup.sh +43 -0
- package/framework/hooks/save-session-state.sh +153 -0
- package/framework/hooks/session-context-loader.sh +28 -0
- package/framework/hooks/session-learn.sh +30 -0
- package/framework/knowledge/claudecode-bible.md +1384 -0
- package/framework/knowledge/client-prefs.md +22 -0
- package/framework/knowledge/common-fixes.md +25 -0
- package/framework/knowledge/deployment-map.md +35 -0
- package/framework/knowledge/email-signature.html +1 -0
- package/framework/knowledge/employees.md +8 -0
- package/framework/knowledge/learned-patterns.md +51 -0
- package/framework/knowledge/optimization-research-2026.md +137 -0
- package/framework/knowledge/qualia-context.md +67 -0
- package/framework/knowledge/supabase-patterns.md +50 -0
- package/framework/knowledge/voice-agent-patterns.md +46 -0
- package/framework/qualia-engine/VERSION +1 -0
- package/framework/qualia-engine/bin/qualia-tools.js +2160 -0
- package/framework/qualia-engine/bin/qualia-tools.test.js +1054 -0
- package/framework/qualia-engine/references/checkpoints.md +775 -0
- package/framework/qualia-engine/references/continuation-format.md +249 -0
- package/framework/qualia-engine/references/decimal-phase-calculation.md +65 -0
- package/framework/qualia-engine/references/design-quality.md +56 -0
- package/framework/qualia-engine/references/git-integration.md +254 -0
- package/framework/qualia-engine/references/git-planning-commit.md +50 -0
- package/framework/qualia-engine/references/model-profile-resolution.md +32 -0
- package/framework/qualia-engine/references/model-profiles.md +73 -0
- package/framework/qualia-engine/references/phase-argument-parsing.md +61 -0
- package/framework/qualia-engine/references/planning-config.md +195 -0
- package/framework/qualia-engine/references/questioning.md +141 -0
- package/framework/qualia-engine/references/tdd.md +263 -0
- package/framework/qualia-engine/references/ui-brand.md +160 -0
- package/framework/qualia-engine/references/verification-patterns.md +612 -0
- package/framework/qualia-engine/templates/DEBUG.md +159 -0
- package/framework/qualia-engine/templates/DESIGN.md +81 -0
- package/framework/qualia-engine/templates/UAT.md +247 -0
- package/framework/qualia-engine/templates/codebase/architecture.md +255 -0
- package/framework/qualia-engine/templates/codebase/concerns.md +310 -0
- package/framework/qualia-engine/templates/codebase/conventions.md +307 -0
- package/framework/qualia-engine/templates/codebase/integrations.md +280 -0
- package/framework/qualia-engine/templates/codebase/stack.md +186 -0
- package/framework/qualia-engine/templates/codebase/structure.md +285 -0
- package/framework/qualia-engine/templates/codebase/testing.md +480 -0
- package/framework/qualia-engine/templates/config.json +35 -0
- package/framework/qualia-engine/templates/context.md +283 -0
- package/framework/qualia-engine/templates/continue-here.md +78 -0
- package/framework/qualia-engine/templates/debug-subagent-prompt.md +91 -0
- package/framework/qualia-engine/templates/discovery.md +146 -0
- package/framework/qualia-engine/templates/milestone-archive.md +123 -0
- package/framework/qualia-engine/templates/milestone.md +115 -0
- package/framework/qualia-engine/templates/phase-prompt.md +567 -0
- package/framework/qualia-engine/templates/planner-subagent-prompt.md +117 -0
- package/framework/qualia-engine/templates/project.md +184 -0
- package/framework/qualia-engine/templates/projects/ai-agent.md +156 -0
- package/framework/qualia-engine/templates/projects/mobile-app.md +181 -0
- package/framework/qualia-engine/templates/projects/voice-agent.md +134 -0
- package/framework/qualia-engine/templates/projects/website.md +137 -0
- package/framework/qualia-engine/templates/requirements.md +231 -0
- package/framework/qualia-engine/templates/research-project/ARCHITECTURE.md +204 -0
- package/framework/qualia-engine/templates/research-project/FEATURES.md +147 -0
- package/framework/qualia-engine/templates/research-project/PITFALLS.md +200 -0
- package/framework/qualia-engine/templates/research-project/STACK.md +120 -0
- package/framework/qualia-engine/templates/research-project/SUMMARY.md +170 -0
- package/framework/qualia-engine/templates/research.md +552 -0
- package/framework/qualia-engine/templates/roadmap.md +202 -0
- package/framework/qualia-engine/templates/state.md +176 -0
- package/framework/qualia-engine/templates/summary-complex.md +59 -0
- package/framework/qualia-engine/templates/summary-minimal.md +41 -0
- package/framework/qualia-engine/templates/summary-standard.md +48 -0
- package/framework/qualia-engine/templates/summary.md +246 -0
- package/framework/qualia-engine/templates/user-setup.md +311 -0
- package/framework/qualia-engine/templates/verification-report.md +322 -0
- package/framework/qualia-engine/workflows/add-phase.md +179 -0
- package/framework/qualia-engine/workflows/add-todo.md +157 -0
- package/framework/qualia-engine/workflows/audit-milestone.md +241 -0
- package/framework/qualia-engine/workflows/check-todos.md +176 -0
- package/framework/qualia-engine/workflows/complete-milestone.md +858 -0
- package/framework/qualia-engine/workflows/diagnose-issues.md +219 -0
- package/framework/qualia-engine/workflows/discovery-phase.md +289 -0
- package/framework/qualia-engine/workflows/discuss-phase.md +534 -0
- package/framework/qualia-engine/workflows/execute-phase.md +559 -0
- package/framework/qualia-engine/workflows/execute-plan.md +438 -0
- package/framework/qualia-engine/workflows/help.md +470 -0
- package/framework/qualia-engine/workflows/insert-phase.md +220 -0
- package/framework/qualia-engine/workflows/list-phase-assumptions.md +178 -0
- package/framework/qualia-engine/workflows/map-codebase.md +327 -0
- package/framework/qualia-engine/workflows/new-milestone.md +363 -0
- package/framework/qualia-engine/workflows/new-project.md +1037 -0
- package/framework/qualia-engine/workflows/pause-work.md +122 -0
- package/framework/qualia-engine/workflows/plan-milestone-gaps.md +256 -0
- package/framework/qualia-engine/workflows/plan-phase.md +422 -0
- package/framework/qualia-engine/workflows/progress.md +354 -0
- package/framework/qualia-engine/workflows/quick.md +252 -0
- package/framework/qualia-engine/workflows/remove-phase.md +326 -0
- package/framework/qualia-engine/workflows/research-phase.md +74 -0
- package/framework/qualia-engine/workflows/resume-project.md +306 -0
- package/framework/qualia-engine/workflows/set-profile.md +80 -0
- package/framework/qualia-engine/workflows/settings.md +145 -0
- package/framework/qualia-engine/workflows/transition.md +556 -0
- package/framework/qualia-engine/workflows/update.md +197 -0
- package/framework/qualia-engine/workflows/verify-phase.md +195 -0
- package/framework/qualia-engine/workflows/verify-work.md +625 -0
- package/framework/rules/context7.md +11 -0
- package/framework/rules/deployment.md +29 -0
- package/framework/rules/frontend.md +33 -0
- package/framework/rules/security.md +12 -0
- package/framework/rules/speed.md +20 -0
- package/framework/scripts/__pycache__/say.cpython-314.pyc +0 -0
- package/framework/scripts/apply-retention.sh +120 -0
- package/framework/scripts/bootstrap-pop-os.sh +354 -0
- package/framework/scripts/claude-voice +13 -0
- package/framework/scripts/cleanup.sh +131 -0
- package/framework/scripts/cowork-mode.sh +141 -0
- package/framework/scripts/generate-project-claude-md.sh +153 -0
- package/framework/scripts/load-test-webhook.js +172 -0
- package/framework/scripts/say.py +236 -0
- package/framework/scripts/showcase-video-recorder/ffmpeg-builder.js +167 -0
- package/framework/scripts/showcase-video-recorder/playwright-helpers.js +216 -0
- package/framework/scripts/speak.py +55 -0
- package/framework/scripts/speak.sh +18 -0
- package/framework/scripts/status.sh +138 -0
- package/framework/scripts/sync-to-framework.sh +65 -0
- package/framework/scripts/voice-hotkey.py +227 -0
- package/framework/scripts/voice-input.sh +51 -0
- package/framework/skills/animate/SKILL.md +202 -0
- package/framework/skills/bolder/SKILL.md +144 -0
- package/framework/skills/browser-qa/SKILL.md +536 -0
- package/framework/skills/clarify/SKILL.md +179 -0
- package/framework/skills/colorize/SKILL.md +170 -0
- package/framework/skills/critique/SKILL.md +126 -0
- package/framework/skills/deep-research/SKILL.md +271 -0
- package/framework/skills/delight/SKILL.md +329 -0
- package/framework/skills/deploy/SKILL.md +261 -0
- package/framework/skills/deploy-verify/SKILL.md +377 -0
- package/framework/skills/deploy-verify/scripts/canary-check.sh +206 -0
- package/framework/skills/deploy-verify/scripts/check-console-errors.js +147 -0
- package/framework/skills/deploy-verify/scripts/check-cwv.js +139 -0
- package/framework/skills/deploy-verify/scripts/project-detect.sh +84 -0
- package/framework/skills/deploy-verify/scripts/verify.sh +548 -0
- package/framework/skills/design-quieter/SKILL.md +130 -0
- package/framework/skills/distill/SKILL.md +149 -0
- package/framework/skills/docs-lookup/SKILL.md +78 -0
- package/framework/skills/fcm-notifications/SKILL.md +125 -0
- package/framework/skills/financial-ledger/SKILL.md +1039 -0
- package/framework/skills/frontend-master/NOTICE.md +4 -0
- package/framework/skills/frontend-master/SKILL.md +127 -0
- package/framework/skills/frontend-master/reference/color-and-contrast.md +132 -0
- package/framework/skills/frontend-master/reference/interaction-design.md +123 -0
- package/framework/skills/frontend-master/reference/motion-design.md +99 -0
- package/framework/skills/frontend-master/reference/responsive-design.md +114 -0
- package/framework/skills/frontend-master/reference/spatial-design.md +100 -0
- package/framework/skills/frontend-master/reference/typography.md +131 -0
- package/framework/skills/frontend-master/reference/ux-writing.md +107 -0
- package/framework/skills/harden/SKILL.md +357 -0
- package/framework/skills/i18n-rtl/SKILL.md +752 -0
- package/framework/skills/learn/SKILL.md +71 -0
- package/framework/skills/memory/SKILL.md +50 -0
- package/framework/skills/mobile-expo/SKILL.md +864 -0
- package/framework/skills/mobile-expo/references/store-checklist.md +550 -0
- package/framework/skills/nestjs-backend/README.md +73 -0
- package/framework/skills/nestjs-backend/SKILL.md +446 -0
- package/framework/skills/nestjs-backend/references/templates.md +1173 -0
- package/framework/skills/normalize/SKILL.md +79 -0
- package/framework/skills/onboard/SKILL.md +242 -0
- package/framework/skills/polish/SKILL.md +209 -0
- package/framework/skills/pr/SKILL.md +66 -0
- package/framework/skills/qualia/SKILL.md +153 -0
- package/framework/skills/qualia-add-todo/SKILL.md +68 -0
- package/framework/skills/qualia-audit-milestone/SKILL.md +92 -0
- package/framework/skills/qualia-check-todos/SKILL.md +55 -0
- package/framework/skills/qualia-complete-milestone/SKILL.md +108 -0
- package/framework/skills/qualia-debug/SKILL.md +149 -0
- package/framework/skills/qualia-design/SKILL.md +203 -0
- package/framework/skills/qualia-discuss-phase/SKILL.md +72 -0
- package/framework/skills/qualia-execute-phase/SKILL.md +86 -0
- package/framework/skills/qualia-help/SKILL.md +67 -0
- package/framework/skills/qualia-idk/SKILL.md +352 -0
- package/framework/skills/qualia-list-phase-assumptions/SKILL.md +67 -0
- package/framework/skills/qualia-new-milestone/SKILL.md +72 -0
- package/framework/skills/qualia-new-project/SKILL.md +92 -0
- package/framework/skills/qualia-optimize/SKILL.md +417 -0
- package/framework/skills/qualia-pause-work/SKILL.md +96 -0
- package/framework/skills/qualia-plan-milestone-gaps/SKILL.md +57 -0
- package/framework/skills/qualia-plan-phase/SKILL.md +101 -0
- package/framework/skills/qualia-progress/SKILL.md +53 -0
- package/framework/skills/qualia-quick/SKILL.md +89 -0
- package/framework/skills/qualia-research-phase/SKILL.md +88 -0
- package/framework/skills/qualia-resume-work/SKILL.md +62 -0
- package/framework/skills/qualia-review/SKILL.md +263 -0
- package/framework/skills/qualia-start/SKILL.md +182 -0
- package/framework/skills/qualia-verify-work/SKILL.md +105 -0
- package/framework/skills/qualia-workflow/SKILL.md +130 -0
- package/framework/skills/rag/SKILL.md +750 -0
- package/framework/skills/responsive/SKILL.md +231 -0
- package/framework/skills/retro/SKILL.md +284 -0
- package/framework/skills/sakani-conventions/SKILL.md +136 -0
- package/framework/skills/sakani-conventions/evals/evals.json +23 -0
- package/framework/skills/sakani-conventions/references/entities.md +365 -0
- package/framework/skills/sakani-conventions/references/error-codes.md +95 -0
- package/framework/skills/seo-master/SKILL.md +490 -0
- package/framework/skills/seo-master/references/checklist.md +199 -0
- package/framework/skills/seo-master/references/structured-data.md +609 -0
- package/framework/skills/ship/SKILL.md +202 -0
- package/framework/skills/stack-researcher/SKILL.md +215 -0
- package/framework/skills/status/SKILL.md +154 -0
- package/framework/skills/status/scripts/health-check.sh +562 -0
- package/framework/skills/subscription-payments/SKILL.md +250 -0
- package/framework/skills/supabase/SKILL.md +973 -0
- package/framework/skills/supabase/references/templates.md +159 -0
- package/framework/skills/team/SKILL.md +67 -0
- package/framework/skills/test-runner/SKILL.md +202 -0
- package/framework/skills/voice-agent/SKILL.md +407 -0
- package/framework/skills/zoho-workflow/SKILL.md +51 -0
- package/framework/statusline-command.sh +117 -0
- package/package.json +24 -0
- package/profiles/fawzi.json +16 -0
- package/profiles/hasan.json +16 -0
- package/profiles/moayad.json +16 -0
- package/templates/CLAUDE-owner.md +52 -0
- package/templates/CLAUDE.md.hbs +58 -0
- package/templates/env.claude.template +12 -0
- package/templates/settings.json +141 -0
|
@@ -0,0 +1,559 @@
|
|
|
1
|
+
<purpose>
|
|
2
|
+
Execute all plans in a phase using wave-based parallel execution. Orchestrator stays lean — delegates plan execution to subagents.
|
|
3
|
+
</purpose>
|
|
4
|
+
|
|
5
|
+
<core_principle>
|
|
6
|
+
Orchestrator coordinates, not executes. Each subagent loads the full execute-plan context. Orchestrator: discover plans → analyze deps → group waves → spawn agents → handle checkpoints → collect results.
|
|
7
|
+
</core_principle>
|
|
8
|
+
|
|
9
|
+
<required_reading>
|
|
10
|
+
Read STATE.md before any operation to load project context.
|
|
11
|
+
</required_reading>
|
|
12
|
+
|
|
13
|
+
<process>
|
|
14
|
+
|
|
15
|
+
<step name="initialize" priority="first">
|
|
16
|
+
Load all context in one call:
|
|
17
|
+
|
|
18
|
+
```bash
|
|
19
|
+
INIT=$(node /home/qualia/.claude/qualia-engine/bin/qualia-tools.js init execute-phase "${PHASE_ARG}")
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
Parse JSON for: `executor_model`, `verifier_model`, `commit_docs`, `parallelization`, `branching_strategy`, `branch_name`, `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `phase_slug`, `plans`, `incomplete_plans`, `plan_count`, `incomplete_count`, `state_exists`, `roadmap_exists`.
|
|
23
|
+
|
|
24
|
+
**If `phase_found` is false:** Error — phase directory not found.
|
|
25
|
+
**If `plan_count` is 0:** Error — no plans found in phase.
|
|
26
|
+
**If `state_exists` is false but `.planning/` exists:** Offer reconstruct or continue.
|
|
27
|
+
|
|
28
|
+
When `parallelization` is false, plans within a wave execute sequentially.
|
|
29
|
+
</step>
|
|
30
|
+
|
|
31
|
+
<step name="handle_branching">
|
|
32
|
+
Check `branching_strategy` from init:
|
|
33
|
+
|
|
34
|
+
**"none":** Skip, continue on current branch.
|
|
35
|
+
|
|
36
|
+
**"phase" or "milestone":** Use pre-computed `branch_name` from init:
|
|
37
|
+
```bash
|
|
38
|
+
git checkout -b "$BRANCH_NAME" 2>/dev/null || git checkout "$BRANCH_NAME"
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
All subsequent commits go to this branch. User handles merging.
|
|
42
|
+
</step>
|
|
43
|
+
|
|
44
|
+
<step name="validate_phase">
|
|
45
|
+
From init JSON: `phase_dir`, `plan_count`, `incomplete_count`.
|
|
46
|
+
|
|
47
|
+
Report: "Found {plan_count} plans in {phase_dir} ({incomplete_count} incomplete)"
|
|
48
|
+
|
|
49
|
+
**Team suggestion (optional):** Check if the phase in ROADMAP.md has a `team:` field (e.g., `team: full-stack-team`). If present, suggest:
|
|
50
|
+
|
|
51
|
+
```
|
|
52
|
+
Note: This phase has a team template configured (full-stack-team).
|
|
53
|
+
Consider using `/team full-stack "<phase goal>"` for coordinated multi-agent execution.
|
|
54
|
+
Continuing with standard execution...
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
This is a suggestion only — execution continues normally regardless. The user can cancel and run `/team` instead, or let standard execution proceed.
|
|
58
|
+
</step>
|
|
59
|
+
|
|
60
|
+
<step name="discover_and_group_plans">
|
|
61
|
+
Load plan inventory with wave grouping in one call:
|
|
62
|
+
|
|
63
|
+
```bash
|
|
64
|
+
PLAN_INDEX=$(node /home/qualia/.claude/qualia-engine/bin/qualia-tools.js phase-plan-index "${PHASE_NUMBER}")
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
Parse JSON for: `phase`, `plans[]` (each with `id`, `wave`, `autonomous`, `objective`, `files_modified`, `task_count`, `has_summary`), `waves` (map of wave number → plan IDs), `incomplete`, `has_checkpoints`.
|
|
68
|
+
|
|
69
|
+
**Filtering:** Skip plans where `has_summary: true`. If `--gaps-only`: also skip non-gap_closure plans. If all filtered: "No matching incomplete plans" → exit.
|
|
70
|
+
|
|
71
|
+
Report:
|
|
72
|
+
```
|
|
73
|
+
## Execution Plan
|
|
74
|
+
|
|
75
|
+
**Phase {X}: {Name}** — {total_plans} plans across {wave_count} waves
|
|
76
|
+
|
|
77
|
+
| Wave | Plans | What it builds |
|
|
78
|
+
|------|-------|----------------|
|
|
79
|
+
| 1 | 01-01, 01-02 | {from plan objectives, 3-8 words} |
|
|
80
|
+
| 2 | 01-03 | ... |
|
|
81
|
+
```
|
|
82
|
+
</step>
|
|
83
|
+
|
|
84
|
+
<step name="execute_waves">
|
|
85
|
+
Execute each wave in sequence. Within a wave: parallel if `PARALLELIZATION=true`, sequential if `false`.
|
|
86
|
+
|
|
87
|
+
**For each wave:**
|
|
88
|
+
|
|
89
|
+
1. **Describe what's being built (BEFORE spawning):**
|
|
90
|
+
|
|
91
|
+
Read each plan's `<objective>`. Extract what's being built and why.
|
|
92
|
+
|
|
93
|
+
```
|
|
94
|
+
---
|
|
95
|
+
## Wave {N}
|
|
96
|
+
|
|
97
|
+
**{Plan ID}: {Plan Name}**
|
|
98
|
+
{2-3 sentences: what this builds, technical approach, why it matters}
|
|
99
|
+
|
|
100
|
+
Spawning {count} agent(s)...
|
|
101
|
+
---
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
- Bad: "Executing terrain generation plan"
|
|
105
|
+
- Good: "Procedural terrain generator using Perlin noise — creates height maps, biome zones, and collision meshes. Required before vehicle physics can interact with ground."
|
|
106
|
+
|
|
107
|
+
2. **Read files and spawn agents:**
|
|
108
|
+
|
|
109
|
+
Content must be inlined — `@` syntax doesn't work across Task() boundaries.
|
|
110
|
+
|
|
111
|
+
```bash
|
|
112
|
+
PLAN_CONTENT=$(cat "{plan_path}")
|
|
113
|
+
STATE_CONTENT=$(cat .planning/STATE.md)
|
|
114
|
+
CONFIG_CONTENT=$(cat .planning/config.json 2>/dev/null)
|
|
115
|
+
# Content must be inlined — @ syntax doesn't work across Task() boundaries
|
|
116
|
+
EXECUTE_PLAN_WF=$(cat /home/qualia/.claude/qualia-engine/workflows/execute-plan.md)
|
|
117
|
+
SUMMARY_TMPL=$(cat /home/qualia/.claude/qualia-engine/templates/summary.md)
|
|
118
|
+
CHECKPOINTS_REF=$(cat /home/qualia/.claude/qualia-engine/references/checkpoints.md)
|
|
119
|
+
TDD_REF=$(cat /home/qualia/.claude/qualia-engine/references/tdd.md)
|
|
120
|
+
# Detect if plan involves frontend work
|
|
121
|
+
IS_FRONTEND=$(echo "$PLAN_CONTENT" | grep -qiE '\.(tsx|jsx|css|scss)|frontend|ui|component|page|layout|dashboard|form|modal' && echo "true" || echo "false")
|
|
122
|
+
if [ "$IS_FRONTEND" = "true" ]; then
|
|
123
|
+
DESIGN_CONTEXT=$(cat /home/qualia/.claude/qualia-engine/references/design-quality.md 2>/dev/null)
|
|
124
|
+
FRONTEND_SKILL=$(cat /home/qualia/.claude/skills/frontend-master/SKILL.md 2>/dev/null)
|
|
125
|
+
fi
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
**Resolve domain skill references from plan:**
|
|
129
|
+
|
|
130
|
+
```bash
|
|
131
|
+
# Extract @skill references from plan
|
|
132
|
+
SKILL_REFS=$(echo "$PLAN_CONTENT" | grep -oP '@/home/qualia/.claude/skills/[^\s]+/SKILL\.md' | sort -u)
|
|
133
|
+
|
|
134
|
+
# Inline each skill's content into domain context
|
|
135
|
+
DOMAIN_CONTEXT=""
|
|
136
|
+
for ref in $SKILL_REFS; do
|
|
137
|
+
SKILL_PATH="${ref#@}"
|
|
138
|
+
if [ -f "$SKILL_PATH" ]; then
|
|
139
|
+
SKILL_NAME=$(basename "$(dirname "$SKILL_PATH")")
|
|
140
|
+
DOMAIN_CONTEXT="${DOMAIN_CONTEXT}
|
|
141
|
+
|
|
142
|
+
--- Skill: ${SKILL_NAME} ---
|
|
143
|
+
$(cat "$SKILL_PATH")
|
|
144
|
+
"
|
|
145
|
+
fi
|
|
146
|
+
done
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
Each agent prompt:
|
|
150
|
+
|
|
151
|
+
```
|
|
152
|
+
<objective>
|
|
153
|
+
Execute plan {plan_number} of phase {phase_number}-{phase_name}.
|
|
154
|
+
Commit each task atomically. Create SUMMARY.md. Update STATE.md.
|
|
155
|
+
</objective>
|
|
156
|
+
|
|
157
|
+
<execution_context>
|
|
158
|
+
{execute_plan_wf}
|
|
159
|
+
{summary_tmpl}
|
|
160
|
+
{checkpoints_ref}
|
|
161
|
+
{tdd_ref}
|
|
162
|
+
</execution_context>
|
|
163
|
+
|
|
164
|
+
<context>
|
|
165
|
+
Plan:
|
|
166
|
+
{plan_content}
|
|
167
|
+
|
|
168
|
+
Project state:
|
|
169
|
+
{state_content}
|
|
170
|
+
|
|
171
|
+
Config (if exists):
|
|
172
|
+
{config_content}
|
|
173
|
+
</context>
|
|
174
|
+
|
|
175
|
+
{If DOMAIN_CONTEXT is non-empty:}
|
|
176
|
+
<domain_skills>
|
|
177
|
+
These skill guidelines apply to this plan. Follow these patterns.
|
|
178
|
+
{DOMAIN_CONTEXT}
|
|
179
|
+
</domain_skills>
|
|
180
|
+
|
|
181
|
+
<success_criteria>
|
|
182
|
+
- [ ] All tasks executed
|
|
183
|
+
- [ ] Each task committed individually
|
|
184
|
+
- [ ] SUMMARY.md created in plan directory
|
|
185
|
+
- [ ] STATE.md updated with position and decisions
|
|
186
|
+
</success_criteria>
|
|
187
|
+
```
|
|
188
|
+
|
|
189
|
+
**If `IS_FRONTEND` is true**, append this block to the agent prompt before `</success_criteria>`:
|
|
190
|
+
|
|
191
|
+
```
|
|
192
|
+
<design_quality>
|
|
193
|
+
This plan involves frontend work. Use the frontend-master skill as your primary design guide.
|
|
194
|
+
|
|
195
|
+
{frontend_skill}
|
|
196
|
+
|
|
197
|
+
Build-time standards summary:
|
|
198
|
+
{design_context}
|
|
199
|
+
</design_quality>
|
|
200
|
+
```
|
|
201
|
+
|
|
202
|
+
And add to success_criteria:
|
|
203
|
+
```
|
|
204
|
+
- [ ] Frontend components meet design quality standards (no generic look, states handled, copy is clear, transitions present)
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
3. **Wait for all agents in wave to complete.**
|
|
208
|
+
|
|
209
|
+
4. **Report completion — spot-check claims first:**
|
|
210
|
+
|
|
211
|
+
For each SUMMARY.md:
|
|
212
|
+
- Verify first 2 files from `key-files.created` exist on disk
|
|
213
|
+
- Check `git log --oneline --all --grep="{phase}-{plan}"` returns ≥1 commit
|
|
214
|
+
- Check for `## Self-Check: FAILED` marker
|
|
215
|
+
|
|
216
|
+
If ANY spot-check fails: report which plan failed, route to failure handler — ask "Retry plan?" or "Continue with remaining waves?"
|
|
217
|
+
|
|
218
|
+
If pass:
|
|
219
|
+
```
|
|
220
|
+
---
|
|
221
|
+
## Wave {N} Complete
|
|
222
|
+
|
|
223
|
+
**{Plan ID}: {Plan Name}**
|
|
224
|
+
{What was built — from SUMMARY.md}
|
|
225
|
+
{Notable deviations, if any}
|
|
226
|
+
|
|
227
|
+
{If more waves: what this enables for next wave}
|
|
228
|
+
---
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
- Bad: "Wave 2 complete. Proceeding to Wave 3."
|
|
232
|
+
- Good: "Terrain system complete — 3 biome types, height-based texturing, physics collision meshes. Vehicle physics (Wave 3) can now reference ground surfaces."
|
|
233
|
+
|
|
234
|
+
5. **Handle failures:** Report which plan failed → ask "Continue?" or "Stop?" → if continue, dependent plans may also fail. If stop, partial completion report.
|
|
235
|
+
|
|
236
|
+
6. **Execute checkpoint plans between waves** — see `<checkpoint_handling>`.
|
|
237
|
+
|
|
238
|
+
7. **Proceed to next wave.**
|
|
239
|
+
</step>
|
|
240
|
+
|
|
241
|
+
<step name="checkpoint_handling">
|
|
242
|
+
Plans with `autonomous: false` require user interaction.
|
|
243
|
+
|
|
244
|
+
**Flow:**
|
|
245
|
+
|
|
246
|
+
1. Spawn agent for checkpoint plan
|
|
247
|
+
2. Agent runs until checkpoint task or auth gate → returns structured state
|
|
248
|
+
3. Agent return includes: completed tasks table, current task + blocker, checkpoint type/details, what's awaited
|
|
249
|
+
4. **Present to user:**
|
|
250
|
+
```
|
|
251
|
+
## Checkpoint: [Type]
|
|
252
|
+
|
|
253
|
+
**Plan:** 03-03 Dashboard Layout
|
|
254
|
+
**Progress:** 2/3 tasks complete
|
|
255
|
+
|
|
256
|
+
[Checkpoint Details from agent return]
|
|
257
|
+
[Awaiting section from agent return]
|
|
258
|
+
```
|
|
259
|
+
5. User responds: "approved"/"done" | issue description | decision selection
|
|
260
|
+
6. **Spawn continuation agent (NOT resume)** using continuation-prompt.md template:
|
|
261
|
+
- `{completed_tasks_table}`: From checkpoint return
|
|
262
|
+
- `{resume_task_number}` + `{resume_task_name}`: Current task
|
|
263
|
+
- `{user_response}`: What user provided
|
|
264
|
+
- `{resume_instructions}`: Based on checkpoint type
|
|
265
|
+
7. Continuation agent verifies previous commits, continues from resume point
|
|
266
|
+
8. Repeat until plan completes or user stops
|
|
267
|
+
|
|
268
|
+
**Why fresh agent, not resume:** Resume relies on internal serialization that breaks with parallel tool calls. Fresh agents with explicit state are more reliable.
|
|
269
|
+
|
|
270
|
+
**Checkpoints in parallel waves:** Agent pauses and returns while other parallel agents may complete. Present checkpoint, spawn continuation, wait for all before next wave.
|
|
271
|
+
</step>
|
|
272
|
+
|
|
273
|
+
<step name="aggregate_results">
|
|
274
|
+
After all waves:
|
|
275
|
+
|
|
276
|
+
```markdown
|
|
277
|
+
## Phase {X}: {Name} Execution Complete
|
|
278
|
+
|
|
279
|
+
**Waves:** {N} | **Plans:** {M}/{total} complete
|
|
280
|
+
|
|
281
|
+
| Wave | Plans | Status |
|
|
282
|
+
|------|-------|--------|
|
|
283
|
+
| 1 | plan-01, plan-02 | ✓ Complete |
|
|
284
|
+
| CP | plan-03 | ✓ Verified |
|
|
285
|
+
| 2 | plan-04 | ✓ Complete |
|
|
286
|
+
|
|
287
|
+
### Plan Details
|
|
288
|
+
1. **03-01**: [one-liner from SUMMARY.md]
|
|
289
|
+
2. **03-02**: [one-liner from SUMMARY.md]
|
|
290
|
+
|
|
291
|
+
### Test Summary
|
|
292
|
+
If any plan SUMMARY.md mentions test results, aggregate:
|
|
293
|
+
```
|
|
294
|
+
Tests: X passed, Y failed across {N} plans
|
|
295
|
+
```
|
|
296
|
+
If Y > 0, note in Issues Encountered.
|
|
297
|
+
|
|
298
|
+
### Issues Encountered
|
|
299
|
+
[Aggregate from SUMMARYs, or "None"]
|
|
300
|
+
```
|
|
301
|
+
</step>
|
|
302
|
+
|
|
303
|
+
<step name="design_polish_pass">
|
|
304
|
+
After all waves complete, check if this phase produced frontend work.
|
|
305
|
+
|
|
306
|
+
```bash
|
|
307
|
+
# Find the earliest commit from this phase across all plan numbering formats
|
|
308
|
+
PHASE_BASE=$(git log --oneline --all --grep="(${PHASE_NUMBER}-" --reverse 2>/dev/null | head -1 | cut -d' ' -f1)
|
|
309
|
+
if [ -z "$PHASE_BASE" ]; then
|
|
310
|
+
# Fallback: try zero-padded format
|
|
311
|
+
PADDED=$(printf "%02d" "${PHASE_NUMBER}")
|
|
312
|
+
PHASE_BASE=$(git log --oneline --all --grep="(${PADDED}-" --reverse 2>/dev/null | head -1 | cut -d' ' -f1)
|
|
313
|
+
fi
|
|
314
|
+
|
|
315
|
+
if [ -n "$PHASE_BASE" ]; then
|
|
316
|
+
FRONTEND_FILES=$(git diff --name-only ${PHASE_BASE}^..HEAD 2>/dev/null | grep -E '\.(tsx|jsx|css|scss)$' | head -30)
|
|
317
|
+
else
|
|
318
|
+
# Last resort: check all uncommitted + recent commits
|
|
319
|
+
FRONTEND_FILES=$(git diff --name-only HEAD~20..HEAD 2>/dev/null | grep -E '\.(tsx|jsx|css|scss)$' | head -30)
|
|
320
|
+
fi
|
|
321
|
+
```
|
|
322
|
+
|
|
323
|
+
**If no frontend files:** Skip to verify_phase_goal.
|
|
324
|
+
|
|
325
|
+
**If frontend files exist:** Run the impeccable diagnostic-then-fix flow.
|
|
326
|
+
|
|
327
|
+
### Step 1: Run /critique diagnostic
|
|
328
|
+
|
|
329
|
+
```bash
|
|
330
|
+
# Content must be inlined — @ syntax doesn't work across Task() boundaries
|
|
331
|
+
CRITIQUE_SKILL=$(cat /home/qualia/.claude/skills/critique/SKILL.md 2>/dev/null)
|
|
332
|
+
FRONTEND_SKILL=$(cat /home/qualia/.claude/skills/frontend-master/SKILL.md 2>/dev/null)
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
```
|
|
336
|
+
Task(
|
|
337
|
+
prompt="You are a design director reviewing frontend work. Run a /critique diagnostic on all changed files.
|
|
338
|
+
|
|
339
|
+
<skill>
|
|
340
|
+
{critique_skill}
|
|
341
|
+
</skill>
|
|
342
|
+
|
|
343
|
+
<frontend_master>
|
|
344
|
+
{frontend_skill}
|
|
345
|
+
</frontend_master>
|
|
346
|
+
|
|
347
|
+
<files_to_review>
|
|
348
|
+
${FRONTEND_FILES}
|
|
349
|
+
</files_to_review>
|
|
350
|
+
|
|
351
|
+
<rules>
|
|
352
|
+
- Read each file before reviewing
|
|
353
|
+
- Follow the critique skill exactly: AI slop detection, visual hierarchy, information architecture, emotional resonance, states, typography, color, microcopy
|
|
354
|
+
- For each issue, specify which command to run (from the Priority Issues > Command field)
|
|
355
|
+
- Do NOT fix anything — only diagnose and recommend
|
|
356
|
+
- Output a structured report with:
|
|
357
|
+
1. Anti-Patterns Verdict (pass/fail)
|
|
358
|
+
2. Priority Issues (each with: what, why, fix, command)
|
|
359
|
+
3. Minor Observations
|
|
360
|
+
- If everything looks good, report 'Design quality meets standards — no fixes needed'
|
|
361
|
+
</rules>",
|
|
362
|
+
subagent_type="qualia-executor",
|
|
363
|
+
description="Design critique for Phase ${PHASE_NUMBER}"
|
|
364
|
+
)
|
|
365
|
+
```
|
|
366
|
+
|
|
367
|
+
### Step 2: Parse critique and run recommended commands
|
|
368
|
+
|
|
369
|
+
Read the critique report. If it says "no fixes needed" — skip to verify_phase_goal.
|
|
370
|
+
|
|
371
|
+
If issues were found, collect the unique recommended commands from the report (e.g., `/polish`, `/harden`, `/animate`, `/normalize`, `/clarify`, `/bolder`, `/distill`, etc.).
|
|
372
|
+
|
|
373
|
+
For each recommended command, load the corresponding skill and spawn a fix agent:
|
|
374
|
+
|
|
375
|
+
```bash
|
|
376
|
+
# Load only the skills the critique recommended
|
|
377
|
+
# Example: if critique recommended /polish and /harden
|
|
378
|
+
for SKILL_NAME in ${RECOMMENDED_COMMANDS}; do
|
|
379
|
+
SKILL_CONTENT=$(cat /home/qualia/.claude/skills/${SKILL_NAME}/SKILL.md 2>/dev/null)
|
|
380
|
+
# Only proceed if skill file exists
|
|
381
|
+
if [ -n "$SKILL_CONTENT" ]; then
|
|
382
|
+
echo "Loading skill: ${SKILL_NAME}"
|
|
383
|
+
fi
|
|
384
|
+
done
|
|
385
|
+
```
|
|
386
|
+
|
|
387
|
+
Spawn a single fix agent with all recommended skills loaded:
|
|
388
|
+
|
|
389
|
+
```
|
|
390
|
+
Task(
|
|
391
|
+
prompt="You are a design quality fixer. Apply the recommended fixes from the critique report.
|
|
392
|
+
|
|
393
|
+
<critique_report>
|
|
394
|
+
{critique_output}
|
|
395
|
+
</critique_report>
|
|
396
|
+
|
|
397
|
+
<skills>
|
|
398
|
+
{For each recommended command, inline its SKILL.md content here}
|
|
399
|
+
</skills>
|
|
400
|
+
|
|
401
|
+
<frontend_master>
|
|
402
|
+
{frontend_skill}
|
|
403
|
+
</frontend_master>
|
|
404
|
+
|
|
405
|
+
<files_to_fix>
|
|
406
|
+
${FRONTEND_FILES}
|
|
407
|
+
</files_to_fix>
|
|
408
|
+
|
|
409
|
+
<rules>
|
|
410
|
+
- Read each file before modifying — understand context first
|
|
411
|
+
- Only modify files in the list above
|
|
412
|
+
- Only fix what the critique identified — do not refactor or restructure logic
|
|
413
|
+
- Apply each recommended skill to address its specific issues
|
|
414
|
+
- Commit changes as: style(${PHASE_NUMBER}): design quality — [summary of what was fixed]
|
|
415
|
+
- If a recommended fix would require architectural changes, skip it and note why
|
|
416
|
+
</rules>",
|
|
417
|
+
subagent_type="qualia-executor",
|
|
418
|
+
description="Design fixes for Phase ${PHASE_NUMBER}"
|
|
419
|
+
)
|
|
420
|
+
```
|
|
421
|
+
|
|
422
|
+
### Step 3: Report
|
|
423
|
+
|
|
424
|
+
```
|
|
425
|
+
---
|
|
426
|
+
## Design Quality Pass
|
|
427
|
+
|
|
428
|
+
**Critique:** {pass/fail verdict}
|
|
429
|
+
**Issues found:** {N}
|
|
430
|
+
**Commands applied:** {list of skills that ran}
|
|
431
|
+
**Fixed:** {summary of changes}
|
|
432
|
+
|
|
433
|
+
{If issues were skipped: list why}
|
|
434
|
+
---
|
|
435
|
+
```
|
|
436
|
+
|
|
437
|
+
Report before proceeding to verify_phase_goal.
|
|
438
|
+
</step>
|
|
439
|
+
|
|
440
|
+
<step name="verify_phase_goal">
|
|
441
|
+
Verify phase achieved its GOAL, not just completed tasks.
|
|
442
|
+
|
|
443
|
+
```
|
|
444
|
+
Task(
|
|
445
|
+
prompt="Verify phase {phase_number} goal achievement.
|
|
446
|
+
Phase directory: {phase_dir}
|
|
447
|
+
Phase goal: {goal from ROADMAP.md}
|
|
448
|
+
Check must_haves against actual codebase. Create VERIFICATION.md.",
|
|
449
|
+
subagent_type="qualia-verifier",
|
|
450
|
+
model="{verifier_model}"
|
|
451
|
+
)
|
|
452
|
+
```
|
|
453
|
+
|
|
454
|
+
Read status:
|
|
455
|
+
```bash
|
|
456
|
+
grep "^status:" "$PHASE_DIR"/*-VERIFICATION.md | cut -d: -f2 | tr -d ' '
|
|
457
|
+
```
|
|
458
|
+
|
|
459
|
+
| Status | Action |
|
|
460
|
+
|--------|--------|
|
|
461
|
+
| `passed` | → update_roadmap |
|
|
462
|
+
| `human_needed` | Present items for human testing, get approval or feedback |
|
|
463
|
+
| `gaps_found` | Present gap summary, offer `/qualia:plan-phase {phase} --gaps` |
|
|
464
|
+
|
|
465
|
+
**If human_needed:**
|
|
466
|
+
```
|
|
467
|
+
## ✓ Phase {X}: {Name} — Human Verification Required
|
|
468
|
+
|
|
469
|
+
All automated checks passed. {N} items need human testing:
|
|
470
|
+
|
|
471
|
+
{From VERIFICATION.md human_verification section}
|
|
472
|
+
|
|
473
|
+
"approved" → continue | Report issues → gap closure
|
|
474
|
+
```
|
|
475
|
+
|
|
476
|
+
**If gaps_found:**
|
|
477
|
+
```
|
|
478
|
+
## ⚠ Phase {X}: {Name} — Gaps Found
|
|
479
|
+
|
|
480
|
+
**Score:** {N}/{M} must-haves verified
|
|
481
|
+
**Report:** {phase_dir}/{phase}-VERIFICATION.md
|
|
482
|
+
|
|
483
|
+
### What's Missing
|
|
484
|
+
{Gap summaries from VERIFICATION.md}
|
|
485
|
+
|
|
486
|
+
---
|
|
487
|
+
## ▶ Next Up
|
|
488
|
+
|
|
489
|
+
`/qualia:plan-phase {X} --gaps`
|
|
490
|
+
|
|
491
|
+
<sub>`/clear` first → fresh context window</sub>
|
|
492
|
+
|
|
493
|
+
Also: `cat {phase_dir}/{phase}-VERIFICATION.md` — full report
|
|
494
|
+
Also: `/qualia:verify-work {X}` — manual testing first
|
|
495
|
+
```
|
|
496
|
+
|
|
497
|
+
Gap closure cycle: `/qualia:plan-phase {X} --gaps` reads VERIFICATION.md → creates gap plans with `gap_closure: true` → user runs `/qualia:execute-phase {X} --gaps-only` → verifier re-runs automatically (see below).
|
|
498
|
+
|
|
499
|
+
**Mandatory re-verification after gap closure:**
|
|
500
|
+
|
|
501
|
+
When executing with `--gaps-only`, after all gap plans complete (aggregate_results), automatically re-run verification — do NOT skip to update_roadmap. The flow is:
|
|
502
|
+
|
|
503
|
+
1. Gap plans execute via execute_waves
|
|
504
|
+
2. aggregate_results reports completion
|
|
505
|
+
3. verify_phase_goal re-runs (spawn qualia-verifier again)
|
|
506
|
+
4. **If `passed`:** → update_roadmap (phase complete)
|
|
507
|
+
5. **If `gaps_found` again:** Present new gaps, offer another `/qualia:plan-phase {X} --gaps` cycle. **Never mark phase complete with gaps.**
|
|
508
|
+
6. **If `human_needed`:** Present for manual testing as usual
|
|
509
|
+
|
|
510
|
+
A phase MUST NOT be marked complete in ROADMAP.md until verification returns `passed` or the user explicitly approves after `human_needed`. There is no bypass.
|
|
511
|
+
</step>
|
|
512
|
+
|
|
513
|
+
<step name="update_roadmap">
|
|
514
|
+
Mark phase complete in ROADMAP.md (date, status). **Only reachable when verification status is `passed` or user approved `human_needed` items.**
|
|
515
|
+
|
|
516
|
+
```bash
|
|
517
|
+
node /home/qualia/.claude/qualia-engine/bin/qualia-tools.js commit "docs(phase-{X}): complete phase execution" --files .planning/ROADMAP.md .planning/STATE.md .planning/phases/{phase_dir}/*-VERIFICATION.md .planning/REQUIREMENTS.md
|
|
518
|
+
```
|
|
519
|
+
</step>
|
|
520
|
+
|
|
521
|
+
<step name="offer_next">
|
|
522
|
+
|
|
523
|
+
**If more phases:**
|
|
524
|
+
```
|
|
525
|
+
## Next Up
|
|
526
|
+
|
|
527
|
+
**Phase {X+1}: {Name}** — {Goal}
|
|
528
|
+
|
|
529
|
+
`/clear` then `/qualia:plan-phase {X+1}`
|
|
530
|
+
```
|
|
531
|
+
|
|
532
|
+
**If milestone complete:**
|
|
533
|
+
```
|
|
534
|
+
MILESTONE COMPLETE!
|
|
535
|
+
|
|
536
|
+
All {N} phases executed.
|
|
537
|
+
|
|
538
|
+
`/clear` then `/qualia:complete-milestone`
|
|
539
|
+
```
|
|
540
|
+
</step>
|
|
541
|
+
|
|
542
|
+
</process>
|
|
543
|
+
|
|
544
|
+
<context_efficiency>
|
|
545
|
+
Orchestrator: ~10-15% context. Subagents: fresh 200k each. No polling (Task blocks). No context bleed.
|
|
546
|
+
</context_efficiency>
|
|
547
|
+
|
|
548
|
+
<failure_handling>
|
|
549
|
+
- **Agent fails mid-plan:** Missing SUMMARY.md → report, ask user how to proceed
|
|
550
|
+
- **Dependency chain breaks:** Wave 1 fails → Wave 2 dependents likely fail → user chooses attempt or skip
|
|
551
|
+
- **All agents in wave fail:** Systemic issue → stop, report for investigation
|
|
552
|
+
- **Checkpoint unresolvable:** "Skip this plan?" or "Abort phase execution?" → record partial progress in STATE.md
|
|
553
|
+
</failure_handling>
|
|
554
|
+
|
|
555
|
+
<resumption>
|
|
556
|
+
Re-run `/qualia:execute-phase {phase}` → discover_plans finds completed SUMMARYs → skips them → resumes from first incomplete plan → continues wave execution.
|
|
557
|
+
|
|
558
|
+
STATE.md tracks: last completed plan, current wave, pending checkpoints.
|
|
559
|
+
</resumption>
|