Skip to main content

Clean up your filesystem

Project description

Pushbroom

Pushbroom is a tool designed to help keep your filesystem clear of clutter. Certain directories, such as your downloads directory, tend to accumulate a large amount of old files that take up space. Over time, this clutter can accumulate to a significant amount of storage space. Pushbroom gives you an easy way to remove these old files.

Pushbroom is written in Python and should therefore work on any platform that can run Python. For now, it is only officially supported for macOS and Linux.

Installation

Homebrew (macOS only)

Install via Homebrew:

brew install gpanders/tap/pushbroom

Copy and modify the included pushbroom.conf file to ~/.config/pushbroom/config and use brew services start gpanders/tap/pushbroom to start the automatic launchd daemon:

cp /usr/local/etc/pushbroom.conf ~/.config/pushbroom/config
brew services start gpanders/tap/pushbroom

Pushbroom will run once every hour.

pip

Install using pip:

pip install --user pushbroom

You must also copy the example configuration file to ~/.config/pushbroom/config or create your own from scratch.

From source

Check the releases page for the latest release. Download and extract the archive, then install with pip:

tar xzf pushbroom-vX.Y.Z.tar.gz
cd pushbroom-vX.Y.Z
pip install --user .
cp pushbroom.conf ~/.config/pushbroom/config

Usage

Pushbroom can be run from the command line using:

pushbroom

Use pushbroom --help to see a list of command line options.

Configuration

The Pushbroom configuration file is organized into sections where each section represents a directory path to monitor. The default configuration file looks like this:

[Downloads]
Path = ~/Downloads
Trash = ~/.Trash
NumDays = 30

This means that, by default, Pushbroom will monitor your ~/Downloads folder and move any file or folder older than 30 days into your ~/.Trash directory.

If you don't want to move files into ~/.Trash but instead want to just delete them, simply remove the Trash option:

[Downloads]
Path = ~/Downloads
NumDays = 30

The name of the section (Downloads in this example) is not important and can be anything you want:

[Home Directory]
Path = ~
NumDays = 90

You can also specify an Ignore parameter to instruct Pushbroom to ignore any files or directories that match the given glob:

[Downloads]
Path = ~/Downloads
NumDays = 30
Ignore = folder_to_keep

Similarly, you can specify Match to have Pushbroom only remove files that match one of the given patterns:

[Vim Backup Directory]
Path = ~/.cache/vim/backup
NumDays = 90
Match = *~

Both Ignore and Match can be a list of patterns separated by commas.

[Home Directory]
Path = ~
NumDays = 365
Match = .*
Ignore = .local, .config, .cache, .vim

Note that .* is not a regular expression for "match everything", but rather a glob expression for "all files that start with a period".


The following configuration items are recognized in pushbroom.conf:

Path

Required

Absolute path to a directory to monitor. Tildes (~) are expanded to the user's home directory.

Trash

Specify where to move files after deletion. If omitted, files will simply be deleted.

NumDays

Required

Number of days to keep files in Path before they are removed.

Ignore

Default: None

List of glob expression patterns of files or directories to ignore.

Match

Default: *

List of glob expression patterns of files or directories to remove. If omitted, everything is removed.

Shred

Default: False

Securely delete files before removing them. Note that this option is mutually exclusive with the Trash option, with Trash taking precedence if both options are used.

RemoveEmpty

Default: True

Remove empty subdirectories from monitored paths.

Automating

If installed via Homebrew then Pushbroom can be set to run once every hour using

brew services start gpanders/tap/pushbroom

Another option is to install a crontab entry

0 */1 * * * /usr/local/bin/pushbroom

If you are using a Linux distribution that uses systemd, you can copy the systemd service and timer files to ~/.local/share/systemd/ and enable the service with

systemctl --user enable --now pushbroom

Note that you may need to change the path to the pushbroom script in the service file depending on your method of installation.

Contributing

Send patches and questions to ~gpanders/pushbroom@lists.sr.ht.

Report a bug or open a ticket at todo.sr.ht/~gpanders/pushbroom.

Similar Work

  • Belvedere: An automated file manager for Windows
  • Hazel: Automated Organization for your Mac

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

pushbroom-1.0.0.tar.gz (8.2 kB view details)

Uploaded Source

Built Distribution

pushbroom-1.0.0-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

Details for the file pushbroom-1.0.0.tar.gz.

File metadata

  • Download URL: pushbroom-1.0.0.tar.gz
  • Upload date:
  • Size: 8.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/2.7.16 Linux/4.19.0-13-amd64

File hashes

Hashes for pushbroom-1.0.0.tar.gz
Algorithm Hash digest
SHA256 ec1fa9542f1b3cb1157bc4dadca3cf61ce1a35f4d1b1aa69949083a4f627ae36
MD5 2fd6fe17be323177a422d8972a855062
BLAKE2b-256 5689b7c86d4572e07362f8666772f5b3ba9a60562f5d4dbb8734dc05b11f1b80

See more details on using hashes here.

File details

Details for the file pushbroom-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: pushbroom-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 8.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/2.7.16 Linux/4.19.0-13-amd64

File hashes

Hashes for pushbroom-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 845e3d48b3624782fa0dc9725b9226251a2340dce133bda3691059ec2d98612c
MD5 c414f38338e86a972ca12d43ff55edc0
BLAKE2b-256 729479c5c15a7bdec483626fd8b7f2d879a4313eee01f473b73ab7fcd06933cd

See more details on using hashes here.

Supported by

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