create-plan

star 13

Create detailed implementation plans through an interactive process. **ALWAYS use when** the user says 'plan this', 'create a plan', 'let's plan the implementation', 'design the approach', or wants a structured TDD implementation plan before writing code. Works best after /research-codebase.

coalesce-labs By coalesce-labs schedule Updated 4/29/2026

name: create-plan description: "Create detailed implementation plans through an interactive process. ALWAYS use when the user says 'plan this', 'create a plan', 'let's plan the implementation', 'design the approach', or wants a structured TDD implementation plan before writing code. Works best after /research-codebase." disable-model-invocation: false allowed-tools: Read, Write, Grep, Glob, Task, TodoWrite, Bash, mcp__serena__activate_project, mcp__serena__list_memories, mcp__serena__read_memory, mcp__serena__get_symbols_overview, mcp__serena__find_symbol, mcp__serena__find_referencing_symbols, mcp__serena__search_for_pattern, mcp__serena__find_file, mcp__serena__list_dir version: 1.0.0

Implementation Plan

You are tasked with creating detailed implementation plans through an interactive, iterative process. You should be skeptical, thorough, and work collaboratively with the user to produce high-quality technical specifications.

Replace PROJ in ticket references with your Linear team's prefix from .catalyst/config.json.

Prerequisites

# Check project setup (thoughts, CLAUDE.md snippet, config)
if [[ -f "${CLAUDE_PLUGIN_ROOT}/scripts/check-project-setup.sh" ]]; then
  "${CLAUDE_PLUGIN_ROOT}/scripts/check-project-setup.sh" || exit 1
fi

# Auto-discover most recent research (workflow context + filesystem fallback)
RECENT_RESEARCH=""
if [[ -f "${CLAUDE_PLUGIN_ROOT}/scripts/workflow-context.sh" ]]; then
  RECENT_RESEARCH=$("${CLAUDE_PLUGIN_ROOT}/scripts/workflow-context.sh" recent research)
fi
if [[ -n "$RECENT_RESEARCH" ]]; then
  echo "๐Ÿ“‹ Auto-discovered recent research: $RECENT_RESEARCH"
else
  echo "โš ๏ธ No recent research found in workflow context or filesystem"
fi

Session Tracking

SESSION_SCRIPT="${CLAUDE_PLUGIN_ROOT}/scripts/catalyst-session.sh"
if [[ -x "$SESSION_SCRIPT" ]]; then
  CATALYST_SESSION_ID=$("$SESSION_SCRIPT" start --skill "create-plan" \
    --ticket "${TICKET_ID:-}" \
    --workflow "${CATALYST_SESSION_ID:-}")
  export CATALYST_SESSION_ID
  "$SESSION_SCRIPT" phase "$CATALYST_SESSION_ID" "planning" --phase 1
fi

Initial Response

Auto-discovery has already run in Prerequisites above. Check its output and follow this priority:

  1. If user provided parameters (file path or ticket reference):

    • Use the provided path (user override)
    • Read any provided files FULLY
    • If Prerequisites also discovered research (๐Ÿ“‹), mention it and ask if it should inform the plan
    • Begin the research process
  2. If no parameters provided AND Prerequisites discovered research (๐Ÿ“‹):

    • Show the discovered research path
    • Ask if it should be used as context for the plan
    • Wait for user's confirmation
  3. If no parameters AND no research found (โš ๏ธ):

    • Ask for: task/ticket description, context/constraints, related research
    • Wait for user's input

Process Steps

