skills/code-cleanup/SKILL.md
Detect stale TODOs, unused imports, and dead code.
npx skillsauth add notque/claude-code-toolkit code-cleanupInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Scan repositories for 9 categories of technical debt (TODOs, unused imports, dead code, missing type hints, deprecated functions, naming inconsistencies, high complexity, duplicate code, missing docstrings), prioritize findings by impact/effort ratio with time estimates, and generate structured markdown reports with exact file:line references. Can apply safe auto-fixes when the user grants explicit permission.
Focused cleanup -- User says "Clean up the API handlers in src/api/". Read project config, scan src/api/ for all 9 categories, prioritize (5 unused imports auto-fixable, 2 stale TODOs >90d, 1 high-complexity function), present tiered report with auto-fix commands.
Broad debt scan -- User says "What's the state of technical debt in this repo?". Identify languages and source directories, run all applicable scans, group 47 findings into Quick Wins (12), Important (8), Polish (27), generate full report with effort estimates: 2h quick wins, 6h important, 4h polish.
Auto-fix request -- User says "Fix all the unused imports and sort them". Verify ruff/goimports available, scan for F401 and I001 violations only, report 23 unused imports across 8 files, user confirms, apply fixes, run tests, show diff.
| Signal | Load These Files | Why |
|---|---|---|
| tasks related to this reference | report-template.md | Loads detailed guidance from report-template.md. |
| tasks related to this reference | scan-commands.md | Loads detailed guidance from scan-commands.md. |
| tasks related to this reference | tools.md | Loads detailed guidance from tools.md. |
Goal: Determine what to scan and verify tooling is available.
Step 1: Read project context
Step 2: Determine scan scope
Step 3: Verify tool availability
Check which analysis tools are installed so you know what scans are possible before starting. Report missing tools with install commands.
# Python tools
command -v ruff && echo "ruff: available" || echo "ruff: MISSING (pip install ruff)"
command -v vulture && echo "vulture: available" || echo "vulture: MISSING (pip install vulture)"
# Go tools
command -v gocyclo && echo "gocyclo: available" || echo "gocyclo: MISSING (go install github.com/fzipp/gocyclo/cmd/gocyclo@latest)"
command -v goimports && echo "goimports: available" || echo "goimports: MISSING (go install golang.org/x/tools/cmd/goimports@latest)"
If critical tools are missing, offer to proceed with partial scan using available tools (grep, git blame are always available).
Gate: Scope defined, languages identified, tool availability known. Proceed only when gate passes.
Goal: Detect all cleanup opportunities within scope using deterministic tools.
Run applicable scans based on language and scope. See references/scan-commands.md for full command reference.
Core scans (all languages):
Extended scans (if tools available): 5. Missing type hints (Python: ruff --select ANN) 6. Deprecated function usage (staticcheck, grep for known patterns) 7. Naming inconsistencies (grep for convention violations) 8. Duplicate code (pylint --enable=duplicate-code) 9. Missing docstrings (ruff --select D)
Collect all output with exact file:line references -- never summarize away specifics, because the user needs precise locations to act on findings. For each scan, record:
If a scan tool is unavailable, note it as skipped and continue with remaining scans. Never abort the entire scan because one tool is missing.
Gate: All applicable scans complete with raw output collected. Proceed only when gate passes.
Goal: Rank findings by impact/effort ratio and categorize. Never present a flat unsorted list -- a critical 90-day-old security TODO buried among trivial missing docstrings wastes the user's attention.
Step 1: Assign impact and effort
| Issue Type | Impact | Effort | Priority Score | |------------|--------|--------|----------------| | Stale TODOs (>90 days) | High | Low | 8 | | Unused imports | Medium | Trivial | 10 | | Deprecated functions | High | Medium | 6 | | High complexity (>20) | High | High | 5 | | Dead code | Medium | Low | 7 | | Missing type hints | Medium | Medium | 5 | | Duplicate code | High | High | 5 | | Missing docstrings | Medium | Medium | 5 | | Naming inconsistencies | Low | Medium | 3 | | Magic numbers | Low | Low | 5 |
Step 2: Group into tiers
Step 3: Estimate total effort per tier
Include time estimates so the user can plan their cleanup budget:
| Issue Type | Time per Instance | |------------|-------------------| | Unused imports | 1-2 min (auto-fix) | | Stale TODOs | 5-15 min each | | Dead code removal | 5-10 min each | | Magic numbers | 2-5 min each | | Missing type hints | 10-20 min per function | | Missing docstrings | 5-15 min per function | | Naming fixes | 10-30 min per violation | | High complexity refactor | 30-120 min per function | | Duplicate code elimination | 30-90 min per instance | | Deprecated function replacement | 15-60 min per usage |
Multiply by instance count for tier totals.
Gate: All findings categorized and prioritized with effort estimates. Proceed only when gate passes.
Goal: Present findings in structured, actionable format.
This skill defaults to read-only scan and report. Do not modify any files during this phase.
Generate report with this structure:
See references/report-template.md for complete template.
Print the complete report to stdout so the user can inspect every finding in full.
If the user provided --output {file} flag, also write report to the specified file.
For each finding in the report:
Remove any intermediate scan outputs at completion, keeping only the final report.
Gate: Report delivered with all findings, exact references, and actionable suggestions.
Goal: Apply safe, deterministic fixes.
MUST have explicit user permission before proceeding. Never auto-enter this phase -- the user expected a report, not file modifications, and changes may conflict with in-progress work.
Step 1: Confirm scope with user
Before applying any fixes, confirm exactly what will be changed:
Will apply these auto-fixes:
- Remove {N} unused imports across {N} files
- Sort imports in {N} files
- Format {N} files
{N} files will be modified. Proceed? (y/n)
Step 2: Apply auto-fixes
Apply fixes in order of safety (most safe first):
# Python - safe fixes only
ruff check . --select F401,I001 --fix # Remove unused imports, sort
ruff format . # Consistent formatting
# Go - safe fixes only
goimports -w . # Remove unused imports, sort, format
gofmt -w . # Consistent formatting
go mod tidy # Clean up go.mod/go.sum
Apply only fixes flagged as safe by ruff in this phase. Keep variable names, function structure, and semantic behavior unchanged.
Step 3: Validate fixes
Run the project's existing test suite to verify nothing broke:
# Python
pytest # Run full test suite
ruff check . # Verify no new lint issues
# Go
go test ./... # Run full test suite
go build ./... # Verify build succeeds
golangci-lint run # Verify no new lint issues
Step 4: Show diff and results
git diff --stat # Summary of changes
git diff # Full diff for review
Present results:
## Fix Results
- Files modified: {N}
- Imports removed: {N}
- Tests: PASS ({N} tests)
- Lint: CLEAN
Review diff above. Commit when satisfied.
Step 5: Handle failures
If tests fail after auto-fix:
git checkout .Keep the repository in a working state after the cleanup pass.
Gate: All auto-fixes applied, tests pass, diff shown to user. Repository is in a clean, working state.
Cause: ruff, vulture, gocyclo, or other tool not installed Solution:
Cause: Cannot use git blame for TODO aging Solution: Continue scan but mark all TODO ages as "unknown". Warn user that age-based triage is unavailable.
Cause: Auto-fix changed behavior that tests depend on Solution:
git checkout .Cause: Files are read-only, locked, or user did not grant write permission Solution:
${CLAUDE_SKILL_DIR}/references/scan-commands.md: Language-specific scan commands and expected output${CLAUDE_SKILL_DIR}/references/report-template.md: Full structured report template${CLAUDE_SKILL_DIR}/references/tools.md: Tool installation, versions, and capabilitiesdocumentation
Document translation: quick/normal/refined modes with chunked parallel subagents and glossary support.
development
AI image generation: Gemini and Nano Banana backends; single/series/batch workflows with prompt-to-disk.
testing
Unified voice content generation pipeline with mandatory validation and joy-check. 13-phase pipeline: LOAD, GROUND, STATS-CHECKPOINT, GENERATE, HOOK-GATE, VALIDATE, REFINE, VARIETY-GATE, JOY-CHECK, ANTI-AI, CLOSE-GATE, OUTPUT, CLEANUP. Use when writing articles, blog posts, or any content that uses a voice profile. Use for "write article", "blog post", "write in voice", "generate content", "draft article", "write about".
documentation
Critique-and-rewrite loop for voice fidelity validation.