Skip to main content

Smart multi-platform cleanup tool (macOS, Windows, Linux) - auto-cleans unused files, caches, apps, installers, and project build bloat

Project description

jhadoo

Auto-clean unused development environments, installers, cache files, and remnants. Built to run natively across macOS, Windows, and Linux.

PyPI version Total Downloads License: MIT

AI-assisted coding tools (like Cursor, Copilot, Bolt, or Windsurf) make prototyping incredibly fast, but they leave behind a massive footprint of heavyweight folders (venv, node_modules, build caches) for every small experiment. A few weeks of coding can silently eat 20 to 50 GB of disk space.

Jhadoo is a lightweight, cross-platform terminal utility that scans and purges stale workspace environments, package caches, local installers, and leftover app configurations. It helps maintain a fast, continuous vibe coding workflow without manual filesystem housekeeping.

Quick Start (Select Your OS)

macOS & Linux

pipx install jhadoo && jhadoo --dry-run

Windows (PowerShell)

pipx install jhadoo; jhadoo --dry-run

Supported Operating Systems

Jhadoo provides native, equal-parity integration across:

  • macOS: Scans app bundles, cleans CocoaPods/Homebrew caches, and supports macOS system paths.
  • Windows: Queries registry uninstall entries, purges %TEMP%, and includes fallback support for Windows console contexts.
  • Linux: Integrates with package managers (apt, dnf, pacman) and cleans up user configurations (~/.config, ~/.local).

Core Features

  • Terminal Dashboard (jhadoo --tui) - A fully interactive 24-bit Truecolor console interface:
    • Disk Tree Explorer: Drill down into directories sorted by size and flag files or folders for archiving using standard Arrow Keys or Vim hotkeys (h/j/k/l).
    • Live Telemetry: Monitor logical CPU utilization, memory metrics, and I/O rates alongside a calculated system health index.
  • System-Wide Optimizer (jhadoo --optimize) - Flushes local DNS caches, purges system temporary directories, and updates standard workspace configurations.
  • Application Uninstaller (jhadoo --uninstall [APP_NAME]) - Removes designated applications along with deep configurations, plists, launch daemons, and hidden leftovers.
  • Installer Sweeper (jhadoo --installers) - Identifies and safely purges leftover .dmg, .pkg, .msi, .exe, .deb, and .rpm files in Downloads and Desktop directories.
  • Smart Staleness Verification - Evaluates true project activity. Skips folders modified solely by automated OS metadata (like .DS_Store or Thumbs.db) that trigger false freshness values.

Zero-Risk Safety Guardrails

Jhadoo is built with conservative defaults to protect system directories and critical user data:

  1. System Path Guardian: Scans are explicitly restricted from modifying critical OS-specific directories (such as /System on macOS, C:\Windows on Windows, or /boot and /etc on Linux).
  2. Dry-Run Mode (--dry-run / -n): Preview exactly what folders, caches, or applications will be targeted before any changes occur on disk.
  3. Archive and Restore (--archive / --restore): Instead of permanently deleting assets, Jhadoo can move them to a secure local archive directory (~/.jhadoo_archive). Use jhadoo --restore to instantly revert the previous session's cleanup.
  4. No Greedy Wildcards: Leftover config directories are identified strictly using bounded package or vendor matches, keeping shared directories safe.

Installation

Standard Installation

# Recommended (install as a global, isolated binary)
pipx install jhadoo

# Standard pip installation
pip install jhadoo

Note: For Windows users wanting to run the interactive curses TUI, please install the dependency wrapper:

pip install windows-curses

Run Directly from the Source Code (GitHub Repo)

If you want to run, contribute, or test the tool directly from the git repository on your system without installing the package globally, follow this procedure:

  1. Clone the Repository:

    git clone https://github.com/bhav09/jhadoo.git
    cd jhadoo
    
  2. Set Up a Virtual Environment (Optional but recommended):

    python3 -m venv .venv
    source .venv/bin/activate  # On Windows, use: .venv\Scripts\activate
    
  3. Install in Editable Mode: This registers the jhadoo command locally and links it directly to your source files:

    pip install -e .
    
  4. Alternatively, Run as a Python Module: If you do not want to install it at all, you can invoke the CLI entry module directly:

    python3 -m jhadoo --dry-run
    

Command Reference

Default Scanning and Core Cleaning

jhadoo                # Run the standard developer project cleanup scan
jhadoo --dry-run      # Safely preview potential savings without modifying anything
jhadoo --archive      # Back up matching targets to ~/.jhadoo_archive instead of deleting
jhadoo --restore      # Revert the last run's archived deletions back to original paths
jhadoo --dashboard    # View past savings history, clean statistics, and trend predictions

Specialized Operations

jhadoo --tui         # Launch the interactive console disk and telemetry dashboard
jhadoo --optimize    # Run system maintenance (flush DNS, purge temp files, clean package stores)
jhadoo --installers  # Scan Downloads and Desktop for setups and installer binaries
jhadoo --uninstall   # Interactive prompt to remove applications and their configuration remnants

Privacy and Telemetry

  • Local Processing: File paths, usernames, and system details never leave your computer.
  • Minimal Telemetry: To track the overall open-source impact, Jhadoo runs aggregate telemetry metrics (global bytes freed, runtime, and OS type) securely enabled on installation.
  • Opt-Out Anytime:
    • Disable: jhadoo --telemetry-off
    • Check status: jhadoo --telemetry-status

License

MIT License. See LICENSE for more details.

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

jhadoo-1.3.3.tar.gz (54.0 kB view details)

Uploaded Source

Built Distribution

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

jhadoo-1.3.3-py3-none-any.whl (54.6 kB view details)

Uploaded Python 3

File details

Details for the file jhadoo-1.3.3.tar.gz.

File metadata

  • Download URL: jhadoo-1.3.3.tar.gz
  • Upload date:
  • Size: 54.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for jhadoo-1.3.3.tar.gz
Algorithm Hash digest
SHA256 650b194d3624233fe3a83460bfbd5a707ee50464070057a9ea5b72657cf15478
MD5 5a749bca7abbe8ad3cebdb1c4a8cd3f1
BLAKE2b-256 5e93ef1c63fac20210bcfe94a91e1e7b3625ec4e8a5804a2150aa25d999dceda

See more details on using hashes here.

File details

Details for the file jhadoo-1.3.3-py3-none-any.whl.

File metadata

  • Download URL: jhadoo-1.3.3-py3-none-any.whl
  • Upload date:
  • Size: 54.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for jhadoo-1.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ad92cc04eb6de5aa6607d733fda7f03bbb3f631363d5fc98d2b54205d55e5c0c
MD5 b34e5200a9235ddd5a3c72ca1932f4db
BLAKE2b-256 997c601903c8727c43399e912497e71bf2f51ba6e6696d6f3b0259fef81f14dd

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