Files
gh-coalesce-labs-catalyst-p…/commands/implement_plan.md
2025-11-29 18:14:39 +08:00

5.8 KiB

description, category, tools, model, version
description category tools model version
Implement approved technical plans from thoughts/shared/plans/ workflow Read, Write, Edit, Grep, Glob, Task, TodoWrite, Bash inherit 1.0.0

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.

Prerequisites

Before executing, verify required tools are installed:

if [[ -f "${CLAUDE_PLUGIN_ROOT}/scripts/check-prerequisites.sh" ]]; then
  "${CLAUDE_PLUGIN_ROOT}/scripts/check-prerequisites.sh" || exit 1
fi

Initial Response

STEP 1: Auto-discover recent plan (REQUIRED)

IMMEDIATELY run this bash script BEFORE any other response:

# Auto-discover most recent plan from workflow context
if [[ -f "${CLAUDE_PLUGIN_ROOT}/scripts/workflow-context.sh" ]]; then
  RECENT_PLAN=$("${CLAUDE_PLUGIN_ROOT}/scripts/workflow-context.sh" recent plans)
  if [[ -n "$RECENT_PLAN" ]]; then
    echo "📋 Auto-discovered recent plan: $RECENT_PLAN"
    echo ""
  fi
fi

STEP 2: Determine which plan to implement

After running the auto-discovery script, follow this logic:

  1. If user provided a plan path as parameter:

    • Use the provided path (user override)
    • Skip to Step 3
  2. If no parameter provided AND RECENT_PLAN was found:

    • Show user: "📋 Found recent plan: $RECENT_PLAN"
    • Ask: "Proceed with this plan? [Y/n]"
    • If yes: use RECENT_PLAN and skip to Step 3
    • If no: proceed to option 3
  3. If no parameter AND no RECENT_PLAN found:

    • List available plans from thoughts/shared/plans/
    • Show most recent 5 plans with dates and ticket numbers
    • Ask user which plan to implement
    • Wait for user input with plan path

STEP 3: Read and prepare

Once you have a plan path:

  • Read the plan completely (no limit/offset)
  • Check for any existing checkmarks (- [x]) to see what's done
  • Read the original ticket and all files mentioned in the plan
  • Think deeply about how the pieces fit together
  • Create a todo list to track your progress
  • Start implementing if you understand what needs to be done

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 test covers 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
  • Check context usage - monitor token consumption

Don't let verification interrupt your flow - batch it at natural stopping points.

Context Management During Implementation

Monitor context proactively throughout implementation:

After Each Phase:

✅ Phase {N} complete!

## 📊 Context Status
Current usage: {X}% ({Y}K/{Z}K tokens)

{If >60%}:
⚠️ **Context Alert**: We're at {X}% usage.

**Recommendation**: Create a handoff before continuing to Phase {N+1}.

**Why?** Implementation accumulates context:
- File reads
- Code changes
- Test outputs
- Error messages
- Context clears ensure continued high performance

**Options**:
1. ✅ Create handoff and clear context (recommended)
   - Use `/create-handoff` to generate properly formatted handoff
   - Format: `thoughts/shared/handoffs/{ticket}/YYYY-MM-DD_HH-MM-SS_description.md`
   - Includes timestamp for lexical sorting by recency
2. Continue to next phase (if close to completion)

**To resume**: Start fresh session, run `/implement-plan {plan-path}`
(The plan file tracks progress with checkboxes - you'll resume automatically)

{If <60%}:
✅ Context healthy. Ready for Phase {N+1}.

When to Warn:

  • After any phase if context >60%
  • If context >70%, strongly recommend handoff
  • If context >80%, STOP and require handoff
  • If user is spinning on errors (3+ attempts), suggest context clear

Educate About Phase-Based Context:

  • Explain that implementation is designed to work in chunks
  • Each phase completion is a natural handoff point
  • Plan file preserves progress across sessions
  • Fresh context = fresh perspective on next phase

Creating a Handoff:

When recommending a handoff, guide the user:

  1. Offer to create the handoff using /create-handoff
  2. Or create a manual handoff following the timestamp convention
  3. Handoff filename format: thoughts/shared/handoffs/{ticket}/YYYY-MM-DD_HH-MM-SS_description.md
  4. Include: completed phases, next steps, key learnings, file references
  5. Update plan file with checkboxes for completed work

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.

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.