Skip to main content

🫰 Thanos - Eliminate files with a snap. Perfectly balanced, as all things should be.

Project description

🫰 Thanos

"Perfectly balanced, as all things should be."

A glove

A Python CLI tool that randomly eliminates a configurable percentage of files in a directory with a snap (default: 50%). Inspired by Marvel's Thanos and his infamous snap.

Test Python application Python 3.9+ Coverage Status License: MIT

⚠️ Warning

This tool permanently deletes files! Use --dry-run first to preview what would be deleted. Deleted files cannot be recovered. Use at your own risk!

✨ Features

  • 🗑️ Trash Mode: Optionally move files to the system trash/recycle bin instead of permanent deletion.
  • ⚖️ Weighted Selection: Configure probabilities based on file age, size, or extension.
  • 🛡️ Smart Protections: Automatically protects .git, node_modules, venv, and system files.
  • 🚫 Custom Ignore: Support for .thanosignore using gitignore syntax.
  • 🎲 Reproducibility: Use seeds to ensure the exact same files are selected every time.
  • 📁 Recursive Support: Optionally include files in subdirectories.

📦 Installation

Using uv (recommended)

uv add thanos-cli
uv pip install thanos-cli   # <- if you don't have pyproject.toml

Using pipx (recommended for CLI use)

pipx install thanos-cli

Installs thanos as an isolated CLI tool available system-wide without polluting your global Python environment.

Using pip

pip install thanos-cli

🚀 Quick Start

1. Initialize Configuration

Create default .thanosignore and .thanosrc.json files in your project:

thanos init

2. Preview the Snap

Always start with a dry run to see the "dead" files without deleting them:

thanos snap --dry-run

3. Execute

When you are ready to restore balance:

# Permanent deletion (Standard Snap)
thanos snap

# Safer Snap (Move to Trash)
thanos snap --trash

⚙️ Configuration

Thanos supports advanced configuration to control the chaos.

.thanosignore

Protect specific files or folders from being snapped (gitignore syntax):

# Protect specific folders
src/
important_docs/
!debug.log

.thanosrc.json

Define weights (0.0 to 1.0) to make specific files more or less likely to be eliminated.

  • 0.0: Never eliminate
  • 0.5: Neutral (Default)
  • 1.0: Always eliminate

Supported weight types:

  • by_extension — e.g., target .tmp or .log files
  • by_age_days — e.g., target files older than 30+ days
  • by_size_mb — e.g., target files larger than 100+ MB

See docs/configuration.md for the full schema.

📖 Commands

The CLI structure:

  • thanos init — Generate configuration files.
  • thanos snap [DIRECTORY] [OPTIONS] — Main command to eliminate files.

Options:

  • -t, --trash — Move files to system trash instead of permanent deletion.
  • -r, --recursive — Include subdirectories
  • -d, --dry-run — Preview without deleting
  • -p, --percent <INT> — Percentage of files to eliminate (default: 50, range: 1–100)
  • --seed <INT> — Set seed for reproducibility
  • --no-protect — Disable protections (dangerous)

For detailed usage, see docs/usage.md.

📝 License

This project is licensed under the MIT License - see the LICENSE file for details.

🤔 FAQ

Q: Can I recover deleted files? A: If you use the --trash flag, YES, you can restore them from your system's Recycle Bin/Trash. If you run the standard command without that flag, files are permanently deleted.

Q: How are files selected? A: Randomly, but you can bias the selection using weights in .thanosrc.json.

Q: What is protected by default? A: .git, .svn, node_modules, venv, __pycache__, .env, and more.

Q: What if I have an odd number of files? A: The count is calculated as int(total * percent / 100), so with 11 files at the default 50%, 5 will be deleted and 6 will remain. Use --percent to adjust.

🙏 Acknowledgments

  • Inspired by the Marvel Cinematic Universe

Remember: With great power comes great responsibility. Use Thanos wisely! 🫰

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

thanos_cli-0.4.1.tar.gz (95.3 kB view details)

Uploaded Source

Built Distribution

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

thanos_cli-0.4.1-py3-none-any.whl (14.5 kB view details)

Uploaded Python 3

File details

Details for the file thanos_cli-0.4.1.tar.gz.

File metadata

  • Download URL: thanos_cli-0.4.1.tar.gz
  • Upload date:
  • Size: 95.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.17

File hashes

Hashes for thanos_cli-0.4.1.tar.gz
Algorithm Hash digest
SHA256 5bfd2623768c7f1cd62132a6d354b0174b700a881583bec0e5ce7cb94140b2d1
MD5 92c65c700ea7cad3e0f7ec680d3c2d67
BLAKE2b-256 b87146149c9675c8f18f22fc157bb3abb683d98a2a78d5287f56df53300d8a8e

See more details on using hashes here.

File details

Details for the file thanos_cli-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: thanos_cli-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 14.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.17

File hashes

Hashes for thanos_cli-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 46f30f50291d6eae15cc9a922c2b9802f30b9ac06e3c2ddec46d19cf08b1a928
MD5 fb8fdbe624b12c11116c6ee473303232
BLAKE2b-256 a813242fc4f87258b1d42362b405768921dbc50edb7cdaf0f74036dee97306fd

See more details on using hashes here.

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