Skip to main content

CLI tools for cleaning artifacts and builds

Project description

Artifact-Scythe

Reclaim disk space by harvesting the build artifacts you forgot about.

CI PyPI version Python versions License: MIT

Artifact-Scythe

Demo

MP4 version

scythe is a Python CLI that walks your projects directory, identifies each project's ecosystem (Node, Python, Rust, Java, Go, Ruby, .NET) from its marker files, and locates the bulky build artifacts that ecosystem leaves behind — node_modules, .venv, __pycache__, target/, build/, and the rest. It reports how much space each one is wasting and, when you tell it to, deletes them.

It is safe by default: every clean previews what is about to happen and asks for confirmation, and a --dry-run mode lets you check the plan before running for real.

Why

A laptop used daily for a year typically holds 30–80 GB of stale node_modules, abandoned virtualenvs, cached compiler output, and CI scratch directories. None of it is load-bearing — but finding and removing it by hand across dozens of project folders is tedious and error-prone. scythe does it in two commands.

Quick start

pipx install artifact-scythe          # one-line global install

scythe scan ~/projects                # see what's eating your disk
scythe clean ~/projects --dry-run     # preview the deletions
scythe clean ~/projects               # do it (with confirmation)

Install

With pipx (recommended)

pipx installs scythe into its own isolated virtual environment and exposes the scythe command globally on your PATH. It's the right tool for Python CLIs: no clash with your project deps, no sudo, one command to upgrade.

pipx install artifact-scythe          # install
pipx upgrade artifact-scythe          # update later
pipx uninstall artifact-scythe        # remove cleanly

Don't have pipx yet? python -m pip install --user pipx && python -m pipx ensurepath (restart your shell once).

With pip

If you don't want the isolated install, plain pip works too:

pip install --user artifact-scythe    # user-level install

Naming note

The PyPI distribution is artifact-scythe (the scythe slot on PyPI was taken), but the installed command and the Python module are both scythe. Scripts written against scythe ... keep working unchanged.

With Docker

If you'd rather not install anything locally (CI agents, throwaway VMs, or just trying it out), the official image is published on GHCR for both linux/amd64 and linux/arm64:

# scan the current directory
docker run --rm -v "$PWD":/work ghcr.io/elielmengue/scythe:latest scan /work

# clean with a dry-run
docker run --rm -v "$PWD":/work ghcr.io/elielmengue/scythe:latest \
    clean /work --dry-run

Tags follow the PyPI release: :latest, :0.5.3, :0.5, :0. The rolling :edge tag tracks main.

From source

git clone https://github.com/elielMengue/scythe.git
cd scythe
pip install -e ".[dev]"

Usage

scythe scan — discover projects and measure artifacts

scythe scan .                                  # current directory
scythe scan ~/dev --depth 2                    # bound recursion depth
scythe scan ~/dev --only node,python           # filter by ecosystem
scythe scan ~/dev --older-than 30              # only artifacts older than 30 days
scythe scan ~/dev --min-size 500MB             # only artifacts at or above 500 MB
scythe scan ~/dev --format tree                # table | tree | compact | json
scythe scan ~/dev --format json -o report.json # also csv via .csv suffix

scan is read-only. It produces a report; nothing is deleted.

scythe clean — delete detected artifacts

scythe clean ~/dev --dry-run                   # simulate (always do this first)
scythe clean ~/dev --interactive               # pick projects manually
scythe clean ~/dev --only rust                 # only Rust target/ directories
scythe clean ~/dev --older-than 30 --dry-run   # only target stale artifacts
scythe clean ~/dev --min-size 1GB --dry-run    # only large artifacts worth deleting
scythe clean ~/dev --force                     # skip the confirmation prompt
scythe clean ~/dev -o run-report.json          # export a JSON report

clean runs the same scan first, prints a summary, then either prompts before deleting or executes immediately depending on flags. Deletion is permanent — files are not moved to the trash.

scythe info

Prints the installed version and the list of supported ecosystems and patterns.

Supported ecosystems

