From formal-verify
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.
npx claudepluginhub petekp/agent-skills --plugin literate-guideThis skill uses the workspace's default tool permissions.
Systematic identification and removal of dead code, redundant implementations, and orphaned artifacts in codebases — particularly those maintained by coding agents with limited context windows.
Guides Next.js Cache Components and Partial Prerendering (PPR) with cacheComponents enabled. Implements 'use cache', cacheLife(), cacheTag(), revalidateTag(), static/dynamic optimization, and cache debugging.
Guides building MCP servers enabling LLMs to interact with external services via tools. Covers best practices, TypeScript/Node (MCP SDK), Python (FastMCP).
Generates original PNG/PDF visual art via design philosophy manifestos for posters, graphics, and static designs on user request.
Systematic identification and removal of dead code, redundant implementations, and orphaned artifacts in codebases — particularly those maintained by coding agents with limited context windows.
Coding agents operate within narrow context windows. When refactoring, they often:
This cruft compounds. Each orphaned artifact misleads the next agent (or human), who wastes context budget reading code that does nothing.
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:
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
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:
references/cruft-patterns.md for detection strategies specific to that trackVerification is critical. Common false positives to watch for:
bin fieldsWhen uncertain, mark as "needs review" rather than "confirmed dead."
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:
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:
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.
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.
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."
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.
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.