Feature Closer
Primary Directive
Close and archive a completed feature, moving it from active backlog to completed.
Input
Feature identifier: ${input:FeatureID (e.g., 003 or 003-my-feature)}
Step 1: Resolve Feature
Determine the feature to close:
- •If input provided, use it to find the feature folder
- •If no input, try to detect from current branch name (
feature/{NNN}-{slug})
# List active features in backlog (not in completed/) ls -d backlog/plans/[0-9][0-9][0-9]-*/ 2>/dev/null | head -20
# Get current branch git branch --show-current
Match the feature ID (NNN or NNN-slug) to a folder in backlog/plans/.
If no matching feature found: Report error and stop.
Step 2: Validate Completion
Read the feature's tasks.md and check for incomplete tasks.
# Check for unchecked tasks (- [ ] pattern)
grep -c '^\s*- \[ \]' backlog/plans/{NNN}-{slug}/tasks.md 2>/dev/null || echo "0"
If incomplete tasks exist: Use the AskUserQuestion tool to ask the user how to proceed:
- •"Close anyway (mark as incomplete)"
- •"Cancel and finish tasks first"
Only proceed if user chooses to close anyway or all tasks are complete.
Step 3: Move Feature Folder
# Ensure completed/features directory exists
mkdir -p backlog/plans/_completed
# Move the feature folder
mv backlog/plans/{NNN}-{slug} backlog/plans/_completed/
Step 4: Update Documentation References
Search for and update any references to the old path in documentation files.
4a: Find References
# Find files referencing the old backlog path (excluding completed/ and .ai/ logs)
grep -rl "backlog/plans/{NNN}-{slug}" . --include="*.md" 2>/dev/null | grep -v -e "^./backlog/plans/_completed/" -e "^./.ai/"
4b: Update References
For each file found, update paths from:
- •
backlog/plans/{NNN}-{slug}/→backlog/plans/_completed/{NNN}-{slug}/ - •
../backlog/plans/{NNN}-{slug}/→../backlog/plans/_completed/{NNN}-{slug}/
Common files to check:
- •
.claude/commands/planner.md(Reference section examples) - •
aidocs/feature-planning-methodology.md - •Any README files referencing the feature
Important: Do NOT update paths in:
- •
specs/tests/(spec tests stay in place) - •
.ai/(progress logs are historical records) - •The feature's own docs (they moved, so relative paths may still work)
Step 5: Commit Changes
Stage and commit all changes from the move and path updates.
# Stage the move and any updated docs
git add -A
# Commit with descriptive message
git commit -m "chore: close feature {NNN}-{slug}
- Move backlog/plans/{NNN}-{slug}/ to backlog/plans/_completed/
- Update documentation references"
Step 6: Summary
Output a summary:
Feature Closed: {NNN}-{slug}
Actions Taken:
✅ Moved backlog/plans/{NNN}-{slug}/ → backlog/plans/_completed/{NNN}-{slug}/
✅ Updated N documentation references
✅ Committed changes
Spec Tests: specs/tests/{NNN}-{slug}.md (unchanged)
Next Steps:
1. Review the commit: git show HEAD
2. Merge to master when ready: git checkout master && git merge feature/{NNN}-{slug}
3. Delete feature branch after merge: git branch -d feature/{NNN}-{slug}
Error Handling
- •Feature not found: List available features and ask user to specify
- •Already in completed/: Report that feature is already closed
- •Git dirty state: Warn user about uncommitted changes before proceeding
- •Move fails: Report error, do not proceed with doc updates