You are executing the user's plan that has been iteratively refined.
To do this, follow these steps precisely:
-
Read
.claude/plan-critique-config.jsonand getplansFolderpath from settings. If the file doesn't exist orplansFolderis not set: Respond with "No plans folder configured. Run/plan:createfirst to set up." -
Get the Claude Code process ID by running:
echo $PPID. Store this assessionPID. -
Clean up stale sessions: Scan
[plansFolder]/.sessions/for files. For each file named with a PID, check if that process is still running viakill -0 [PID] 2>/dev/null. If the command fails (process not running), delete that session file. This is non-blocking cleanup. -
Read the current session's plan from
[plansFolder]/.sessions/[sessionPID]if it exists. Store assessionPlan. -
Scan
[plansFolder]/for subdirectories (each subdirectory is a plan). Excludearchived/and.sessions/folders and any files, only list plan directories. If no plan folders exist: Respond with "No plans found. Create one with/plan:create". -
Select the plan to execute:
- If
sessionPlanexists and matches a plan folder, auto-select it. Inform the user: "Using current session plan: [sessionPlan]" - Else if only one plan exists, auto-select it and inform user.
- Otherwise, ask the user to select a plan from the list.
Example:
Available plans: 1. add-user-authentication 2. refactor-database-layer 3. implement-caching Which plan would you like to execute? [1-3]
- If
-
Update the session file
[plansFolder]/.sessions/[sessionPID]with the selected plan slug (create if needed). -
Check prerequisites:
- If
[plansFolder]/[selected-plan]/plan.mddoes not exist: Respond with "No plan.md found." - If
plan.mdis empty: Respond with "Plan file is empty. Run /plan:critique first."
- If
-
Read
CLAUDE.mdfrom the project root if it exists. Hold its standards as context and ensure compliance during each execution step. If it does not exist, note this but do not block execution. -
Read
[plansFolder]/[selected-plan]/critique.mdif it exists. Note the iteration number and summary. Inform the user: "Plan was critiqued (iteration N). Last critique summary: [brief]." Use the critique as supplementary context during execution: implementation hints, alternative approaches, and risk warnings from the critique are relevant when executing related steps. Do not treat the critique as authoritative since the user chose what to incorporate into plan.md. If critique.md does not exist, warn: "This plan has not been critiqued. Run/plan:critiquefirst, or confirm you want to proceed without review." Wait for user confirmation before continuing. -
Check git status by running
git status.- If git repo and clean: inform user "Git available. Per-step commits will be offered after each step."
- If git repo and dirty: warn "Uncommitted changes detected. Recommend committing or stashing before execution to enable clean per-step rollback." Wait for user acknowledgement.
- If not a git repo: inform "Not a git repository. Per-step commits are not available." Store whether git is available for later use.
-
Check for existing execution state. If
[plansFolder]/[selected-plan]/execution-state.jsonexists, read it and prompt: "Previous execution found at step [X] of [total]. Resume or restart?" Wait for user response before proceeding.- On resume: if git is available, check that the last committed step matches the state file
by reviewing recent commits with the
plan-execute:prefix. If they do not match, warn the user that the codebase may have diverged from the recorded state. Skip already-completed steps. - On restart: overwrite execution-log.md with a new header. Note the restart in the log: "Restarted execution (previous attempt reached step [X])."
- On resume: if git is available, check that the last committed step matches the state file
by reviewing recent commits with the
-
Review supporting files in the
[plansFolder]/[selected-plan]/folder. Classify each file by type and inferred purpose. Present to the user alongside the step list: "Supporting files found: schema.sql (SQL migration), mockup.png (UI reference)." Let the user confirm or clarify how each file should be used during execution. -
Parse the plan into discrete, executable steps using this ordering strategy:
- Independent tasks first: changes with no dependencies on other changes
- Small to large: within independent tasks, order from smallest to largest scope
- Dependent tasks after: once all independent tasks are ordered, add tasks that depend on them
- Same-level tiebreaker: for tasks at the same dependency level, order by logical grouping
Example: If a plan has "Add utility function", "Create database migration", and "Update API endpoint (uses utility)", order as: 1) Add utility function, 2) Create database migration, 3) Update API endpoint
-
Use Glob and Grep to estimate which existing files each step is likely to affect. Present the steps to the user for confirmation, including the dependency graph and file estimates:
I've parsed your plan into the following steps: 1. [Step description] - likely affects: src/auth.ts, src/middleware.ts (no dependencies) 2. [Step description] - creates new file: src/utils/hash.ts (no dependencies) 3. [Step description] - likely affects: src/routes.ts (depends on step 1) ... Do you want me to proceed with execution? You can reorder or adjust steps before starting.Wait for the user to confirm or request changes to the ordering.
-
Execute each step sequentially:
- Record the step start time.
- Before each step, update execution-state.json with current progress including
stepStartedAt(see execution-state-format.md). - Ask for explicit user permission before high-risk operations:
- Database migrations or schema changes
- Deleting files or directories
- Modifying configuration files
- External API calls with side effects
- Any irreversible operations
- Execute the step, ensuring compliance with CLAUDE.md standards loaded in step 9. Reference critique.md findings when they are relevant to the current step.
- After the step completes, run verification:
- Use
mcp__ide__getDiagnosticson files modified in this step. Report only NEW errors or warnings (compare before and after to avoid flagging pre-existing issues). - If new errors are found, inform the user and ask: "Fix now, continue, or stop?"
- Use
- Show a diff summary: list files added, modified, or deleted in this step.
- If git is available (step 11), offer to commit:
- On the first step, ask: "Commit this step? (yes / no / yes-to-all)"
- If the user chose "yes-to-all", commit subsequent steps automatically without asking.
- Commit message format:
plan-execute: [plan-slug] step N - [brief description] - Record the commit hash in execution-state.json under
gitCommits.
- Compute step duration and log results to execution-log.md including duration and files changed (see execution-log-format.md).
- If a step introduces architectural patterns that should be documented in
CLAUDE.md, flag this to the user immediately rather than waiting until completion. - On error:
- Save execution state with the failed step.
- Diagnose the error: read the error output, identify the likely root cause.
- Include the actual error output verbatim in the execution log (not just a summary).
- Present recovery options to the user:
- Fix and retry - attempt to fix the issue, then re-execute this step.
- Skip step - mark as SKIPPED, warn about downstream dependencies, continue.
- Rollback step - if git commits are available, revert the last commit.