Implement Plan
You are tasked with implementing an approved technical plan from thoughts/shared/plans/. These plans contain phases with specific changes and success criteria.
Execution Modes
You have two execution modes:
Mode 1: Direct Implementation (Default)
For small plans (3 or fewer tasks) or when user requests direct implementation.
- You implement each phase yourself
- Context accumulates in main conversation
- Use this for quick, focused implementations
Mode 2: Agent Orchestration (Recommended for larger plans)
For plans with 4+ tasks or when context preservation is critical.
- You act as a thin orchestrator
- Agents execute each task and create handoffs
- Compaction-resistant: handoffs persist even if context compacts
- Use this for multi-phase implementations
To use agent orchestration mode, say: "I'll use agent orchestration for this plan" and follow the Agent Orchestration section below.
Getting Started
When given a plan path:
- Read the plan completely and check for any existing checkmarks (- [x])
- Read the original ticket and all files mentioned in the plan
- Read files fully - never use limit/offset parameters, you need complete context
- Think deeply about how the pieces fit together
- Create a todo list to track your progress
Pre-Implementation Risk Check
Before starting implementation, run a deep pre-mortem:
/premortem deep <plan-path>
This analyzes the plan against comprehensive checklists:
- Technical risks (scalability, dependencies, data, security)
- Integration risks (breaking changes, migration, rollback)
- Process risks (unclear requirements, stakeholder input)
- Testing risks (coverage gaps, load testing needs)
If HIGH severity risks are identified:
- The premortem will block via AskUserQuestion
- User must: accept risks explicitly, add mitigations, or research solutions
- If mitigations are added, update the plan before proceeding
Skip premortem if:
- Plan already has a "## Risks (Pre-Mortem)" section with mitigations
- User explicitly requests to skip (
--skip-premortem)
After premortem passes, start implementing if you understand what needs to be done.
If no plan path provided, ask for one.
Implementation Philosophy
Plans are carefully designed, but reality can be messy. Your job is to:
- Follow the plan's intent while adapting to what you find
- Implement each phase fully before moving to the next
- Verify your work makes sense in the broader codebase context
- Update checkboxes in the plan as you complete sections
When things don't match the plan exactly, think about why and communicate clearly. The plan is your guide, but your judgment matters too.
If you encounter a mismatch:
- STOP and think deeply about why the plan can't be followed
- Present the issue clearly:
Issue in Phase [N]: Expected: [what the plan says] Found: [actual situation] Why this matters: [explanation] How should I proceed?
Verification Approach
After implementing a phase:
- Run the success criteria checks (usually
make check testcovers everything) - Fix any issues before proceeding
- Update your progress in both the plan and your todos
- Check off completed items in the plan file itself using Edit
- Pause for human verification: After completing all automated verification for a phase, pause and inform the human that the phase is ready for manual testing. Use this format:
Phase [N] Complete - Ready for Manual Verification Automated verification passed: - [List automated checks that passed] Please perform the manual verification steps listed in the plan: - [List manual verification items from the plan] Let me know when manual testing is complete so I can proceed to Phase [N+1].
If instructed to execute multiple phases consecutively, skip the pause until the last phase. Otherwise, assume you are just doing one phase.
do not check off items in the manual testing steps until confirmed by the user.
If You Get Stuck
When something isn't working as expected:
- First, make sure you've read and understood all the relevant code
- Consider if the codebase has evolved since the plan was written
- Present the mismatch clearly and ask for guidance
Use sub-tasks sparingly - mainly for targeted debugging or exploring unfamiliar territory.
Resumable Agents
If the plan was created by plan-agent, you may be able to resume it for clarification:
- Check
.claude/cache/agents/agent-log.jsonlfor the plan-agent entry - Look for the
agentIdfield - To clarify or update the plan:
Task( resume="<agentId>", prompt="Phase 2 isn't matching the codebase. Can you clarify..." )
The resumed agent retains its full prior context (research, codebase analysis).
Available agents to resume:
plan-agent- Created the implementation planoracle- Researched best practicesdebug-agent- Investigated issues
Resuming Work
If the plan has existing checkmarks:
- Trust that completed work is done
- Pick up from the first unchecked item
- Verify previous work only if something seems off
Remember: You're implementing a solution, not just checking boxes. Keep the end goal in mind and maintain forward momentum.
Agent Orchestration Mode
When implementing larger plans (4+ tasks), use agent orchestration to stay compaction-resistant.
Why Agent Orchestration?
The Problem: During long implementations, context accumulates. If auto-compact triggers mid-task, you lose implementation context. Handoffs created at 80% context become stale.
The Solution: Delegate implementation to agents. Each agent:
- Starts with fresh context
- Implements one task
- Creates a handoff on completion
- Returns to orchestrator
Handoffs persist on disk. If compaction happens, you re-read handoffs and continue.
Setup
-
Create handoff directory:
mkdir -p thoughts/handoffs/<session-name>Use the session name from your continuity ledger.
-
Read the implementation agent skill:
cat .claude/skills/implement_task/SKILL.mdThis defines how agents should behave.
Pre-Requisite: Plan Validation
Before implementing, ensure the plan has been validated using the validate-agent. The validation step is separate and should have created a handoff with status VALIDATED.
Check for validation handoff:
ls thoughts/handoffs/<session>/validation-*.md
If no validation exists, suggest running validation first:
"This plan hasn't been validated yet. Would you like me to spawn validate-agent first?"
If validation exists but status is NEEDS REVIEW, present the issues before proceeding.
Orchestration Loop
For each task in the plan:
-
Prepare agent context:
- Read continuity ledger (current state)
- Read the plan (overall context)
- Read previous handoff if exists (from thoughts/handoffs/<session>/)
- Identify the specific task
-
Spawn implementation agent:
Task( subagent_type="general-purpose", model="claude-opus-4-5-20251101", prompt=""" [Paste contents of .claude/skills/implement_task/SKILL.md here] --- ## Your Context ### Continuity Ledger: [Paste ledger content] ### Plan: [Paste relevant plan section or full plan] ### Your Task: Task [N] of [Total]: [Task description from plan] ### Previous Handoff: [Paste previous task's handoff content, or "This is the first task - no previous handoff"] ### Handoff Directory: thoughts/handoffs/<session-name>/ ### Handoff Filename: task-[NN]-[short-description].md --- Implement your task and create your handoff. """ ) -
Process agent result:
- Read the agent's handoff file
- Update ledger checkbox:
[x] Task N - Update plan checkbox if applicable
- Continue to next task
-
On agent failure/blocker:
- Rea