Agent skill
dead-code-sweep
This skill should be used when cleaning up codebases that have accumulated dead code, redundant implementations, and orphaned artifacts — especially codebases maintained by coding agents. Triggers on "find dead code", "clean up unused code", "remove redundant code", "prune this codebase", "dead code sweep", "code cleanup", or when a codebase has gone through multiple agent-driven refactors and likely contains overlooked remnants. Systematically identifies cruft, categorizes findings, and removes confirmed dead code with user approval.
Install this agent skill to your Project
npx add-skill https://github.com/petekp/agent-skills/tree/main/skills/dead-code-sweep
Metadata
Additional technical details for this skill
- author
- petekp
- version
- 0.1.0
SKILL.md
Dead Code Sweep
Systematic identification and removal of dead code, redundant implementations, and orphaned artifacts in codebases — particularly those maintained by coding agents with limited context windows.
Why Agent-Maintained Codebases Accumulate Cruft
Coding agents operate within narrow context windows. When refactoring, they often:
- Re-implement functionality without finding and removing the original
- Leave compatibility shims for interfaces that no longer exist
- Abandon helper functions after inlining their logic
- Create new files without deleting the ones they replace
- Duplicate type definitions across module boundaries
- Leave imports for symbols they stopped using mid-refactor
This cruft compounds. Each orphaned artifact misleads the next agent (or human), who wastes context budget reading code that does nothing.
Workflow
Phase 1: Scope and Inventory
Determine the analysis boundary.
If the user provides a scope (directory, file pattern, module), constrain all analysis to that scope.
If no scope is provided, analyze the full codebase. Start by reading the project structure:
- Identify the primary language(s) and framework(s)
- Map entry points (main files, route definitions, exported modules, test runners)
- Note the build system and dependency configuration
- Check for monorepo structure — analyze each package as a unit
Produce a brief inventory:
Language(s): TypeScript, Python
Entry points: src/index.ts, src/cli.ts
Build: esbuild via package.json scripts
Packages: 1 (single package)
Estimated LOC: ~4,200
Phase 2: Detection
Launch parallel sub-agents to scan for different categories of dead code. Read references/cruft-patterns.md for the full catalog of detection patterns.
Organize detection into these parallel tracks:
| Track | What It Finds |
|---|---|
| Orphaned files | Files not imported, required, or referenced by any other file |
| Unused exports | Exported symbols (functions, classes, types, constants) never imported elsewhere |
| Redundant implementations | Multiple functions/classes doing the same thing under different names |
| Stale compatibility code | Shims, adapters, wrappers, and re-exports that bridge interfaces that no longer differ |
| Dead branches | Conditional paths that can never execute (always-true/false guards, unreachable returns) |
| Orphaned tests | Test files testing functions or modules that no longer exist |
| Orphaned dependencies | Packages in dependency manifests not imported anywhere in source |
For each track, the sub-agent should:
- Read
references/cruft-patterns.mdfor detection strategies specific to that track - Search the codebase using Grep and Glob
- Verify each candidate by tracing references — a symbol is only dead if zero live code paths reach it
- Record findings with file path, line range, and evidence
Verification is critical. Common false positives to watch for:
- Symbols used via dynamic dispatch, reflection, or string-based lookups
- Framework-magic exports (e.g., Next.js page components, pytest fixtures, Rails conventions)
- Public API surface intended for external consumers
- Conditional imports behind feature flags or environment checks
- Decorator-registered or plugin-registered handlers
- CLI entry points referenced in package.json
binfields - CSS class names referenced in templates or JSX as dynamic strings
When uncertain, mark as "needs review" rather than "confirmed dead."
Phase 3: Report
Consolidate all findings into a structured report at .claude/dead-code-report.md.
Organize findings by confidence level, then by category:
# Dead Code Sweep Report
**Scope:** [full codebase | specific path]
**Date:** [date]
**Estimated removable lines:** [count]
## Confirmed Dead (high confidence)
### Orphaned Files
- `src/utils/old-parser.ts` — Not imported anywhere. Superseded by `src/parser/index.ts`.
- ...
### Unused Exports
- `formatDate()` in `src/helpers.ts:42-58` — Exported but zero imports across codebase.
- ...
[...other categories...]
## Needs Review (uncertain)
### Possibly Dynamic
- `handleLegacyEvent()` in `src/events.ts:91` — No static imports, but may be registered dynamically.
- ...
For each finding, include:
- File path and line range
- What it is (function, class, file, type, constant, dependency)
- Why it appears dead (no imports, no references, superseded by X)
- Confidence (confirmed / needs review)
Phase 4: Cleanup with Approval
Present the report summary to the user and ask for approval before removing anything.
Use AskUserQuestion to present findings by category:
Found 12 confirmed dead items and 3 needing review.
Confirmed dead by category:
- 3 orphaned files (~280 lines)
- 5 unused exports (~120 lines)
- 2 redundant implementations (~90 lines)
- 2 orphaned dependencies
Which categories should I clean up?
Options: Remove all confirmed / Select categories / Review each item / Skip cleanup
For each approved category:
- Remove the dead code
- Clean up any imports that referenced the removed code
- Remove empty files left after cleanup
- Remove orphaned dependencies from the manifest
- Run the project's lint/typecheck/build commands to verify nothing broke
If any removal causes a build or type error, immediately revert that specific removal and move the item to "needs review."
After cleanup, update the report with what was removed and what was kept.
Detection Principles
Trace from entry points, not from suspects
Start from known entry points and trace what's reachable, rather than starting from a suspect symbol and trying to prove it's used. The reachability approach has fewer false negatives.
Respect the module boundary
A symbol exported from a package's public API may be consumed by external code not visible in this repository. When analyzing libraries or packages with external consumers, only flag internal (non-public-API) dead code as "confirmed." Flag public API dead code as "needs review."
Look for clusters, not just individuals
Agent-generated cruft tends to cluster. When one dead function is found, examine its neighbors — the agent likely abandoned the entire section during a refactor. A dead file often has sibling dead files created in the same commit.
Use git history as a signal
When available, check when suspect code was last meaningfully modified. Code untouched across several refactor commits is more likely dead. Use git log --follow to trace renames and detect superseded files.
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
multi-model-meta-analysis
Synthesize outputs from multiple AI models into a comprehensive, verified assessment. Use when: (1) User pastes feedback/analysis from multiple LLMs (Claude, GPT, Gemini, etc.) about code or a project, (2) User wants to consolidate model outputs into a single reliable document, (3) User needs conflicting model claims resolved against actual source code. This skill verifies model claims against the codebase, resolves contradictions with evidence, and produces a more reliable assessment than any single model.
capture-learning
Analyze recent conversation context and capture learnings to project knowledge files (for project-specific insights) or skills/commands/subagents (for cross-project patterns). Use when the user asks to "capture this learning", "update the docs with this", "remember this for next time", "document this issue", "add this to CLAUDE.md", "save this knowledge", or "update project knowledge". Also triggers after resolving build/setup issues, discovering non-obvious patterns, or completing debugging sessions with valuable insights.
optimize-agent-docs
Build a retrieval-optimized knowledge layer over agent documentation in dotfiles (.claude, .codex, .cursor, .aider). Use when asked to "optimize docs", "improve agent knowledge", "make docs more efficient", or when documentation has accumulated and retrieval feels inefficient. Generates a manifest mapping task-contexts to knowledge chunks, optimizes information density, and creates compiled artifacts for efficient agent consumption.
agent-changelog
Compile an agent-optimized changelog by cross-referencing git history with plans and documentation. Use when asked to "update changelog", "compile history", "document project evolution", or proactively after major milestones, architectural changes, or when stale/deprecated information is detected that could confuse coding agents.
literate-guide
Create a narrative guide to a codebase or feature in the style of Knuth's Literate Programming — code and prose interwoven as a single essay, ordered for human understanding rather than compiler needs. Use when the user asks to 'explain this codebase as a story', 'write a literate guide', 'create a narrative walkthrough', 'tell the story of this code', 'Knuth-style documentation', 'weave a guide for this feature', or when they want deep, readable documentation that treats the program as literature. Also trigger when someone wants a document that a thoughtful reader could follow from start to finish and come away understanding both WHAT the code does and WHY every design choice was made.
autonomous-agent-readiness
Assess a codebase's readiness for autonomous agent development and provide tailored recommendations. Use when asked to evaluate how well a project supports unattended agent execution, assess development practices for agent autonomy, audit infrastructure for agent reliability, or improve a codebase for autonomous agent workflows. Triggers on requests like "assess this project for agent readiness", "how autonomous-ready is this codebase", "evaluate agent infrastructure", or "improve development practices for agents".
Didn't find tool you were looking for?