README
¶
rmstale
rmstale is a cross-platform command-line tool to remove stale files and empty directories recursively below a given directory.
Table of Contents
Features
- Remove files and empty directories older than a specified age
- Cross-platform: Windows, Linux, macOS
- Dry-run mode for safe testing
- Extension-based file filtering
- Logs errors (e.g., permission issues)
- Designed for automation and scheduling
Some example use cases:
- Set on a schedule to clear old files from your temporary directories
- Set on a schedule to remove downloaded files from your downloads directory
Install instructions
Windows (Chocolatey)
choco install rmstale
Windows (Winget)
winget install danstis.rmstale
Linux / macOS
Visit the releases page for the latest version, or use:
# Fetch the latest release tag from GitHub
latest_version=$(curl -s https://api.github.com/repos/danstis/rmstale/releases/latest | grep -Po '"tag_name": "\K.*?(?=")')
# Download the latest version tarball
curl -L -o rmstale.tar.gz "https://github.com/danstis/rmstale/releases/download/$latest_version/rmstale_${latest_version#v}_linux_amd64.tar.gz"
# Extract and install
sudo tar -xzf rmstale.tar.gz -C /usr/local/bin rmstale
# Cleanup
rm rmstale.tar.gz
Manual Download
- Download the latest binary for your OS from the GitHub releases page.
- Place the downloaded file into a directory in your PATH.
Usage instructions
Command Line Flags
| Flag | Description | Default |
|---|---|---|
| -a, --age | Period in days before an item is considered stale. (REQUIRED) | (required) |
| -d, --dry-run | Runs the process in dry-run mode. No files will be removed, but the tool will log the files that would be deleted. | false |
| -e, --extension | Filter files for a defined file extension. This flag only applies to files, not directories. | (empty) |
| -p, --path | Path to a folder to process. | system temp dir |
| -v, --version | Displays the version of rmstale that is currently running. | false |
| -y, --confirm | Allows for processing without confirmation prompt, useful for scheduling. | false |
Usage Examples
Show Version
rmstale --version
# rmstale v1.2.3
Remove files older than 14 days (Windows)
rmstale --age 14 --path c:\temp
# WARNING: Will remove files and folders recursively below 'c:\temp' older than 14 days. Continue?: y
# -Removing 'C:\Temp\amc2E40.tmp.LOG1'...
# ...
Remove files older than 14 days (Linux/macOS)
rmstale --age 14 --path /tmp
# WARNING: Will remove files and folders recursively below '/tmp' older than 14 days. Continue?: y
# -Removing '/tmp/oldfile1'...
# ...
Dry-run mode (no files deleted)
rmstale --age 30 --path ~/Downloads --dry-run
# [DRY RUN] '/home/user/Downloads/oldfile.txt' would be removed...
# ...
Any errors encountered during the deletion process (e.g., permission issues) will be logged.
Contribution
Feedback, issues, and contributions are welcome! For bugs, issues, or feature requests, please create an issue on the GitHub issues page.
Want to contribute? Please:
- Fork the repo and clone it locally
- Use Go 1.24 or above
- Format code with
gofmt -wand check withgolangci-lint - Add or update tests (
go test ./...) - Follow the CONTRIBUTING.md guidelines
- Create a pull request with a clear description
Release Process
This project follows Semantic Versioning. To create a new release:
- Ensure all changes are committed to the main branch via a pull request
- The release pipeline will automatically generate a tag if the build number is a clean semver version (e.g.,
v1.2.3) - Alternatively, manually tag a commit with a version number (
v1.2.3) and push the tag - The CI/CD pipeline will build and publish the release
License
This project is licensed under the MIT License.
Click to show internal directories.
Click to hide internal directories.