Ecosystem Marker files Artifact patterns
Node.js package.json, yarn.lock, pnpm-lock.yaml node_modules, dist, build, .next, .nuxt, out, .cache, .parcel-cache, .turbo, coverage
Python requirements.txt, setup.py, pyproject.toml, Pipfile, poetry.lock .venv, venv, env, __pycache__, .pytest_cache, .mypy_cache, .ruff_cache, .tox, *.egg-info, dist, build, .eggs, htmlcov
Rust Cargo.toml, Cargo.lock target
Java (Maven) pom.xml target, .m2/repository
Java (Gradle) build.gradle, build.gradle.kts, settings.gradle build, .gradle, out
Go go.mod, go.sum bin, pkg, vendor
Ruby Gemfile, Gemfile.lock, .ruby-version vendor/bundle, .bundle, tmp
.NET *.csproj, *.fsproj, *.vbproj, *.sln bin, obj, packages, .vs

The --only flag accepts both canonical names (node, python, java_maven, java_gradle, dotnet, ...) and short aliases (py, js, rs, golang, .net, cs).

Safety

  • clean deletes via shutil.rmtree / Path.unlink — files are gone, not in the trash bin. Run --dry-run first when in doubt.
  • Source-control dirs (.git, .svn, .hg, .bzr), editor metadata (.idea, .vscode), and OS metadata (.DS_Store, Thumbs.db) are skipped during traversal.
  • Symlinks are not followed unless --follow-symlinks is passed.
  • Use --depth N on very large filesystems to avoid runaway scans.

Development

Python 3.10+ is required.

git clone https://github.com/elielMengue/scythe.git
cd scythe
pip install -e ".[dev]"

pytest -v                       # full test suite
pytest --cov=scythe             # with coverage
pytest tests/test_scanner.py    # a single file

CI runs the test suite on Linux, macOS, and Windows for Python 3.10, 3.11, and 3.12. See .github/workflows/ci.yml.

Contributing

Issues and pull requests are welcome.

To add support for a new ecosystem, extend two places:

Then add a fixture and an assertion in tests/test_detector.py that exercises the new pattern. Keeping these two maps in sync is the core invariant of the codebase.

Roadmap

  • Configuration & foundations
  • Directory scanner
  • Artifact detection
  • Rich-based UI (table / tree / compact / JSON)
  • Cleaning engine (--dry-run, --interactive, --force, JSON report)
  • Advanced features — in progress (--only, --older-than, --min-size shipped; planned: --ignore, trash-mode)
  • Comprehensive tests & validation
  • Broader distribution (Homebrew tap, Scoop)

See CHANGELOG.md for the release history.

License

MIT © Eliel MENGUE

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

artifact_scythe-0.5.3.tar.gz (26.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

artifact_scythe-0.5.3-py3-none-any.whl (26.2 kB view details)

Uploaded Python 3

File details

Details for the file artifact_scythe-0.5.3.tar.gz.

File metadata

  • Download URL: artifact_scythe-0.5.3.tar.gz
  • Upload date:
  • Size: 26.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for artifact_scythe-0.5.3.tar.gz
Algorithm Hash digest
SHA256 c39420c3873adadd18846b863904eb581ffec34f3a8e4f0df9260a3e93784894
MD5 d0dff7c4fe1d50ee5a720f488a2c9bfb
BLAKE2b-256 198180a3023d50ee504d9dfeb58d82e857de384ef4b3db292e0c0c955242ad9a

See more details on using hashes here.

Provenance

The following attestation bundles were made for artifact_scythe-0.5.3.tar.gz:

Publisher: release.yml on elielMengue/scythe

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file artifact_scythe-0.5.3-py3-none-any.whl.

File metadata

File hashes

Hashes for artifact_scythe-0.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 dd009048d9a1936e7b580e719437a2f8a9e47f22618eff62dd9357744892d32e
MD5 449327a6188c529cec14e3ce91a25b61
BLAKE2b-256 94f1734e4b54e31e214dca17b949e164185df48415f834810a799855793e6b54

See more details on using hashes here.

Provenance

The following attestation bundles were made for artifact_scythe-0.5.3-py3-none-any.whl:

Publisher: release.yml on elielMengue/scythe

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page