Step 1: Context Gathering & Initial Analysis

  1. Read all mentioned files immediately and FULLY:

    • Ticket files, research documents, related plans, JSON/data files
    • IMPORTANT: Use the Read tool WITHOUT limit/offset parameters
    • CRITICAL: Read these files yourself before spawning sub-tasks
  2. Extract ticket and update Linear state:

    If a ticket is detected (from the research document's source_ticket frontmatter, from the command argument, or from context), update ticket status to stateMap.planning from config using Linearis CLI (run linearis issues usage for syntax). If Linearis CLI is not available, skip silently and continue planning.

  3. Gather context using research sub-agents โ€” use the same agent palette and orientation process as /catalyst-dev:research-codebase (that skill is the single source of truth for how codebase research works). For planning, focus agents on the specific ticket/task scope rather than broad exploration:

    • codebase-locator โ€” find all files related to the ticket/task
    • codebase-analyzer โ€” understand how the current implementation works
    • thoughts-locator โ€” find existing thoughts documents about this feature (if relevant)
  4. Read all files identified by research tasks FULLY into the main context

  5. Analyze and verify understanding:

    • Cross-reference ticket requirements with actual code
    • Identify discrepancies, assumptions, and true scope
  6. Present informed understanding and focused questions:

    • Show what you found with file:line references
    • Only ask questions you genuinely cannot answer through code investigation

Step 2: Research & Discovery

After getting initial clarifications:

  1. If the user corrects any misunderstanding:

    • Spawn new research tasks to verify โ€” don't just accept corrections
    • Only proceed once you've verified the facts yourself
  2. Create a research todo list using TodoWrite

  3. Spawn parallel sub-tasks for comprehensive research:

    For local codebase:

    • codebase-locator โ€” find specific files
    • codebase-analyzer โ€” understand implementation details
    • codebase-pattern-finder โ€” find similar features to model after

    For external research:

    • external-research โ€” framework patterns and best practices from popular repos

    For historical context:

    • thoughts-locator / thoughts-analyzer โ€” find past research, plans, decisions
  4. Wait for ALL sub-tasks to complete before proceeding

  5. Present findings and design options with pros/cons for each approach

Step 3: Plan Structure Development

Once aligned on approach:

  1. Create initial plan outline showing phases and what each accomplishes
  2. Get feedback on structure before writing details

Step 4: Detailed Plan Writing

After structure approval:

  1. Gather metadata:

    CURRENT_ISO_DATETIME=$(date -Iseconds)
    CURRENT_DATE=$(date +%Y-%m-%d)
    GIT_COMMIT_SHORT=$(git rev-parse --short HEAD)
    GIT_BRANCH=$(git branch --show-current)
    REPO_NAME=$(basename "$(git rev-parse --show-toplevel)")
    

    IMPORTANT: Document Storage Rules

    • ALWAYS write to thoughts/shared/plans/
    • NEVER write to thoughts/searchable/ (read-only search index)
  2. Write the plan to thoughts/shared/plans/YYYY-MM-DD-PROJ-XXXX-description.md

    • With ticket: 2025-01-08-PROJ-123-parent-child-tracking.md
    • Without ticket: 2025-01-08-improve-error-handling.md
  3. Use this template structure (frontmatter comes BEFORE the heading):

---
date: { CURRENT_ISO_DATETIME }
researcher: claude
git_commit: { GIT_COMMIT_SHORT }
branch: { GIT_BRANCH }
repository: { REPO_NAME }
topic: "{PLAN_TITLE}"
tags: [plan, implementation, { RELEVANT_COMPONENT_TAGS }]
status: ready_for_implementation
last_updated: { CURRENT_DATE }
last_updated_by: claude
type: implementation_plan
source_ticket: { TICKET-ID or null }
source_research: "[[research-doc-filename]]" # or null
---

# [Feature/Task Name] Implementation Plan

## Overview

[Brief description of what we're implementing and why]

## Current State Analysis

[What exists now, what's missing, key constraints discovered]

## Desired End State

[Specification of the desired end state and how to verify it]

### Key Discoveries:

- [Important finding with file:line reference]
- [Pattern to follow]
- [Constraint to work within]

## What We're NOT Doing

[Explicitly list out-of-scope items to prevent scope creep]

## Implementation Approach

[High-level strategy and reasoning]

## Phase 1: [Descriptive Name]

### Overview

[What this phase accomplishes]

### Tests First (Red):

Define the expected behavior before writing implementation code.

#### 1. [Test File/Group]

**File**: `tests/path/to/feature.test.ext` **Tests to write**:

```[language]
// Test describing expected behavior โ€” should FAIL before implementation
```

### Implementation (Green):

Write the minimum code to make the tests pass.

#### 1. [Component/File Group]

**File**: `path/to/file.ext` **Changes**: [Summary of changes]

```[language]
// Specific code to add/modify
```

### Refactor (if needed):

[Any cleanup, extraction, or simplification to do while tests stay green]

### Success Criteria:

#### Automated Verification:

- [ ] Unit tests pass: `make test`
- [ ] Type checking passes: `make check`
- [ ] Linting passes: `make lint`

#### Manual Verification:

- [ ] Feature works as expected when tested
- [ ] No regressions in related features

---

## Phase 2: [Descriptive Name]

[Similar structure โ€” always Tests First โ†’ Implementation โ†’ Refactor]

---

## Testing Strategy (TDD)

**Approach: Test-Driven Development (Red โ†’ Green โ†’ Refactor)**

Each phase writes tests BEFORE implementation code. This ensures:

- Requirements are encoded as executable specifications
- Implementation stays focused on passing defined behavior
- Refactoring is safe because tests catch regressions

**Test tiers:**

- **Unit tests** โ€” written first for each function with business logic
- **Integration tests** โ€” written first for API endpoints and data flows
- **Edge case tests** โ€” written first for error states, invalid inputs, auth failures

**Per-phase rhythm:**

1. Write failing tests that describe the phase's expected behavior
2. Implement the minimum code to make tests pass
3. Refactor while keeping tests green

[Additional manual testing steps if needed]

## Performance Considerations

[Any performance implications]

## Migration Notes

[If applicable]

## References

- Original ticket: [[PROJ-XXX]]
- Related research: [[YYYY-MM-DD-relevant-research]]
- Similar implementation: `[file:line]`

Step 5: Sync, Track, and Review

5a. Sync thoughts:

humanlayer thoughts sync

5b. Present plan and ask for review:

  • Show plan location
  • Ask: Are phases properly scoped? Success criteria specific enough? Missing edge cases?
  • If context >60%, recommend clearing before implementation phase
  1. Iterate based on feedback until the user is satisfied

    • Re-sync thoughts after changes
  2. End session tracking:

    if [[ -n "${CATALYST_SESSION_ID:-}" && -x "$SESSION_SCRIPT" ]]; then
      "$SESSION_SCRIPT" end "$CATALYST_SESSION_ID" --status done
    fi
    
  3. After plan approval, provide implementation command:

    Use --team when: 3+ parallel phases, distinct domains, non-overlapping files, 10+ files Use standard mode when: sequential phases, same directory, <10 files, tightly coupled

    ## Ready to Implement
    
    Start a new session and run:
    /catalyst-dev:implement-plan [--team] thoughts/shared/plans/{PLAN_FILENAME}
    
    Tip: Start a fresh session โ€” implementation needs context for source files and progress tracking.
    

Important Guidelines

  1. Be Skeptical: Question vague requirements. Don't assume โ€” verify with code.
  2. Be Interactive: Don't write the full plan in one shot. Get buy-in at each step.
  3. Be Thorough: Read all context files COMPLETELY. Include file:line references. Use make check over individual lint/test commands when available.
  4. Be Practical: Focus on incremental, testable changes. Include "what we're NOT doing".
  5. No Open Questions in Final Plan: Research or ask for clarification immediately. The plan must be complete and actionable โ€” every decision made before finalizing.

Success Criteria Guidelines

Always separate into two categories:

  1. Automated Verification (run by agents): make test, make lint, type checking, etc.
  2. Manual Verification (requires human): UI/UX, performance, edge cases, acceptance criteria

Common Patterns

All patterns follow TDD: write tests for each step BEFORE implementing it.

For Database Changes:

Schema/migration โ†’ tests for store methods โ†’ store methods โ†’ tests for business logic โ†’ business logic โ†’ tests for API โ†’ API โ†’ clients

For New Features:

Research patterns โ†’ data model โ†’ tests for backend logic โ†’ backend logic โ†’ tests for API endpoints โ†’ API endpoints โ†’ tests for UI components โ†’ UI

For Refactoring:

Capture existing behavior as tests first โ†’ incremental changes (keep tests green) โ†’ backwards compatibility โ†’ migration strategy

Linear Integration

If a ticket is detected (from research document's source_ticket frontmatter, command argument, or context):

  • At planning start (Step 1): Update ticket status to stateMap.planning from config using Linearis CLI (run linearis issues usage for syntax).
  • After plan saved: Add a comment with the plan path using Linearis CLI (run linearis comments usage for syntax).
  • If Linearis CLI not available, skip silently and continue planning
Install via CLI
npx skills add https://github.com/coalesce-labs/catalyst --skill create-plan
Repository Details
star Stars 13
call_split Forks 2
navigation Branch main
article Path SKILL.md
More from Creator
coalesce-labs
coalesce-labs Explore all skills →