name: specs-code-cleanup description: "Provides final code cleanup after task review approval. Removes debug logs, temporary comments, dead code, optimizes imports, and improves readability. Use when asked to clean up code, polish, finalize, tidy up, remove technical debt, or prepare code for completion after review. Not for refactoring logic or fixing bugs—focused solely on cosmetic and hygiene cleanup." allowed-tools: Task, Read, Write, Edit, Bash, Grep, Glob, TodoWrite, AskUserQuestion
Code Cleanup
Overview
Performs post-review cosmetic cleanup to make code production-ready. This is the final workflow step after /developer-kit-specs:specs.task-review approval.
Input: docs/specs/[id]/tasks/TASK-XXX.md (reviewed status)
Output: Cleaned code, task marked completed
When to Use
- Use when asked to clean up code, polish, finalize, tidy up, or remove technical debt after review approval.
- Use to prepare code for completion: remove debug logs, dead code, optimize imports, and improve readability.
- Use as the final quality gate in the specification-driven development workflow.
- Not for refactoring logic or fixing bugs — focused solely on cosmetic and hygiene cleanup.
Arguments
| Argument | Required | Description |
|---|---|---|
--lang | No | java, spring, typescript, nestjs, react, python, general |
--task | Yes | Path to task file |
Best Practices
- Clean, not change: Only remove or reorganize — never change functionality
- Preserve behavior: Code must work exactly the same after cleanup
- Use project tools: Prefer
./mvnw spotless:apply,npm run lint:fix,black, etc. - Use TodoWrite: Track progress through all 8 phases
- Stop on failure: If tests fail, stop and report — do not proceed
See references/language-patterns.md for language-specific formatter commands, import ordering, and grep patterns.
Instructions
Phase 1: Task Verification
-
Parse
$ARGUMENTSfor parameters:--lang(optional): Target language/framework--task(required): Task ID or file path--spec(optional): Spec folder path (used with task ID)
Support two formats:
- Format 1 (direct path):
--task=docs/specs/001-feature/tasks/TASK-001.md - Format 2 (spec+task):
--spec=docs/specs/001-feature --task=TASK-001
If Format 2 is used, construct the task file path as:
{spec}/tasks/{task}.md -
Read the task file. Verify:
- Status is
reviewedorimplemented(notcompleted) - Review report
TASK-XXX--review.mdexists and is approved
- Status is
-
If not reviewed → stop and tell user to run
/developer-kit-specs:specs.task-reviewfirst -
Extract task ID, title, and
providesfiles
Phase 2: Identify Files to Clean
- Read
TASK-XXX--review.mdfor files created/modified - Read task
providesfield for file paths - Verify files exist; build cleanup list
- Categorize: source files, test files, config files
Phase 3: Technical Debt Removal
Search files for temporary/debug artifacts with Grep:
console.log,System.out.println,print(,// DEBUG:,// temp,// hack- Resolved
TODO/FIXMEcomments (keep unresolved ones)
Review context for each finding. Remove confirmed debt and document what was removed.
Phase 4: Import Optimization
- Run language-specific import optimizer if available (see references)
- Manually remove unused imports if no tool exists
- Document files changed
Phase 5: Code Readability Improvements
- Run language-specific formatter if available (see references)
- If no formatter: fix indentation, break long lines (>120), fix spacing
- Remove dead code only if obviously safe
- Document changes
Phase 6: Documentation Verification
- Verify class/file headers and public API docs
- Check remaining TODOs are still valid and have context
- Remove or update outdated comments
- Document documentation changes
Phase 7: Final Verification
- Run linters if available
- Run tests if available
- Verify no logic or signature changes were introduced
- If tests fail → stop and report failures
Phase 8: Task Completion
-
Auto-update task status:
- Add a
## Cleanup Summarysection to the task file - Check any remaining boxes in the DoD section
- Hooks automatically update status to
completedand setcompleted_date+cleanup_date
- Add a
-
Append
## Cleanup Summaryto task file with:- Files cleaned
- Changes made
- Verification checklist (linters, tests, no functionality changes)
-
Mark all todos complete
Examples
Spring Boot Cleanup
/developer-kit-specs:specs-code-cleanup --lang=spring --task="docs/specs/001-user-auth/tasks/TASK-001.md"
Actions:
- Verify TASK-001 status is
reviewed - Files:
UserController.java,UserService.java,UserRepository.java - Remove 5
System.out.printlnand 2 resolved TODOs - Run
./mvnw spotless:apply - Run
./mvnw test -q - Mark task
completed
TypeScript Cleanup
/developer-kit-specs:specs-code-cleanup --lang=typescript --task="docs/specs/002-dashboard/tasks/TASK-003.md"
Actions:
- Verify TASK-003 status is
reviewed - Files:
Dashboard.tsx,useDashboard.ts,Dashboard.test.tsx - Remove 8
console.logstatements - Run
npm run lint:fixandnpm run format - Run
npm test - Mark task
completed
Constraints and Warnings
- Never change logic or signatures during cleanup
- Stop immediately and report if tests fail
- Verify behavior is unchanged before marking complete