#tool #cli #cargo

app cargo-sweep

A tool for cleaning unused build files created by Cargo

7 releases (4 breaking)

✓ Uses Rust 2018 edition

0.5.0 Jan 24, 2020
0.4.1 Feb 5, 2019
0.4.0 Jan 23, 2019
0.3.0 Dec 7, 2018
0.1.1 Nov 9, 2018

#57 in Cargo plugins

Download history 64/week @ 2020-03-12 71/week @ 2020-03-19 59/week @ 2020-03-26 42/week @ 2020-04-02 87/week @ 2020-04-09 76/week @ 2020-04-16 68/week @ 2020-04-23 122/week @ 2020-04-30 98/week @ 2020-05-07 205/week @ 2020-05-14 236/week @ 2020-05-21 66/week @ 2020-05-28 339/week @ 2020-06-04 244/week @ 2020-06-11 81/week @ 2020-06-18 320/week @ 2020-06-25

346 downloads per month

MIT and MPL-2.0 licenses

787 lines


A cargo subcommand for cleaning up unused build files generated by Cargo.


Ideally you want:

  • Caching of recent artifacts for fast build times
  • Limited target size so that CI caches (on Travis etc.) are fast
  • An easy way of maintaining one or more projects at the same time

Cargo-sweep aims to solve all these issues for which a simple cargo clean is not sufficient.

Quick start

To install run:

cargo install cargo-sweep

To clean all build files older than 30 days in the local cargo project run:

cargo sweep -t 30

To clean all build files not made by the currently installed (by rustup) nightly compiler:

cargo sweep --toolchains="nightly"

This can be useful if you checked that your library works on stable, but mostly develop on nightly.

To clean all build files not made by any of the currently installed (by rustup) compilers:

cargo sweep -i

This can be useful if you just updated your compilers with a rustup update.

To preview the results of a sweep run, which is recommended as a first step, add the -d flag, for instance:

cargo sweep -d -t 30

You can also specify a path instead of defaulting to the current directory:

cargo sweep -t 30 <path>

To clean everything but the latest build you will need to run it in several steps.

cargo sweep -s

<Insert any number of cargo build, cargo test etc...>

cargo sweep -f

The first step generates a timestamp file which will be used to clean everything that was not used between it and the next time the file (-f) option is used.

Finally, you can recursively clean all cargo project below a given path by adding the -r flag, for instance:

cargo sweep -r -t 30 code/github.com/holmgr/

For more information run:

cargo sweep -h


Cargo-sweep is distributed under the terms the MIT license.

See LICENSE for details.


~67K SLoC