spec-kitty-cli 0.12.1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- spec_kitty_cli-0.12.1.dist-info/METADATA +1767 -0
- spec_kitty_cli-0.12.1.dist-info/RECORD +242 -0
- spec_kitty_cli-0.12.1.dist-info/WHEEL +4 -0
- spec_kitty_cli-0.12.1.dist-info/entry_points.txt +2 -0
- spec_kitty_cli-0.12.1.dist-info/licenses/LICENSE +21 -0
- specify_cli/__init__.py +171 -0
- specify_cli/acceptance.py +627 -0
- specify_cli/agent_utils/README.md +157 -0
- specify_cli/agent_utils/__init__.py +9 -0
- specify_cli/agent_utils/status.py +356 -0
- specify_cli/cli/__init__.py +6 -0
- specify_cli/cli/commands/__init__.py +46 -0
- specify_cli/cli/commands/accept.py +189 -0
- specify_cli/cli/commands/agent/__init__.py +22 -0
- specify_cli/cli/commands/agent/config.py +382 -0
- specify_cli/cli/commands/agent/context.py +191 -0
- specify_cli/cli/commands/agent/feature.py +1057 -0
- specify_cli/cli/commands/agent/release.py +11 -0
- specify_cli/cli/commands/agent/tasks.py +1253 -0
- specify_cli/cli/commands/agent/workflow.py +801 -0
- specify_cli/cli/commands/context.py +246 -0
- specify_cli/cli/commands/dashboard.py +85 -0
- specify_cli/cli/commands/implement.py +973 -0
- specify_cli/cli/commands/init.py +827 -0
- specify_cli/cli/commands/init_help.py +62 -0
- specify_cli/cli/commands/merge.py +755 -0
- specify_cli/cli/commands/mission.py +240 -0
- specify_cli/cli/commands/ops.py +265 -0
- specify_cli/cli/commands/orchestrate.py +640 -0
- specify_cli/cli/commands/repair.py +175 -0
- specify_cli/cli/commands/research.py +165 -0
- specify_cli/cli/commands/sync.py +364 -0
- specify_cli/cli/commands/upgrade.py +249 -0
- specify_cli/cli/commands/validate_encoding.py +186 -0
- specify_cli/cli/commands/validate_tasks.py +186 -0
- specify_cli/cli/commands/verify.py +310 -0
- specify_cli/cli/helpers.py +123 -0
- specify_cli/cli/step_tracker.py +91 -0
- specify_cli/cli/ui.py +192 -0
- specify_cli/core/__init__.py +53 -0
- specify_cli/core/agent_context.py +311 -0
- specify_cli/core/config.py +96 -0
- specify_cli/core/context_validation.py +362 -0
- specify_cli/core/dependency_graph.py +351 -0
- specify_cli/core/git_ops.py +129 -0
- specify_cli/core/multi_parent_merge.py +323 -0
- specify_cli/core/paths.py +260 -0
- specify_cli/core/project_resolver.py +110 -0
- specify_cli/core/stale_detection.py +263 -0
- specify_cli/core/tool_checker.py +79 -0
- specify_cli/core/utils.py +43 -0
- specify_cli/core/vcs/__init__.py +114 -0
- specify_cli/core/vcs/detection.py +341 -0
- specify_cli/core/vcs/exceptions.py +85 -0
- specify_cli/core/vcs/git.py +1304 -0
- specify_cli/core/vcs/jujutsu.py +1208 -0
- specify_cli/core/vcs/protocol.py +285 -0
- specify_cli/core/vcs/types.py +249 -0
- specify_cli/core/version_checker.py +261 -0
- specify_cli/core/worktree.py +506 -0
- specify_cli/dashboard/__init__.py +28 -0
- specify_cli/dashboard/diagnostics.py +204 -0
- specify_cli/dashboard/handlers/__init__.py +17 -0
- specify_cli/dashboard/handlers/api.py +143 -0
- specify_cli/dashboard/handlers/base.py +65 -0
- specify_cli/dashboard/handlers/features.py +390 -0
- specify_cli/dashboard/handlers/router.py +81 -0
- specify_cli/dashboard/handlers/static.py +50 -0
- specify_cli/dashboard/lifecycle.py +541 -0
- specify_cli/dashboard/scanner.py +437 -0
- specify_cli/dashboard/server.py +123 -0
- specify_cli/dashboard/static/dashboard/dashboard.css +722 -0
- specify_cli/dashboard/static/dashboard/dashboard.js +1424 -0
- specify_cli/dashboard/static/spec-kitty.png +0 -0
- specify_cli/dashboard/templates/__init__.py +36 -0
- specify_cli/dashboard/templates/index.html +258 -0
- specify_cli/doc_generators.py +621 -0
- specify_cli/doc_state.py +408 -0
- specify_cli/frontmatter.py +384 -0
- specify_cli/gap_analysis.py +915 -0
- specify_cli/gitignore_manager.py +300 -0
- specify_cli/guards.py +145 -0
- specify_cli/legacy_detector.py +83 -0
- specify_cli/manifest.py +286 -0
- specify_cli/merge/__init__.py +63 -0
- specify_cli/merge/executor.py +653 -0
- specify_cli/merge/forecast.py +215 -0
- specify_cli/merge/ordering.py +126 -0
- specify_cli/merge/preflight.py +230 -0
- specify_cli/merge/state.py +185 -0
- specify_cli/merge/status_resolver.py +354 -0
- specify_cli/mission.py +654 -0
- specify_cli/missions/documentation/command-templates/implement.md +309 -0
- specify_cli/missions/documentation/command-templates/plan.md +275 -0
- specify_cli/missions/documentation/command-templates/review.md +344 -0
- specify_cli/missions/documentation/command-templates/specify.md +206 -0
- specify_cli/missions/documentation/command-templates/tasks.md +189 -0
- specify_cli/missions/documentation/mission.yaml +113 -0
- specify_cli/missions/documentation/templates/divio/explanation-template.md +192 -0
- specify_cli/missions/documentation/templates/divio/howto-template.md +168 -0
- specify_cli/missions/documentation/templates/divio/reference-template.md +179 -0
- specify_cli/missions/documentation/templates/divio/tutorial-template.md +146 -0
- specify_cli/missions/documentation/templates/generators/jsdoc.json.template +18 -0
- specify_cli/missions/documentation/templates/generators/sphinx-conf.py.template +36 -0
- specify_cli/missions/documentation/templates/plan-template.md +269 -0
- specify_cli/missions/documentation/templates/release-template.md +222 -0
- specify_cli/missions/documentation/templates/spec-template.md +172 -0
- specify_cli/missions/documentation/templates/task-prompt-template.md +140 -0
- specify_cli/missions/documentation/templates/tasks-template.md +159 -0
- specify_cli/missions/research/command-templates/merge.md +388 -0
- specify_cli/missions/research/command-templates/plan.md +125 -0
- specify_cli/missions/research/command-templates/review.md +144 -0
- specify_cli/missions/research/command-templates/tasks.md +225 -0
- specify_cli/missions/research/mission.yaml +115 -0
- specify_cli/missions/research/templates/data-model-template.md +33 -0
- specify_cli/missions/research/templates/plan-template.md +161 -0
- specify_cli/missions/research/templates/research/evidence-log.csv +18 -0
- specify_cli/missions/research/templates/research/source-register.csv +18 -0
- specify_cli/missions/research/templates/research-template.md +35 -0
- specify_cli/missions/research/templates/spec-template.md +64 -0
- specify_cli/missions/research/templates/task-prompt-template.md +148 -0
- specify_cli/missions/research/templates/tasks-template.md +114 -0
- specify_cli/missions/software-dev/command-templates/accept.md +75 -0
- specify_cli/missions/software-dev/command-templates/analyze.md +183 -0
- specify_cli/missions/software-dev/command-templates/checklist.md +286 -0
- specify_cli/missions/software-dev/command-templates/clarify.md +157 -0
- specify_cli/missions/software-dev/command-templates/constitution.md +432 -0
- specify_cli/missions/software-dev/command-templates/dashboard.md +101 -0
- specify_cli/missions/software-dev/command-templates/implement.md +41 -0
- specify_cli/missions/software-dev/command-templates/merge.md +383 -0
- specify_cli/missions/software-dev/command-templates/plan.md +171 -0
- specify_cli/missions/software-dev/command-templates/review.md +32 -0
- specify_cli/missions/software-dev/command-templates/specify.md +321 -0
- specify_cli/missions/software-dev/command-templates/tasks.md +566 -0
- specify_cli/missions/software-dev/mission.yaml +100 -0
- specify_cli/missions/software-dev/templates/plan-template.md +132 -0
- specify_cli/missions/software-dev/templates/spec-template.md +116 -0
- specify_cli/missions/software-dev/templates/task-prompt-template.md +140 -0
- specify_cli/missions/software-dev/templates/tasks-template.md +159 -0
- specify_cli/orchestrator/__init__.py +75 -0
- specify_cli/orchestrator/agent_config.py +224 -0
- specify_cli/orchestrator/agents/__init__.py +170 -0
- specify_cli/orchestrator/agents/augment.py +112 -0
- specify_cli/orchestrator/agents/base.py +243 -0
- specify_cli/orchestrator/agents/claude.py +112 -0
- specify_cli/orchestrator/agents/codex.py +106 -0
- specify_cli/orchestrator/agents/copilot.py +137 -0
- specify_cli/orchestrator/agents/cursor.py +139 -0
- specify_cli/orchestrator/agents/gemini.py +115 -0
- specify_cli/orchestrator/agents/kilocode.py +94 -0
- specify_cli/orchestrator/agents/opencode.py +132 -0
- specify_cli/orchestrator/agents/qwen.py +96 -0
- specify_cli/orchestrator/config.py +455 -0
- specify_cli/orchestrator/executor.py +642 -0
- specify_cli/orchestrator/integration.py +1230 -0
- specify_cli/orchestrator/monitor.py +898 -0
- specify_cli/orchestrator/scheduler.py +832 -0
- specify_cli/orchestrator/state.py +508 -0
- specify_cli/orchestrator/testing/__init__.py +122 -0
- specify_cli/orchestrator/testing/availability.py +346 -0
- specify_cli/orchestrator/testing/fixtures.py +684 -0
- specify_cli/orchestrator/testing/paths.py +218 -0
- specify_cli/plan_validation.py +107 -0
- specify_cli/scripts/debug-dashboard-scan.py +61 -0
- specify_cli/scripts/tasks/acceptance_support.py +695 -0
- specify_cli/scripts/tasks/task_helpers.py +506 -0
- specify_cli/scripts/tasks/tasks_cli.py +848 -0
- specify_cli/scripts/validate_encoding.py +180 -0
- specify_cli/task_metadata_validation.py +274 -0
- specify_cli/tasks_support.py +447 -0
- specify_cli/template/__init__.py +47 -0
- specify_cli/template/asset_generator.py +206 -0
- specify_cli/template/github_client.py +334 -0
- specify_cli/template/manager.py +193 -0
- specify_cli/template/renderer.py +99 -0
- specify_cli/templates/AGENTS.md +190 -0
- specify_cli/templates/POWERSHELL_SYNTAX.md +229 -0
- specify_cli/templates/agent-file-template.md +35 -0
- specify_cli/templates/checklist-template.md +42 -0
- specify_cli/templates/claudeignore-template +58 -0
- specify_cli/templates/command-templates/accept.md +141 -0
- specify_cli/templates/command-templates/analyze.md +253 -0
- specify_cli/templates/command-templates/checklist.md +352 -0
- specify_cli/templates/command-templates/clarify.md +224 -0
- specify_cli/templates/command-templates/constitution.md +432 -0
- specify_cli/templates/command-templates/dashboard.md +175 -0
- specify_cli/templates/command-templates/implement.md +190 -0
- specify_cli/templates/command-templates/merge.md +374 -0
- specify_cli/templates/command-templates/plan.md +171 -0
- specify_cli/templates/command-templates/research.md +88 -0
- specify_cli/templates/command-templates/review.md +510 -0
- specify_cli/templates/command-templates/specify.md +321 -0
- specify_cli/templates/command-templates/status.md +92 -0
- specify_cli/templates/command-templates/tasks.md +199 -0
- specify_cli/templates/git-hooks/pre-commit +22 -0
- specify_cli/templates/git-hooks/pre-commit-agent-check +37 -0
- specify_cli/templates/git-hooks/pre-commit-encoding-check +142 -0
- specify_cli/templates/plan-template.md +108 -0
- specify_cli/templates/spec-template.md +118 -0
- specify_cli/templates/task-prompt-template.md +165 -0
- specify_cli/templates/tasks-template.md +161 -0
- specify_cli/templates/vscode-settings.json +13 -0
- specify_cli/text_sanitization.py +225 -0
- specify_cli/upgrade/__init__.py +18 -0
- specify_cli/upgrade/detector.py +239 -0
- specify_cli/upgrade/metadata.py +182 -0
- specify_cli/upgrade/migrations/__init__.py +65 -0
- specify_cli/upgrade/migrations/base.py +80 -0
- specify_cli/upgrade/migrations/m_0_10_0_python_only.py +359 -0
- specify_cli/upgrade/migrations/m_0_10_12_constitution_cleanup.py +99 -0
- specify_cli/upgrade/migrations/m_0_10_14_update_implement_slash_command.py +176 -0
- specify_cli/upgrade/migrations/m_0_10_1_populate_slash_commands.py +174 -0
- specify_cli/upgrade/migrations/m_0_10_2_update_slash_commands.py +172 -0
- specify_cli/upgrade/migrations/m_0_10_6_workflow_simplification.py +174 -0
- specify_cli/upgrade/migrations/m_0_10_8_fix_memory_structure.py +252 -0
- specify_cli/upgrade/migrations/m_0_10_9_repair_templates.py +168 -0
- specify_cli/upgrade/migrations/m_0_11_0_workspace_per_wp.py +182 -0
- specify_cli/upgrade/migrations/m_0_11_1_improved_workflow_templates.py +173 -0
- specify_cli/upgrade/migrations/m_0_11_1_update_implement_slash_command.py +160 -0
- specify_cli/upgrade/migrations/m_0_11_2_improved_workflow_templates.py +173 -0
- specify_cli/upgrade/migrations/m_0_11_3_workflow_agent_flag.py +114 -0
- specify_cli/upgrade/migrations/m_0_12_0_documentation_mission.py +155 -0
- specify_cli/upgrade/migrations/m_0_12_1_remove_kitty_specs_from_gitignore.py +183 -0
- specify_cli/upgrade/migrations/m_0_2_0_specify_to_kittify.py +80 -0
- specify_cli/upgrade/migrations/m_0_4_8_gitignore_agents.py +118 -0
- specify_cli/upgrade/migrations/m_0_5_0_encoding_hooks.py +141 -0
- specify_cli/upgrade/migrations/m_0_6_5_commands_rename.py +169 -0
- specify_cli/upgrade/migrations/m_0_6_7_ensure_missions.py +228 -0
- specify_cli/upgrade/migrations/m_0_7_2_worktree_commands_dedup.py +89 -0
- specify_cli/upgrade/migrations/m_0_7_3_update_scripts.py +114 -0
- specify_cli/upgrade/migrations/m_0_8_0_remove_active_mission.py +82 -0
- specify_cli/upgrade/migrations/m_0_8_0_worktree_agents_symlink.py +148 -0
- specify_cli/upgrade/migrations/m_0_9_0_frontmatter_only_lanes.py +346 -0
- specify_cli/upgrade/migrations/m_0_9_1_complete_lane_migration.py +656 -0
- specify_cli/upgrade/migrations/m_0_9_2_research_mission_templates.py +221 -0
- specify_cli/upgrade/registry.py +121 -0
- specify_cli/upgrade/runner.py +284 -0
- specify_cli/validators/__init__.py +14 -0
- specify_cli/validators/paths.py +154 -0
- specify_cli/validators/research.py +428 -0
- specify_cli/verify_enhanced.py +270 -0
- specify_cli/workspace_context.py +224 -0
|
@@ -0,0 +1,321 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: Create or update the feature specification from a natural language feature description.
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# /spec-kitty.specify - Create Feature Specification
|
|
6
|
+
|
|
7
|
+
**Version**: 0.11.0+
|
|
8
|
+
|
|
9
|
+
## 📍 WORKING DIRECTORY: Stay in MAIN repository
|
|
10
|
+
|
|
11
|
+
**IMPORTANT**: Specify works in the main repository. NO worktrees are created.
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
# Run from project root:
|
|
15
|
+
cd /path/to/project/root # Your main repository
|
|
16
|
+
|
|
17
|
+
# All planning artifacts are created in main and committed:
|
|
18
|
+
# - kitty-specs/###-feature/spec.md → Created in main
|
|
19
|
+
# - Committed to main branch
|
|
20
|
+
# - NO worktrees created
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
**Worktrees are created later** during `/spec-kitty.implement`, not during planning.
|
|
24
|
+
|
|
25
|
+
## User Input
|
|
26
|
+
|
|
27
|
+
```text
|
|
28
|
+
$ARGUMENTS
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
You **MUST** consider the user input before proceeding (if not empty).
|
|
32
|
+
|
|
33
|
+
## Discovery Gate (mandatory)
|
|
34
|
+
|
|
35
|
+
Before running any scripts or writing to disk you **must** conduct a structured discovery interview.
|
|
36
|
+
|
|
37
|
+
- **Scope proportionality (CRITICAL)**: FIRST, gauge the inherent complexity of the request:
|
|
38
|
+
- **Trivial/Test Features** (hello world, simple pages, proof-of-concept): Ask 1-2 questions maximum, then proceed. Examples: "a simple hello world page", "tic-tac-toe game", "basic contact form"
|
|
39
|
+
- **Simple Features** (small UI additions, minor enhancements): Ask 2-3 questions covering purpose and basic constraints
|
|
40
|
+
- **Complex Features** (new subsystems, integrations): Ask 3-5 questions covering goals, users, constraints, risks
|
|
41
|
+
- **Platform/Critical Features** (authentication, payments, infrastructure): Full discovery with 5+ questions
|
|
42
|
+
|
|
43
|
+
- **User signals to reduce questioning**: If the user says "just testing", "quick prototype", "skip to next phase", "stop asking questions" - recognize this as a signal to minimize discovery and proceed with reasonable defaults.
|
|
44
|
+
|
|
45
|
+
- **First response rule**:
|
|
46
|
+
- For TRIVIAL features (hello world, simple test): Ask ONE clarifying question, then if the answer confirms it's simple, proceed directly to spec generation
|
|
47
|
+
- For other features: Ask a single focused discovery question and end with `WAITING_FOR_DISCOVERY_INPUT`
|
|
48
|
+
|
|
49
|
+
- If the user provides no initial description (empty command), stay in **Interactive Interview Mode**: keep probing with one question at a time.
|
|
50
|
+
|
|
51
|
+
- **Conversational cadence**: After each user reply, decide if you have ENOUGH context for this feature's complexity level. For trivial features, 1-2 questions is sufficient. Only continue asking if truly necessary for the scope.
|
|
52
|
+
|
|
53
|
+
Discovery requirements (scale to feature complexity):
|
|
54
|
+
|
|
55
|
+
1. Maintain a **Discovery Questions** table internally covering questions appropriate to the feature's complexity (1-2 for trivial, up to 5+ for complex). Track columns `#`, `Question`, `Why it matters`, and `Current insight`. Do **not** render this table to the user.
|
|
56
|
+
2. For trivial features, reasonable defaults are acceptable. Only probe if truly ambiguous.
|
|
57
|
+
3. When you have sufficient context for the feature's scope, paraphrase into an **Intent Summary** and confirm. For trivial features, this can be very brief.
|
|
58
|
+
4. If user explicitly asks to skip questions or says "just testing", acknowledge and proceed with minimal discovery.
|
|
59
|
+
|
|
60
|
+
## Mission Selection
|
|
61
|
+
|
|
62
|
+
After completing discovery and confirming the Intent Summary, determine the appropriate mission for this feature.
|
|
63
|
+
|
|
64
|
+
### Available Missions
|
|
65
|
+
|
|
66
|
+
- **software-dev**: For building software features, APIs, CLI tools, applications
|
|
67
|
+
- Phases: research → design → implement → test → review
|
|
68
|
+
- Best for: code changes, new features, bug fixes, refactoring
|
|
69
|
+
|
|
70
|
+
- **research**: For investigations, literature reviews, technical analysis
|
|
71
|
+
- Phases: question → methodology → gather → analyze → synthesize → publish
|
|
72
|
+
- Best for: feasibility studies, market research, technology evaluation
|
|
73
|
+
|
|
74
|
+
### Mission Inference
|
|
75
|
+
|
|
76
|
+
1. **Analyze the feature description** to identify the primary goal:
|
|
77
|
+
- Building, coding, implementing, creating software → **software-dev**
|
|
78
|
+
- Researching, investigating, analyzing, evaluating → **research**
|
|
79
|
+
|
|
80
|
+
2. **Check for explicit mission requests** in the user's description:
|
|
81
|
+
- If user mentions "research project", "investigation", "analysis" → use research
|
|
82
|
+
- If user mentions "build", "implement", "create feature" → use software-dev
|
|
83
|
+
|
|
84
|
+
3. **Confirm with user** (unless explicit):
|
|
85
|
+
> "Based on your description, this sounds like a **[software-dev/research]** project.
|
|
86
|
+
> I'll use the **[mission name]** mission. Does that work for you?"
|
|
87
|
+
|
|
88
|
+
4. **Handle user response**:
|
|
89
|
+
- If confirmed: proceed with selected mission
|
|
90
|
+
- If user wants different mission: use their choice
|
|
91
|
+
|
|
92
|
+
5. **Handle --mission flag**: If the user provides `--mission <key>` in their command, skip inference and use the specified mission directly.
|
|
93
|
+
|
|
94
|
+
Store the final mission selection in your notes and include it in the spec output. Do not pass a `--mission` flag to feature creation.
|
|
95
|
+
|
|
96
|
+
## Workflow (0.11.0+)
|
|
97
|
+
|
|
98
|
+
**Planning happens in main repository - NO worktree created!**
|
|
99
|
+
|
|
100
|
+
1. Creates `kitty-specs/###-feature/spec.md` directly in main repo
|
|
101
|
+
2. Automatically commits to main branch
|
|
102
|
+
3. No worktree created during specify
|
|
103
|
+
|
|
104
|
+
**Worktrees created later**: Use `spec-kitty implement WP##` to create a workspace for each work package. Worktrees are created later during implement (e.g., `.worktrees/###-feature-WP##`).
|
|
105
|
+
|
|
106
|
+
## Location
|
|
107
|
+
|
|
108
|
+
- Work in: **Main repository** (not a worktree)
|
|
109
|
+
- Creates: `kitty-specs/###-feature/spec.md`
|
|
110
|
+
- Commits to: `main` branch
|
|
111
|
+
|
|
112
|
+
## Outline
|
|
113
|
+
|
|
114
|
+
### 0. Generate a Friendly Feature Title
|
|
115
|
+
|
|
116
|
+
- Summarize the agreed intent into a short, descriptive title (aim for ≤7 words; avoid filler like "feature" or "thing").
|
|
117
|
+
- Read that title back during the Intent Summary and revise it if the user requests changes.
|
|
118
|
+
- Use the confirmed title to derive the kebab-case feature slug for the create-feature command.
|
|
119
|
+
|
|
120
|
+
The text the user typed after `/spec-kitty.specify` in the triggering message **is** the initial feature description. Capture it verbatim, but treat it only as a starting point for discovery—not the final truth. Your job is to interrogate the request, surface gaps, and co-create a complete specification with the user.
|
|
121
|
+
|
|
122
|
+
Given that feature description, do this:
|
|
123
|
+
|
|
124
|
+
- **Generation Mode (arguments provided)**: Use the provided text as a starting point, validate it through discovery, and fill gaps with explicit questions or clearly documented assumptions (limit `[NEEDS CLARIFICATION: …]` to at most three critical decisions the user has postponed).
|
|
125
|
+
- **Interactive Interview Mode (no arguments)**: Use the discovery interview to elicit all necessary context, synthesize the working feature description, and confirm it with the user before you generate any specification artifacts.
|
|
126
|
+
|
|
127
|
+
1. **Check discovery status**:
|
|
128
|
+
- If this is your first message or discovery questions remain unanswered, stay in the one-question loop, capture the user's response, update your internal table, and end with `WAITING_FOR_DISCOVERY_INPUT`. Do **not** surface the table; keep it internal. Do **not** call the creation command yet.
|
|
129
|
+
- Only proceed once every discovery question has an explicit answer and the user has acknowledged the Intent Summary.
|
|
130
|
+
- Empty invocation rule: stay in interview mode until you can restate the agreed-upon feature description. Do **not** call the creation command while the description is missing or provisional.
|
|
131
|
+
|
|
132
|
+
2. When discovery is complete and the intent summary, **title**, and **mission** are confirmed, run the feature creation command from repo root:
|
|
133
|
+
|
|
134
|
+
```bash
|
|
135
|
+
spec-kitty agent feature create-feature "<slug>" --json
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
Where `<slug>` is a kebab-case version of the friendly title (e.g., "Checkout Upsell Flow" → "checkout-upsell-flow").
|
|
139
|
+
|
|
140
|
+
The command returns JSON with:
|
|
141
|
+
- `result`: "success" or error message
|
|
142
|
+
- `feature`: Feature number and slug (e.g., "014-checkout-upsell-flow")
|
|
143
|
+
- `feature_dir`: Absolute path to the feature directory inside the main repo
|
|
144
|
+
|
|
145
|
+
Parse these values for use in subsequent steps. All file paths are absolute.
|
|
146
|
+
|
|
147
|
+
**IMPORTANT**: You must only ever run this command once. The JSON is provided in the terminal output - always refer to it to get the actual paths you're looking for.
|
|
148
|
+
3. **Stay in the main repository**: No worktree is created during specify.
|
|
149
|
+
|
|
150
|
+
4. Load the spec template from `.kittify/templates/spec-template.md` (or `templates/spec-template.md`) to understand required sections.
|
|
151
|
+
|
|
152
|
+
5. Create meta.json in the feature directory with:
|
|
153
|
+
```json
|
|
154
|
+
{
|
|
155
|
+
"feature_number": "<number>",
|
|
156
|
+
"slug": "<full-slug>",
|
|
157
|
+
"friendly_name": "<Friendly Title>",
|
|
158
|
+
"mission": "<selected-mission>",
|
|
159
|
+
"source_description": "$ARGUMENTS",
|
|
160
|
+
"created_at": "<ISO timestamp>"
|
|
161
|
+
}
|
|
162
|
+
```
|
|
163
|
+
|
|
164
|
+
6. Generate the specification content by following this flow:
|
|
165
|
+
- Use the discovery answers as your authoritative source of truth (do **not** rely on raw `$ARGUMENTS`)
|
|
166
|
+
- For empty invocations, treat the synthesized interview summary as the canonical feature description
|
|
167
|
+
- Identify: actors, actions, data, constraints, motivations, success metrics
|
|
168
|
+
- For any remaining ambiguity:
|
|
169
|
+
* Ask the user a focused follow-up question immediately and halt work until they answer
|
|
170
|
+
* Only use `[NEEDS CLARIFICATION: …]` when the user explicitly defers the decision
|
|
171
|
+
* Record any interim assumption in the Assumptions section
|
|
172
|
+
* Prioritize clarifications by impact: scope > outcomes > risks/security > user experience > technical details
|
|
173
|
+
- Fill User Scenarios & Testing section (ERROR if no clear user flow can be determined)
|
|
174
|
+
- Generate Functional Requirements (each requirement must be testable)
|
|
175
|
+
- Define Success Criteria (measurable, technology-agnostic outcomes)
|
|
176
|
+
- Identify Key Entities (if data involved)
|
|
177
|
+
|
|
178
|
+
7. Write the specification to `<feature_dir>/spec.md` using the template structure, replacing placeholders with concrete details derived from the feature description while preserving section order and headings.
|
|
179
|
+
|
|
180
|
+
8. **Specification Quality Validation**: After writing the initial spec, validate it against quality criteria:
|
|
181
|
+
|
|
182
|
+
a. **Create Spec Quality Checklist**: Generate a checklist file at `FEATURE_DIR/checklists/requirements.md` using the checklist template structure with these validation items:
|
|
183
|
+
|
|
184
|
+
```markdown
|
|
185
|
+
# Specification Quality Checklist: [FEATURE NAME]
|
|
186
|
+
|
|
187
|
+
**Purpose**: Validate specification completeness and quality before proceeding to planning
|
|
188
|
+
**Created**: [DATE]
|
|
189
|
+
**Feature**: [Link to spec.md]
|
|
190
|
+
|
|
191
|
+
## Content Quality
|
|
192
|
+
|
|
193
|
+
- [ ] No implementation details (languages, frameworks, APIs)
|
|
194
|
+
- [ ] Focused on user value and business needs
|
|
195
|
+
- [ ] Written for non-technical stakeholders
|
|
196
|
+
- [ ] All mandatory sections completed
|
|
197
|
+
|
|
198
|
+
## Requirement Completeness
|
|
199
|
+
|
|
200
|
+
- [ ] No [NEEDS CLARIFICATION] markers remain
|
|
201
|
+
- [ ] Requirements are testable and unambiguous
|
|
202
|
+
- [ ] Success criteria are measurable
|
|
203
|
+
- [ ] Success criteria are technology-agnostic (no implementation details)
|
|
204
|
+
- [ ] All acceptance scenarios are defined
|
|
205
|
+
- [ ] Edge cases are identified
|
|
206
|
+
- [ ] Scope is clearly bounded
|
|
207
|
+
- [ ] Dependencies and assumptions identified
|
|
208
|
+
|
|
209
|
+
## Feature Readiness
|
|
210
|
+
|
|
211
|
+
- [ ] All functional requirements have clear acceptance criteria
|
|
212
|
+
- [ ] User scenarios cover primary flows
|
|
213
|
+
- [ ] Feature meets measurable outcomes defined in Success Criteria
|
|
214
|
+
- [ ] No implementation details leak into specification
|
|
215
|
+
|
|
216
|
+
## Notes
|
|
217
|
+
|
|
218
|
+
- Items marked incomplete require spec updates before `/spec-kitty.clarify` or `/spec-kitty.plan`
|
|
219
|
+
```
|
|
220
|
+
|
|
221
|
+
b. **Run Validation Check**: Review the spec against each checklist item:
|
|
222
|
+
- For each item, determine if it passes or fails
|
|
223
|
+
- Document specific issues found (quote relevant spec sections)
|
|
224
|
+
|
|
225
|
+
c. **Handle Validation Results**:
|
|
226
|
+
|
|
227
|
+
- **If all items pass**: Mark checklist complete and proceed to step 6
|
|
228
|
+
|
|
229
|
+
- **If items fail (excluding [NEEDS CLARIFICATION])**:
|
|
230
|
+
1. List the failing items and specific issues
|
|
231
|
+
2. Update the spec to address each issue
|
|
232
|
+
3. Re-run validation until all items pass (max 3 iterations)
|
|
233
|
+
4. If still failing after 3 iterations, document remaining issues in checklist notes and warn user
|
|
234
|
+
|
|
235
|
+
- **If [NEEDS CLARIFICATION] markers remain**:
|
|
236
|
+
1. Extract all [NEEDS CLARIFICATION: ...] markers from the spec
|
|
237
|
+
2. Re-confirm with the user whether each outstanding decision truly needs to stay unresolved. Do not assume away critical gaps.
|
|
238
|
+
3. For each clarification the user has explicitly deferred, present options using plain text—no tables:
|
|
239
|
+
|
|
240
|
+
```
|
|
241
|
+
Question [N]: [Topic]
|
|
242
|
+
Context: [Quote relevant spec section]
|
|
243
|
+
Need: [Specific question from NEEDS CLARIFICATION marker]
|
|
244
|
+
Options: (A) [First answer — implications] · (B) [Second answer — implications] · (C) [Third answer — implications] · (D) Custom (describe your own answer)
|
|
245
|
+
Reply with a letter or a custom answer.
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
4. Number questions sequentially (Q1, Q2, Q3 - max 3 total)
|
|
249
|
+
5. Present all questions together before waiting for responses
|
|
250
|
+
6. Wait for user to respond with their choices for all questions (e.g., "Q1: A, Q2: Custom - [details], Q3: B")
|
|
251
|
+
7. Update the spec by replacing each [NEEDS CLARIFICATION] marker with the user's selected or provided answer
|
|
252
|
+
9. Re-run validation after all clarifications are resolved
|
|
253
|
+
|
|
254
|
+
d. **Update Checklist**: After each validation iteration, update the checklist file with current pass/fail status
|
|
255
|
+
|
|
256
|
+
9. Report completion with feature directory, spec file path, checklist results, and readiness for the next phase (`/spec-kitty.clarify` or `/spec-kitty.plan`).
|
|
257
|
+
|
|
258
|
+
**NOTE:** The script creates and checks out the new branch and initializes the spec file before writing.
|
|
259
|
+
|
|
260
|
+
## General Guidelines
|
|
261
|
+
|
|
262
|
+
## Quick Guidelines
|
|
263
|
+
|
|
264
|
+
- Focus on **WHAT** users need and **WHY**.
|
|
265
|
+
- Avoid HOW to implement (no tech stack, APIs, code structure).
|
|
266
|
+
- Written for business stakeholders, not developers.
|
|
267
|
+
- DO NOT create any checklists that are embedded in the spec. That will be a separate command.
|
|
268
|
+
|
|
269
|
+
### Section Requirements
|
|
270
|
+
|
|
271
|
+
- **Mandatory sections**: Must be completed for every feature
|
|
272
|
+
- **Optional sections**: Include only when relevant to the feature
|
|
273
|
+
- When a section doesn't apply, remove it entirely (don't leave as "N/A")
|
|
274
|
+
|
|
275
|
+
### For AI Generation
|
|
276
|
+
|
|
277
|
+
When creating this spec from a user prompt:
|
|
278
|
+
|
|
279
|
+
1. **Make informed guesses**: Use context, industry standards, and common patterns to fill gaps
|
|
280
|
+
2. **Document assumptions**: Record reasonable defaults in the Assumptions section
|
|
281
|
+
3. **Limit clarifications**: Maximum 3 [NEEDS CLARIFICATION] markers - use only for critical decisions that:
|
|
282
|
+
- Significantly impact feature scope or user experience
|
|
283
|
+
- Have multiple reasonable interpretations with different implications
|
|
284
|
+
- Lack any reasonable default
|
|
285
|
+
4. **Prioritize clarifications**: scope > security/privacy > user experience > technical details
|
|
286
|
+
5. **Think like a tester**: Every vague requirement should fail the "testable and unambiguous" checklist item
|
|
287
|
+
6. **Common areas needing clarification** (only if no reasonable default exists):
|
|
288
|
+
- Feature scope and boundaries (include/exclude specific use cases)
|
|
289
|
+
- User types and permissions (if multiple conflicting interpretations possible)
|
|
290
|
+
- Security/compliance requirements (when legally/financially significant)
|
|
291
|
+
|
|
292
|
+
**Examples of reasonable defaults** (don't ask about these):
|
|
293
|
+
|
|
294
|
+
- Data retention: Industry-standard practices for the domain
|
|
295
|
+
- Performance targets: Standard web/mobile app expectations unless specified
|
|
296
|
+
- Error handling: User-friendly messages with appropriate fallbacks
|
|
297
|
+
- Authentication method: Standard session-based or OAuth2 for web apps
|
|
298
|
+
- Integration patterns: RESTful APIs unless specified otherwise
|
|
299
|
+
|
|
300
|
+
### Success Criteria Guidelines
|
|
301
|
+
|
|
302
|
+
Success criteria must be:
|
|
303
|
+
|
|
304
|
+
1. **Measurable**: Include specific metrics (time, percentage, count, rate)
|
|
305
|
+
2. **Technology-agnostic**: No mention of frameworks, languages, databases, or tools
|
|
306
|
+
3. **User-focused**: Describe outcomes from user/business perspective, not system internals
|
|
307
|
+
4. **Verifiable**: Can be tested/validated without knowing implementation details
|
|
308
|
+
|
|
309
|
+
**Good examples**:
|
|
310
|
+
|
|
311
|
+
- "Users can complete checkout in under 3 minutes"
|
|
312
|
+
- "System supports 10,000 concurrent users"
|
|
313
|
+
- "95% of searches return results in under 1 second"
|
|
314
|
+
- "Task completion rate improves by 40%"
|
|
315
|
+
|
|
316
|
+
**Bad examples** (implementation-focused):
|
|
317
|
+
|
|
318
|
+
- "API response time is under 200ms" (too technical, use "Users see results instantly")
|
|
319
|
+
- "Database can handle 1000 TPS" (implementation detail, use user-facing metric)
|
|
320
|
+
- "React components render efficiently" (framework-specific)
|
|
321
|
+
- "Redis cache hit rate above 80%" (technology-specific)
|