askill
vulture-dead-code

vulture-dead-codeSafety 95Repository

Vulture and deadcode tools for detecting unused Python code (functions, classes, variables, imports). Use when cleaning up codebases, removing unused code, or enforcing code hygiene in CI. Triggered by: vulture, deadcode, dead code detection, unused code, code cleanup, remove unused.

7 stars
1.2k downloads
Updated 2/15/2026

Package Files

Loading files...
SKILL.md

Vulture and deadcode - Dead Code Detection

Tools for finding unused Python code including functions, classes, variables, imports, and attributes.

When to Use This Skill

Use this skill when...Use another tool instead when...
Detecting unused functions, classes, variablesFinding unused imports only (use ruff --select F401)
Cleaning up dead code in a codebaseChecking type correctness (use basedpyright)
Enforcing code hygiene in CIFormatting code (use ruff format)
Generating whitelists for false positivesRunning general linting (use ruff check)

Overview

Vulture (mature, confidence-based) and deadcode (newer, AST-based) both detect unused code but with different approaches:

FeatureVulturedeadcode
ApproachStatic analysis + confidence scoresAST-based detection
AccuracyConfidence scores (60-100%)High accuracy, fewer false positives
SpeedFastVery fast
ConfigurationWhitelist filesTOML configuration
MaturityMature (2012)Newer (2023+)
Best ForLarge codebases, gradual cleanupNew projects, strict enforcement

Installation

# Install vulture
uv add --dev vulture

# Install deadcode (newer alternative)
uv add --dev deadcode

# Install both for comparison
uv add --dev vulture deadcode

Vulture - Confidence-Based Detection

Basic Usage

# Check entire project
vulture .

# Check specific files/directories
vulture src/ tests/

# Minimum confidence threshold (60-100%)
vulture --min-confidence 80 .

# Exclude patterns
vulture . --exclude "**/migrations/*,**/tests/*"

# Sort by confidence
vulture --sort-by-size .

# Generate whitelist of current issues
vulture . --make-whitelist > vulture_whitelist.py

Configuration (pyproject.toml)

[tool.vulture]
min_confidence = 80
paths = ["src", "tests"]
exclude = [
    "**/migrations/*",
    "**/__pycache__/*",
    ".venv/*"
]
ignore_decorators = [
    "@app.route",
    "@pytest.fixture",
    "@property",
    "@staticmethod",
    "@classmethod"
]
ignore_names = [
    "test_*",
    "setUp*",
    "tearDown*",
]

deadcode - AST-Based Detection

Basic Usage

# Check entire project
deadcode .

# Check specific files/directories
deadcode src/

# Verbose output
deadcode --verbose .

# Dry run (show what would be removed)
deadcode --dry-run .

# Show unreachable code
deadcode --show-unreachable .

# Generate configuration
deadcode --init

Configuration (pyproject.toml)

[tool.deadcode]
paths = ["src"]
exclude = [
    "tests/*",
    "**/__pycache__/*",
    "**/migrations/*",
]
ignore_names = [
    "test_*",
    "setUp",
    "tearDown",
    "main",
]
ignore_decorators = [
    "app.route",
    "pytest.fixture",
    "property",
    "staticmethod",
    "classmethod",
    "abstractmethod"
]
show_unreachable = false

Choosing Between Tools

Choose Vulture when...Choose deadcode when...
Large, mature codebasesNew projects
Need confidence-based filteringWant fewer false positives
Need whitelist file approachPrefer TOML configuration
Dynamic code (getattr, exec)Need unreachable code detection

Hybrid Approach

# Run both for comprehensive detection
vulture --min-confidence 80 .
deadcode .

Agentic Optimizations

ContextCommand
Quick vulture checkvulture --min-confidence 90 .
Quick deadcode checkdeadcode .
Generate whitelistvulture . --make-whitelist > vulture_whitelist.py
CI enforcementvulture --min-confidence 80 . vulture_whitelist.py
Unreachable codedeadcode --show-unreachable .
Combined checkvulture --min-confidence 80 . && deadcode .

Quick Reference

Vulture Flags

FlagDescription
--min-confidence NMinimum confidence (60-100%)
--exclude PATTERNExclude glob patterns
--sort-by-sizeSort results by size
--make-whitelistGenerate whitelist file

deadcode Flags

FlagDescription
--verboseVerbose output
--dry-runShow without modifying
--show-unreachableDetect unreachable code
--initGenerate configuration
--strictStrict enforcement mode

For detailed examples, advanced patterns, and best practices, see REFERENCE.md.

Install

Download ZIP
Requires askill CLI v1.0+

AI Quality Score

95/100Analyzed 2/15/2026

Metadata

Licenseunknown
Version-
Updated2/15/2026
Publisherlaurigates

Tags

ci-cdlintingtesting