spec-kitty-plan
/spec-kitty.plan - Create Implementation Plan
Version: 0.11.0+
📍 WORKING DIRECTORY: Stay in planning repository
IMPORTANT: Plan works in the planning repository. NO worktrees created.
# Run from project root (same directory as /spec-kitty.specify):
# You should already be here if you just ran /spec-kitty.specify
# Creates:
# - kitty-specs/###-feature/plan.md → In planning repository
# - Commits to target branch
# - NO worktrees created
Do NOT cd anywhere. Stay in the planning repository root.
User Input
$ARGUMENTS
You MUST consider the user input before proceeding (if not empty).
Location Check (0.11.0+)
This command runs in the planning repository, not in a worktree.
- Resolve branch context from deterministic JSON output, not from
meta.jsoninspection:- Run
spec-kitty agent feature setup-plan --feature <feature-slug> --json - Use
target_branch/base_branch(and uppercase aliases) from that payload - Ensure
git branch --show-currentmatchestarget_branch
- Run
- Planning artifacts live in
kitty-specs/###-feature/ - The plan template is committed to the target branch after generation
Path reference rule: When you mention directories or files, provide either the absolute path or a path relative to the project root (for example, kitty-specs/<feature>/tasks/). Never refer to a folder by name alone.
Planning Interrogation (mandatory)
Before executing any scripts or generating artifacts you must interrogate the specification and stakeholders.
-
Scope proportionality (CRITICAL): FIRST, assess the feature's complexity from the spec:
- Trivial/Test Features (hello world, simple static pages, basic demos): Ask 1-2 questions maximum about tech stack preference, then proceed with sensible defaults
- Simple Features (small components, minor API additions): Ask 2-3 questions about tech choices and constraints
- Complex Features (new subsystems, multi-component features): Ask 3-5 questions covering architecture, NFRs, integrations
- Platform/Critical Features (core infrastructure, security, payments): Full interrogation with 5+ questions
-
User signals to reduce questioning: If the user says "use defaults", "just make it simple", "skip to implementation", "vanilla HTML/CSS/JS" - recognize these as signals to minimize planning questions and use standard approaches.
-
First response rule:
- For TRIVIAL features: Ask ONE tech stack question, then if answer is simple (e.g., "vanilla HTML"), proceed directly to plan generation
- For other features: Ask a single architecture question and end with
WAITING_FOR_PLANNING_INPUT
-
If the user has not provided plan context, keep interrogating with one question at a time.
-
Conversational cadence: After each reply, assess if you have SUFFICIENT context for this feature's scope. For trivial features, knowing the basic stack is enough. Only continue if critical unknowns remain.
Planning requirements (scale to complexity):
- Maintain a Planning Questions table internally covering questions appropriate to the feature's complexity (1-2 for trivial, up to 5+ for platform-level). Track columns
#,Question,Why it matters, andCurrent insight. Do not render this table to the user. - For trivial features, standard practices are acceptable (vanilla HTML, simple file structure, no build tools). Only probe if the user's request suggests otherwise.
- When you have sufficient context for the scope, summarize into an Engineering Alignment note and confirm.
- If user explicitly asks to skip questions or use defaults, acknowledge and proceed with best practices for that feature type.
Outline
-
Check planning discovery status:
- If any planning questions remain unanswered or the user has not confirmed the Engineering Alignment summary, stay in the one-question cadence, capture the user's response, update your internal table, and end with
WAITING_FOR_PLANNING_INPUT. Do not surface the table. Do not run the setup command yet. - Once every planning question has a concrete answer and the alignment summary is confirmed by the user, continue.
- If any planning questions remain unanswered or the user has not confirmed the Engineering Alignment summary, stay in the one-question cadence, capture the user's response, update your internal table, and end with
-
Detect feature context (CRITICAL - prevents wrong feature selection):
Before running any commands, detect which feature you're working on:
a. Check git branch name:
- Run:
git rev-parse --abbrev-ref HEAD - If branch matches pattern
###-feature-nameor###-feature-name-WP##, extract the feature slug (strip-WP##suffix if present) - Example: Branch
020-my-featureor020-my-feature-WP01→ Feature020-my-feature
b. Check current directory:
- Look for
###-feature-namepattern in the current path - Examples:
- Inside
kitty-specs/020-my-feature/→ Feature020-my-feature - Not in a worktree during planning (worktrees only used during implement): If detection runs from
.worktrees/020-my-feature-WP01/→ Feature020-my-feature
- Inside
c. Prioritize features without plan.md (if multiple exist):
- If multiple features exist and none detected from branch/path, list all features in
kitty-specs/ - Prefer features that don't have
plan.mdyet (unplanned features) - If ambiguous, ask the user which feature to plan
d. Extract feature slug:
- Feature slug format:
###-feature-name(e.g.,020-my-feature) - You MUST pass this explicitly to the setup-plan command using
--featureflag - DO NOT rely on auto-detection by the CLI (prevents wrong feature selection)
- Run:
-
Setup: Run
spec-kitty agent feature setup-plan --feature <feature-slug> --jsonfrom the repository root and parse JSON for:result: "success" or error messageplan_file: Absolute path to the created plan.mdfeature_dir: Absolute path to the feature directorytarget_branch/base_branch(deterministic branch contract for downstream commands)
Example:
# If detected feature is 020-my-feature: spec-kitty agent feature setup-plan --feature 020-my-feature --jsonError handling: If the command fails with "Cannot detect feature" or "Multiple features found", verify your feature detection logic in step 2 and ensure you're passing the correct feature slug.
-
Load context: Read FEATURE_SPEC and
.kittify/memory/constitution.mdif it exists. If the constitution file is missing, skip Constitution Check and note that it is absent. Load IMPL_PLAN template (already copied). -
Execute plan workflow: Follow the structure in IMPL_PLAN template, using the validated planning answers as ground truth:
- Update Technical Context with explicit statements from the user or discovery research; mark
[NEEDS CLARIFICATION: …]only when the user deliberately postpones a decision - If a constitution exists, fill Constitution Check section from it and challenge any conflicts directly with the user. If no constitution exists, mark the section as skipped.
- Evaluate gates (ERROR if violations unjustified or questions remain unanswered)
- Phase 0: Generate research.md (commission research to resolve every outstanding clarification)
- Phase 1: Generate data-model.md, contracts/, quickstart.md based on confirmed intent
- Phase 1: Update agent context by running the agent script
- Re-evaluate Constitution Check post-design, asking the user to resolve new gaps before proceeding
- Update Technical Context with explicit statements from the user or discovery research; mark
-
STOP and report: This command ends after Phase 1 planning. Report branch, IMPL_PLAN path, and generated artifacts.
⚠️ CRITICAL: DO NOT proceed to task generation! The user must explicitly run
/spec-kitty.tasksto generate work packages. Your job is COMPLETE after reporting the planning artifacts.
Phases
Phase 0: Outline & Research
-
Extract unknowns from Technical Context above:
- For each NEEDS CLARIFICATION → research task
- For each dependency → best practices task
- For each integration → patterns task
-
Generate and dispatch research agents:
For each unknown in Technical Context: Task: "Research {unknown} for {feature context}" For each technology choice: Task: "Find best practices for {tech} in {domain}" -
Consolidate findings in
research.mdusing format:- Decision: [what was chosen]
- Rationale: [why chosen]
- Alternatives considered: [what else evaluated]
Output: research.md with all NEEDS CLARIFICATION resolved
Phase 1: Design & Contracts
Prerequisites: research.md complete
-
Extract entities from feature spec →
data-model.md:- Entity name, fields, relationships
- Validation rules from requirements
- State transitions if applicable
-
Generate API contracts from functional requirements:
- For each user action → endpoint
- Use standard REST/GraphQL patterns
- Output OpenAPI/GraphQL schema to
/contracts/
-
Agent context update:
- Run ``
- These scripts detect which AI agent is in use
- Update the appropriate agent-specific context file
- Add only new technology from current plan
- Preserve manual additions between markers
Output: data-model.md, /contracts/*, quickstart.md, agent-specific file
Key rules
- Use absolute paths
- ERROR on gate failures or unresolved clarifications
⛔ MANDATORY STOP POINT
This command is COMPLETE after generating planning artifacts.
After reporting:
plan.mdpathresearch.mdpath (if generated)data-model.mdpath (if generated)contracts/contents (if generated)- Agent context file updated
YOU MUST STOP HERE.
Do NOT:
- ❌ Generate
tasks.md - ❌ Create work package (WP) files
- ❌ Create
tasks/subdirectories - ❌ Proceed to implementation
The user will run /spec-kitty.tasks when they are ready to generate work packages.
Next suggested command: /spec-kitty.tasks (user must invoke this explicitly)