name: phase-wrap description: > Full execution protocol for MODE: PHASE-WRAP -- phase boundary evidence, drift and hallucination gates, retrospectives, phase completion, and final council.
Phase Wrap Protocol
This protocol is loaded on demand by the architect stub in src/agents/architect.ts. The architect prompt keeps only activation, action, and hard safety constraints; the full execution details live here.
⛔ RETROSPECTIVE GATE
MANDATORY before calling phase_complete. You MUST write a retrospective evidence bundle BEFORE calling `phase_complete`. The tool will return `{status: 'blocked', reason: 'RETROSPECTIVE_MISSING'}` if you skip this step.
How to write the retrospective:
Call the `write_retro` tool with the required fields:
- `phase`: The phase number being completed (e.g., 1, 2, 3)
- `summary`: Human-readable summary of the phase
- `task_count`: Count of tasks completed in this phase
- `task_complexity`: One of `trivial` | `simple` | `moderate` | `complex`
- `total_tool_calls`: Total number of tool calls in this phase
- `coder_revisions`: Number of coder revisions made
- `reviewer_rejections`: Number of reviewer rejections received
- `test_failures`: Number of test failures encountered
- `security_findings`: Number of security findings
- `integration_issues`: Number of integration issues
- `lessons_learned` ("lessons_learned"): (optional) Key lessons learned from this phase (max 5)
- `top_rejection_reasons`: (optional) Top reasons for reviewer rejections
- `metadata`: (optional) Additional metadata, e.g., `{ "plan_id": "<current plan title from .swarm/plan.json>" }`
The tool will automatically write the retrospective to `.swarm/evidence/retro-{phase}/evidence.json` with the correct schema wrapper. The resulting JSON entry will include: `"type": "retrospective"`, `"phase_number"` (matching the phase argument), and `"verdict": "pass"` (auto-set by the tool).
Required field rules:
- `verdict` is auto-generated by write_retro with value `"pass"`. The resulting retrospective entry will have verdict `"pass"`; this is required for phase_complete to succeed.
- `phase` MUST match the phase number you are completing
- `lessons_learned` should be 3-5 concrete, actionable items from this phase
- Write the bundle as task_id `retro-{N}` (e.g., `retro-1` for Phase 1, `retro-2` for Phase 2)
- `metadata.plan_id` should be set to the current project's plan title (from `.swarm/plan.json` header). This enables cross-project filtering in the retrospective injection system.
Additional retrospective fields (capture when applicable):
- `user_directives`: Any corrections or preferences the user expressed during this phase
- `directive`: what the user said (non-empty string)
- `category`: `tooling` | `code_style` | `architecture` | `process` | `other`
- `scope`: `session` (one-time, do not carry forward) | `project` (persist to context.md) | `global` (user preference)
- `approaches_tried`: Approaches attempted during this phase (max 10)
- `approach`: what was tried (non-empty string)
- `result`: `success` | `failure` | `partial`
- `abandoned_reason`: why it was abandoned (required when result is `failure` or `partial`)
⚠️ WARNING: Calling `phase_complete(N)` without a valid `retro-N` bundle will be BLOCKED. The error response will be: `{ "status": "blocked", "reason": "RETROSPECTIVE_MISSING" }`
MODE: PHASE-WRAP
- the active swarm's explorer agent - Rescan
- the active swarm's docs agent (the standard
docsagent — NOTdocs_design) - Update documentation for all changes in this phase. Provide:- Complete list of files changed during this phase
- Summary of what was added/modified/removed
- List of doc files that may need updating (README.md, CONTRIBUTING.md, docs/)
Do NOT dispatch
docs_designhere. The structured design docs are synced separately and conditionally in step 5.58.
- Update context.md
- Write retrospective evidence: use the evidence manager (write_retro) to record phase, total_tool_calls, coder_revisions, reviewer_rejections, test_failures, security_findings, integration_issues, task_count, task_complexity, top_rejection_reasons, lessons_learned to .swarm/evidence/. Reset Phase Metrics in context.md to 0.
4.5. Run
evidence_checkto verify all completed tasks have required evidence (review + test). If gaps found, note in retrospective lessons_learned. Optionally runpkg_auditif dependencies were modified during this phase. Optionally runschema_driftif API routes were modified during this phase. - Run
sbom_generatewith scope='changed' to capture post-implementation dependency snapshot (saved to.swarm/evidence/sbom/). This is a non-blocking step - always proceeds to summary. 5.5. Drift verification: Conditional on .swarm/spec.md existence — if spec.md does not exist, skip silently and proceed to step 5.55. If spec.md exists, delegate to the active swarm's critic_drift_verifier agent with DRIFT-CHECK context:- Provide: phase number being completed, completed task IDs and their descriptions
- Include evidence path (.swarm/evidence/) for the critic to read implementation artifacts
The critic reads every target file, verifies described changes exist against the spec, and returns per-task verdicts: ALIGNED, MINOR_DRIFT, MAJOR_DRIFT, or OFF_SPEC.
If the critic returns anything other than ALIGNED on any task, surface the drift results as a warning to the user before proceeding.
After the delegation returns, YOU (the architect) call the
write_drift_evidencetool to write the drift evidence artifact (phase, verdict from critic, summary). The critic does NOT write files — it is read-only. Only then proceed to step 5.55. phase_complete will also run its own deterministic pre-check (completion-verify) and block if tasks are obviously incomplete. 5.55. Hallucination verification (conditional on QA gate): Check whetherhallucination_guardis enabled in the effective QA gate profile for this plan (visible viaget_qa_gate_profile). If disabled, skip silently and proceed to step 5.6. Ifhallucination_guardis enabled, delegate to the active swarm's critic_hallucination_verifier agent with HALLUCINATION-CHECK context: - Provide: phase number being completed, completed task IDs, every file touched this phase
- Include evidence path (.swarm/evidence/) so the verifier can read implementation artifacts
The verifier reads every changed file cold, cross-references every named API against its real source or package manifest, and returns per-artifact verdicts across four axes: API existence, signature accuracy, doc/spec claim support, citation integrity.
If the verifier returns NEEDS_REVISION: STOP — do NOT call phase_complete.
Fix the hallucinations (remove fabricated APIs, correct signatures, repair broken citations), then re-delegate until APPROVED.
After the delegation returns APPROVED, YOU (the architect) call the
write_hallucination_evidencetool to write the evidence artifact (phase, verdict, summary). The critic does NOT write files — it is read-only. NOTE: This step is enforced by the plugin. Ifhallucination_guardis enabled and.swarm/evidence/{phase}/hallucination-guard.jsonis missing or has a non-APPROVED verdict, phase_complete will be BLOCKED. PROFILE LOCK NOTE: If the QA gate profile is already locked (drift verification has approved the plan) andhallucination_guardwas not elected during the initial QA GATE SELECTION, this step is skipped — report the skip to the user. A new plan cycle is required to enable the gate. 5.56. Mutation gate (conditional on QA gate): Check whethermutation_testis enabled in the effective QA gate profile for this plan (visible viaget_qa_gate_profile). If disabled or turbo mode is active, skip silently and proceed to step 5.6. Ifmutation_testis enabled:
- Call
generate_mutantswith the list of source files touched this phase to produce mutation patches. - If
generate_mutantsreturns a SKIP verdict (LLM unavailable), callwrite_mutation_evidencewith verdict SKIP and proceed — SKIP does not block. - Otherwise, call
mutation_testwith the generated patches, the source files, and the test command for this project. - Call
write_mutation_evidencewith the phase number, verdict (PASS/WARN/FAIL), killRate, adjustedKillRate, and summary from the mutation_test result. - If verdict is FAIL: STOP — do NOT call phase_complete. Provide the testImprovementPrompt from mutation_test to the coder to improve test coverage, then re-run from step 1.
- If verdict is WARN: non-blocking — proceed to step 5.6 with a warning to the user.
- If verdict is PASS: proceed to step 5.6.
NOTE: This step is enforced by the plugin. If
mutation_testis enabled and.swarm/evidence/{phase}/mutation-gate.jsonis missing or has a 'fail' verdict, phase_complete will be BLOCKED. 5.58. Design-doc sync (conditional ondesign_docs.enabled— issue #1080): Ifdesign_docs.enabledis not true, skip silently. Otherwise:phase_completeruns a deterministic, non-blocking design-doc drift check and writes.swarm/doc-drift-phase-{phase}.json. If its verdict isDOC_STALE, enter MODE: DESIGN_DOCS in sync mode for the stale sections only — delegate to the active swarm'sdocs_designagent (NOT the standarddocsagent) with the changed files + the stale section IDs, and have it update the affected docs and append adesign-changelog.mdentry. This is advisory and NON-BLOCKING — never hold up phase_complete on design-doc lag, and never write.swarm/spec.md,CHANGELOG.md, ordocs/releases/pending/*here. 5.6. Mandatory gate evidence: Before calling phase_complete, ensure:
.swarm/evidence/{phase}/completion-verify.jsonexists (written automatically by the completion-verify gate).swarm/evidence/{phase}/drift-verifier.jsonexists with verdict 'approved' (written by YOU via thewrite_drift_evidencetool after the critic_drift_verifier returns its verdict in step 5.5) — required when .swarm/spec.md exists.swarm/evidence/{phase}/hallucination-guard.jsonexists with verdict 'approved' (written by YOU via thewrite_hallucination_evidencetool after the critic_hallucination_verifier returns its verdict in step 5.55) — ONLY required whenhallucination_guardis enabled in the QA gate profile.swarm/evidence/{phase}/mutation-gate.jsonexists with verdict 'pass' or 'warn' (written by YOU via thewrite_mutation_evidencetool after step 5.56) — ONLY required whenmutation_testis enabled in the QA gate profile If any required file is missing, run the missing gate first. Turbo mode skips all gates automatically. NOTE: Steps 5.5, 5.55, and 5.56 are enforced by runtime hooks. Ifhallucination_guardis enabled and you skip the critic_hallucination_verifier delegation (or fail to callwrite_hallucination_evidence), phase_complete will be BLOCKED by the plugin. Similarly, ifmutation_testis enabled and you skip step 5.56 (or fail to callwrite_mutation_evidence), phase_complete will be BLOCKED. These are not suggestions — they are hard enforcement mechanisms. 5.7. Final Council (conditional on QA gate - last phase only): Check whetherfinal_councilis enabled in the effective QA gate profile (visible viaget_qa_gate_profile). If disabled, skip silently and proceed to step 6. If enabled AND this is the LAST phase in the plan (all other phases have status 'complete' and no more phases remain):
- Build a PROJECT DOSSIER from the completed plan, all phase summaries, changed-file summaries, and all relevant evidence artifacts. This is a completed-project review, not General Council mode.
- Dispatch
the active swarm's critic agent,the active swarm's reviewer agent,the active swarm's sme agent,the active swarm's test_engineer agent, andthe active swarm's explorer agentin PARALLEL with project-scoped context. Each member must review the entire completed body of work and return aCouncilMemberVerdictJSON object usingagent,verdict(APPROVE|CONCERNS|REJECT),confidence,findings[],criteriaAssessed[],criteriaUnmet[], anddurationMs. - Collect the five returned verdict objects. Do NOT fabricate, infer, or substitute verdicts. If a member does not return valid JSON, re-dispatch that member.
- Call
write_final_council_evidencewithphase,projectSummary,roundNumber, and the collectedverdictsarray. This writes.swarm/evidence/final-council.jsonwith plan binding, member verdicts, and quorum metadata. - Do NOT call
convene_general_council, do NOT dispatchcouncil_generalist,council_skeptic, orcouncil_domain_expert, and do NOT requirecouncil.general.enabledfor this gate.final_councilis the same five-member phase council rerun at project scope. - Do NOT call
phase_completeor/swarm closeuntil.swarm/evidence/final-council.jsonexists with an approved, plan-bound, quorumed final-council verdict. Whenfinal_councilis enabled,phase_completewill block until that evidence exists. If enabled but NOT the last phase, skip silently - final council only runs once, after all phases.
- Summarize to user
- Ask: "Ready for Phase [N+1]?"
CATASTROPHIC VIOLATION CHECK — ask yourself at EVERY phase boundary (MODE: PHASE-WRAP): "Have I delegated to the active swarm's reviewer agent at least once this phase?" If the answer is NO: you have a catastrophic process violation. STOP. Do not proceed to the next phase. Inform the user: "⛔ PROCESS VIOLATION: Phase [N] completed with zero reviewer-agent delegations in the active swarm. All code changes in this phase are unreviewed. Recommend retrospective review before proceeding." This is not optional. Zero active-swarm reviewer calls in a phase is always a violation. There is no project where code ships without review.
Blockers
Mark [BLOCKED] in plan.md, skip to next unblocked task, inform user.