Skip to main content

macOS maintenance CLI — updates, cleanup, and system maintenance

Project description

macmaint

PyPI version Python 3.13+ License: MIT

A macOS maintenance CLI that keeps your system clean and up-to-date with a single command. Run macmaint to update Homebrew packages, the Mac App Store, uv-managed tools, clear caches, trim log files, vacuum Mail.app, flush DNS, and show you which apps you haven't opened in months.

Everything is idempotent and safe to run as a daily cron job. Use --dry-run to preview every action before it executes.

Install

uv tool install macmaint

Or with pipx:

pipx install macmaint

Prerequisites

Requirement Notes
macOS 13 Ventura or later macOS-only by design
Python 3.13+ Installed automatically by uv/pipx
Homebrew Optional — needed for update and cleanup brew tasks
mas Optional — brew install mas for App Store updates
uv Optional — for uv tool upgrade --all in update
bun Optional — for bun update -g (global JS CLIs like ccusage) in update
Docker, npm Optional — cleanup prunes these if available

Quick start

# Check which tools are wired up on your machine
macmaint doctor

# Preview all maintenance tasks without executing anything
macmaint --dry-run

# Run everything
macmaint

Subcommands

Command What it does
macmaint update Homebrew update/upgrade/cleanup + Mac App Store upgrades + uv tool upgrade --all + bun update -g
macmaint cleanup Empty trash, clear user caches, purge pip/npm/uv caches, remove Xcode DerivedData, prune Docker, delete old logs
macmaint maintenance Flush DNS cache, vacuum Mail.app envelope index, repair user permissions, rebuild Spotlight index, free APFS purgeable space
macmaint apps Show all installed apps sorted by last used date (GUI apps, Homebrew formulae, Steam games)
macmaint doctor Check which optional tools are available and what macmaint can do

Common flags

# Preview mode — show what would run, no changes
macmaint --dry-run
macmaint cleanup --dry-run

# Skip specific tasks
macmaint update --no-brew          # skip Homebrew
macmaint update --no-mas           # skip App Store
macmaint update --no-uv-tools      # skip uv tool upgrade --all
macmaint update --no-bun           # skip bun update -g
macmaint cleanup --no-caches       # skip user caches
macmaint cleanup --no-docker       # skip Docker prune

# App usage filtering
macmaint apps --days 90            # highlight apps unused for 90+ days
macmaint apps --unused             # show only unused apps
macmaint apps --size               # include disk footprint column

Configuration

Create ~/.config/macmaint/config.toml to override defaults. All keys are optional.

[cleanup]
# Which cache directories under ~/Library/Caches/ to clear.
# Defaults to a curated safe list (Safari, Chrome, VSCode, JetBrains IDEs, etc.)
cache-allowlist = [
    "com.apple.Safari",
    "com.google.Chrome",
    "com.apple.WebKit.WebContent",
    "pip",
    "com.spotify.client",
    "com.microsoft.VSCode",
    "com.jetbrains.intellij",
    "PyCharm",
    "CLion",
    "Rider",
    "WebStorm",
    "DataGrip",
]

# Remove log files older than this many days from ~/Library/Logs/
# Default: 7
log-retention-days = 7

[apps]
# Glob patterns for Steam library volumes to scan in addition to ~/Library.
# Default: ["/Volumes/*"]
steam-volumes = ["/Volumes/*"]

Caveats

  • Mac App Store (mas upgrade) requires sudo. macmaint runs sudo mas upgrade; you will be prompted for your password. This is a mas limitation.

  • macmaint apps uses the Screen Time database (knowledgeC.db) for last-used dates. This database is protected by macOS privacy controls. For accurate results, grant Full Disk Access to the terminal app running macmaint (System Settings → Privacy & Security → Full Disk Access). Without access, macmaint falls back to Spotlight metadata, which is less accurate.

  • macmaint apps --size is slow for large app libraries. It runs du on each app bundle plus associated Library directories. Expect 30–120 seconds for 100+ apps.

  • macOS-only. macmaint uses macOS-specific tools (mdls, tmutil, dscacheutil, diskutil, sqlite3) and will not run on Linux or Windows.

License

MIT — see LICENSE.

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

macmaint-2026.4.5.tar.gz (38.9 kB view details)

Uploaded Source

Built Distribution

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

macmaint-2026.4.5-py3-none-any.whl (16.7 kB view details)

Uploaded Python 3

File details

Details for the file macmaint-2026.4.5.tar.gz.

File metadata

  • Download URL: macmaint-2026.4.5.tar.gz
  • Upload date:
  • Size: 38.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for macmaint-2026.4.5.tar.gz
Algorithm Hash digest
SHA256 ac251d803e812fd58d4a16eea4c31cc8f34dac72e994428794e7192966846a1f
MD5 f420677956cd81705c4a580907cd0e6a
BLAKE2b-256 9fbcf77e37250ca69ed190939e0cc4c73961cc059e83754609ee0920eabbc70c

See more details on using hashes here.

File details

Details for the file macmaint-2026.4.5-py3-none-any.whl.

File metadata

  • Download URL: macmaint-2026.4.5-py3-none-any.whl
  • Upload date:
  • Size: 16.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for macmaint-2026.4.5-py3-none-any.whl
Algorithm Hash digest
SHA256 a75306cd9225a7b2e55899fd72718b89631e9c41e817596da828795e8c62c128
MD5 07e7b07be14520a92513322ab3e2b9e0
BLAKE2b-256 571233b990e9cd3b55a3e337a3b17fa94c33ce0e6031819984feed7041e48510

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