11 stable releases (4 major)
| 4.2.0 | Mar 4, 2026 |
|---|---|
| 4.1.1 | Nov 21, 2023 |
| 4.1.0 | Jun 17, 2022 |
| 3.1.0 | Mar 11, 2022 |
| 0.0.2 | Dec 18, 2017 |
#72 in Command-line interface
260,917 downloads per month
Used in 161 crates
(127 directly)
50KB
1.5K
SLoC
Spinners - 🛎 60+ Elegant terminal spinners for Rust

❤️ Shameless plug
Install
See Cargo page
Usage
use spinners::{Spinner, Spinners};
use std::thread::sleep;
use std::time::Duration;
fn main() {
let mut sp = Spinner::new(Spinners::Dots9, "Waiting for 3 seconds".into());
sleep(Duration::from_secs(3));
sp.stop();
}
Example
cargo run --example cycle
cargo run --example simple
Feature flags
osc-progress
Enables native terminal progress bar support via the ConEmu OSC 9;4 protocol. Terminals like Ghostty, Windows Terminal, iTerm2, Kitty, and WezTerm render these as GUI progress bars in the title/tab bar. Unsupported terminals silently ignore the sequences.
[dependencies]
spinners = { version = "4.1.0", features = ["osc-progress"] }
The progress bar is emitted as an indeterminate/pulsing indicator while the spinner is active, and cleared when the spinner is stopped or dropped. Sequences are only emitted when the output stream is a terminal, so piped output is unaffected.
Signal handling caveat: If the process is killed abruptly (e.g. SIGINT via Ctrl+C, SIGKILL), the Drop implementation may not run and the progress bar won't be cleared. Terminals like Ghostty mitigate this with a ~15-second auto-clear timeout, but for immediate cleanup, applications should install their own signal handler that stops the spinner (e.g. by dropping it or calling .stop()) before exiting.
License
MIT © François-Guillaume Ribreau, James Cordor
Dependencies
~1.5MB
~41K SLoC