Generate a feature technical specification document for the feature $1.
Directory Guard
- •
If
START_PROMPTS.mdorGENERATOR_PROMPT.mdexists in the current working directory → STOP: "You're in the toolkit repo. Feature skills run from your project directory. Run:cd ~/Projects/your-project && /feature-technical-spec $1" - •
Check
.claude/toolkit-version.jsonexists in the current working directory (confirms/setupwas run). If missing → STOP: "Toolkit not installed. Run/setupfrom the toolkit first." - •
Check
AGENTS.mdexists in the current working directory (confirms project root). If missing → STOP: "Run this from your project root (where AGENTS.md lives)."
Arguments
- •
$1= feature name (e.g.,analytics,dark-mode) - •If
$1is empty, ask the user for the feature name - •
PROJECT_ROOT= current working directory - •
FEATURE_DIR=PROJECT_ROOT/features/$1
Prerequisites
- •Check that
FEATURE_DIR/FEATURE_SPEC.mdexists. If not: "FEATURE_SPEC.md not found at features/$1/. Run/feature-spec $1first." - •Check that
PROJECT_ROOT/AGENTS.mdexists (indicates an existing project). If not, warn: "AGENTS.md not found. Feature development assumes an existing project. Did you mean to run/product-specfor a new project?"
Existing File Guard (Prevent Overwrite)
Before asking any questions, check whether FEATURE_DIR/FEATURE_TECHNICAL_SPEC.md already exists.
- •If it does not exist: continue normally.
- •If it exists: STOP and ask the user what to do:
- •Backup then overwrite (recommended): read the existing file and write it to
FEATURE_DIR/FEATURE_TECHNICAL_SPEC.md.bak.YYYYMMDD-HHMMSS, then write the new document toFEATURE_DIR/FEATURE_TECHNICAL_SPEC.md - •Overwrite: replace
FEATURE_DIR/FEATURE_TECHNICAL_SPEC.mdwith the new document - •Abort: do not write anything; suggest they rename/move the existing file first
- •Backup then overwrite (recommended): read the existing file and write it to
Process
Read .claude/skills/feature-technical-spec/PROMPT.md and follow its instructions exactly:
- •
Read
FEATURE_DIR/FEATURE_SPEC.mdas input - •
Perform Existing Code Analysis (REQUIRED before any design):
Note: All code analysis should be performed on PROJECT_ROOT (current working directory).
a. Similar Functionality Audit
- •Search for existing code that does something similar to what the feature needs
- •List any utilities, helpers, or patterns that could be reused
- •Flag if creating new code when existing code could be extended
- •Output:
code
SIMILAR FUNCTIONALITY FOUND --------------------------- - {file}: {description of similar functionality} - {file}: {reusable utility/helper} Recommendation: {extend existing | create new | hybrid approach}
b. Pattern Compliance Check
- •Identify how similar features are implemented in the codebase
- •Note naming conventions, file organization, error handling patterns
- •Document the "house style" for this type of feature
- •Output:
code
EXISTING PATTERNS ----------------- File organization: {pattern} Naming convention: {pattern} Error handling: {pattern} Testing approach: {pattern}
c. Integration Point Mapping
- •List every existing file/module the feature will touch
- •For each, assess: complexity, test coverage, documentation quality
- •Flag high-risk integration points
- •Output:
code
INTEGRATION POINTS ------------------ | File | Risk | Coverage | Notes | |------|------|----------|-------| | {file} | High/Med/Low | X% | {concerns} |
- •
Assess codebase maturity — Is this a legacy/brownfield codebase?
- •Look for: outdated dependencies, missing tests, undocumented code, deprecated patterns
- •If legacy indicators found, explicitly address technical debt, undocumented behavior, and human decision points
- •
Work through integration analysis, regression risks, and migration strategy
- •
Generate the final FEATURE_TECHNICAL_SPEC.md document, incorporating findings from step 2
Output
Write the completed specification to FEATURE_DIR/FEATURE_TECHNICAL_SPEC.md.
Verification (Automatic)
After writing FEATURE_TECHNICAL_SPEC.md, run the spec-verification workflow:
- •Read
.claude/skills/spec-verification/SKILL.mdfor the verification process - •Verify context preservation: Check that all key items from FEATURE_SPEC.md appear in FEATURE_TECHNICAL_SPEC.md
- •Run quality checks for vague language, missing rationale, undefined contracts, integration gaps
- •Present any CRITICAL issues to the user with resolution options
- •Apply fixes based on user choices
- •Re-verify until clean or max iterations reached
IMPORTANT: Do not proceed to "Next Step" until verification passes or user explicitly chooses to proceed with noted issues.
Deferred Requirements Capture (During Q&A)
IMPORTANT: Capture deferred requirements interactively during the Q&A process, not after.
Write deferred items to PROJECT_ROOT/DEFERRED.md (not the feature directory).
When to Trigger
During the Q&A, watch for signals that the user is deferring a technical decision:
- •"out of scope"
- •"not in this feature" / "separate feature"
- •"v2" / "future version"
- •"premature optimization"
- •"technical debt we'll address later"
- •"keep it simple for now"
- •"follow-up" / "future enhancement"
Capture Flow
When you detect a deferral signal, immediately use AskUserQuestion:
Question: "Would you like to save this to your deferred requirements?" Header: "Defer?" Options: - "Yes, capture it" — I'll ask a few quick questions to document it - "No, skip" — Don't record this
If user selects "Yes, capture it":
Ask these clarifying questions:
- •
What's being deferred? "In one sentence, what's the technical decision or feature?" (Pre-fill with your understanding from context)
- •
Why defer it? Options: "Premature optimization" / "Out of scope" / "Separate feature" / "V2" / "Needs more research" / "Other"
- •
Notes for later? "Any technical context that will help when revisiting this?" (Optional — user can skip)
Write to DEFERRED.md Immediately
After collecting answers, append to PROJECT_ROOT/DEFERRED.md right away.
Add new section or append to existing feature section:
## From FEATURE_TECHNICAL_SPEC.md: {FEATURE_NAME} ({date})
| Requirement | Reason | Notes |
|-------------|--------|-------|
| {user's answer} | {selected reason} | {notes or "—"} |
Continue Q&A
After capturing (or skipping), continue the spec Q&A where you left off.
Cross-Model Review (Automatic)
After verification passes, run cross-model review if Codex CLI is available:
- •Check if Codex CLI is installed:
codex --version - •If available, run
/codex-consultwith upstream context - •Present any findings to the user before proceeding
Consultation invocation:
/codex-consult --upstream features/$1/FEATURE_SPEC.md --research "{detected technologies from codebase}" features/$1/FEATURE_TECHNICAL_SPEC.md
If Codex finds issues:
- •Show critical issues and recommendations
- •Ask user: "Address findings before proceeding?" (Yes/No)
- •If Yes: Apply suggested fixes
- •If No: Continue with noted issues
If Codex unavailable: Skip silently and proceed to Next Step.
Next Step
When verification is complete, inform the user:
FEATURE_TECHNICAL_SPEC.md created and verified at features/$1/FEATURE_TECHNICAL_SPEC.md
Verification: PASSED | PASSED WITH NOTES | NEEDS REVIEW
Cross-Model Review: PASSED | PASSED WITH NOTES | SKIPPED
Deferred Requirements: {count} items captured to DEFERRED.md
Next: Run /feature-plan $1