update: v0.3.0
This commit is contained in:
parent
1c2e19ac8b
commit
a66e983554
|
@ -1,6 +1,6 @@
|
||||||
[package]
|
[package]
|
||||||
name = "spinoff"
|
name = "spinoff"
|
||||||
version = "0.2.0"
|
version = "0.3.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
authors = ["ad4m"]
|
authors = ["ad4m"]
|
||||||
description = "🔨 Simple to use Rust library for displaying spinners in the terminal."
|
description = "🔨 Simple to use Rust library for displaying spinners in the terminal."
|
||||||
|
|
BIN
assets/index.gif
BIN
assets/index.gif
Binary file not shown.
Before Width: | Height: | Size: 1.1 MiB After Width: | Height: | Size: 278 KiB |
|
@ -1,4 +1,4 @@
|
||||||
use spinoff::{Spinner, Spinners, Color};
|
use spinoff::{Color, Spinner, Spinners};
|
||||||
use std::{thread::sleep, time::Duration};
|
use std::{thread::sleep, time::Duration};
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
|
28
src/lib.rs
28
src/lib.rs
|
@ -59,6 +59,8 @@ pub enum Color {
|
||||||
Yellow,
|
Yellow,
|
||||||
Cyan,
|
Cyan,
|
||||||
White,
|
White,
|
||||||
|
Black,
|
||||||
|
Magenta,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Spinner {
|
impl Spinner {
|
||||||
|
@ -77,7 +79,7 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let sp = Spinner::new(Spinners::Dots, "Hello", Some(Color::Blue));
|
/// let sp = Spinner::new(Spinners::Dots, "Hello World!", Some(Color::Blue));
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.clear();
|
/// sp.clear();
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -107,12 +109,12 @@ impl Spinner {
|
||||||
.iter()
|
.iter()
|
||||||
.cycle()
|
.cycle()
|
||||||
.take_while(|_| still_spinning.load(std::sync::atomic::Ordering::Relaxed));
|
.take_while(|_| still_spinning.load(std::sync::atomic::Ordering::Relaxed));
|
||||||
|
// Dynamically delete the last line of the terminal depending on the length of the message + spinner.
|
||||||
let mut last_length = 0;
|
let mut last_length = 0;
|
||||||
for frame in frames {
|
for frame in frames {
|
||||||
// This is dependant on the stdout attached is a terminal that respects \r
|
|
||||||
let mut stdout_lock = stdout.lock();
|
let mut stdout_lock = stdout.lock();
|
||||||
let frame_str = format!(" {} {}", init_color(color, frame.to_string()), msg);
|
let frame_str = format!(" {} {}", init_color(color, frame.to_string()), msg);
|
||||||
|
// Get us back to the start of the line.
|
||||||
delete_last_line(last_length);
|
delete_last_line(last_length);
|
||||||
last_length = frame_str.bytes().len();
|
last_length = frame_str.bytes().len();
|
||||||
write!(stdout_lock, "{}", frame_str).unwrap();
|
write!(stdout_lock, "{}", frame_str).unwrap();
|
||||||
|
@ -144,7 +146,7 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let sp = Spinner::new(Spinners::Dots9, "Spinning...", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.stop();
|
/// sp.stop();
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -168,7 +170,7 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let sp = Spinner::new(Spinners::Dots2, "Hello", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.stop_with_message("Bye");
|
/// sp.stop_with_message("Bye");
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -188,7 +190,7 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let sp = Spinner::new(Spinners::Mindblown, "Guess what's coming...", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.stop_and_persist("🍕", "Pizza!");
|
/// sp.stop_and_persist("🍕", "Pizza!");
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -207,7 +209,7 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let sp = Spinner::new(Spinners::Aesthetic, "Trying to load information...", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.success("Success!");
|
/// sp.success("Success!");
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -230,9 +232,9 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let sp = Spinner::new(Spinners::BouncingBar, "Executing code...", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.fail("Failed!");
|
/// sp.fail("Code failed to compile!");
|
||||||
/// ```
|
/// ```
|
||||||
///
|
///
|
||||||
pub fn fail(mut self, msg: StringLiteral) {
|
pub fn fail(mut self, msg: StringLiteral) {
|
||||||
|
@ -249,9 +251,9 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let sp = Spinner::new(Spinners::Material, "Measuring network speed...", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.warn("Look out!");
|
/// sp.warn("You might want to check your internet connection...");
|
||||||
/// ```
|
/// ```
|
||||||
///
|
///
|
||||||
pub fn warn(mut self, msg: StringLiteral) {
|
pub fn warn(mut self, msg: StringLiteral) {
|
||||||
|
@ -275,7 +277,7 @@ impl Spinner {
|
||||||
/// let mut sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let mut sp = Spinner::new(Spinners::Dots, "Hello", None);
|
||||||
///
|
///
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.update(Spinners::Dots2, "Goodbye", None);
|
/// sp.update(Spinners::Dots2, "World", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
///
|
///
|
||||||
/// sp.stop();
|
/// sp.stop();
|
||||||
|
@ -298,7 +300,7 @@ impl Spinner {
|
||||||
/// # use std::thread::sleep;
|
/// # use std::thread::sleep;
|
||||||
/// # use std::time::Duration;
|
/// # use std::time::Duration;
|
||||||
/// #
|
/// #
|
||||||
/// let mut sp = Spinner::new(Spinners::Dots, "Hello", None);
|
/// let mut sp = Spinner::new(Spinners::Grenade, "Clearing...", None);
|
||||||
/// sleep(Duration::from_millis(800));
|
/// sleep(Duration::from_millis(800));
|
||||||
/// sp.clear();
|
/// sp.clear();
|
||||||
/// ```
|
/// ```
|
||||||
|
|
|
@ -22,6 +22,8 @@ pub fn init_color(color: Option<Color>, spinner: String) -> Paint<String> {
|
||||||
Some(Color::Yellow) => Paint::yellow(spinner),
|
Some(Color::Yellow) => Paint::yellow(spinner),
|
||||||
Some(Color::Cyan) => Paint::cyan(spinner),
|
Some(Color::Cyan) => Paint::cyan(spinner),
|
||||||
Some(Color::White) => Paint::new(spinner),
|
Some(Color::White) => Paint::new(spinner),
|
||||||
|
Some(Color::Black) => Paint::black(spinner),
|
||||||
|
Some(Color::Magenta) => Paint::magenta(spinner),
|
||||||
None => Paint::new(spinner),
|
None => Paint::new(spinner),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use crate::{spinner_enum::Spinners, StringLiteral};
|
use crate::spinner_enum::Spinners;
|
||||||
use maplit::{self, hashmap};
|
use maplit::{self, hashmap};
|
||||||
use once_cell::sync::Lazy;
|
use once_cell::sync::Lazy;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
@ -7,7 +7,7 @@ use std::collections::HashMap;
|
||||||
/// Frames is a Vec of &str, each &str is a frame of the spinner.
|
/// Frames is a Vec of &str, each &str is a frame of the spinner.
|
||||||
/// Interval is the number of milliseconds to wait before moving to the next frame.
|
/// Interval is the number of milliseconds to wait before moving to the next frame.
|
||||||
pub struct SpinnerFrames {
|
pub struct SpinnerFrames {
|
||||||
pub frames: Vec<StringLiteral>,
|
pub frames: Vec<&'static str>,
|
||||||
pub interval: u16,
|
pub interval: u16,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1096,8 +1096,8 @@ pub static SPINNER_FRAMES: Lazy<HashMap<Spinners, SpinnerFrames>> = Lazy::new(||
|
||||||
"🤜 🤛",
|
"🤜 🤛",
|
||||||
" 🤜 🤛 ",
|
" 🤜 🤛 ",
|
||||||
" 🤜🤛 ",
|
" 🤜🤛 ",
|
||||||
" 🤜✨🤛 ",
|
" 🤜✨🤛 ",
|
||||||
"🤜 ✨ 🤛 "
|
"🤜 ✨ 🤛 "
|
||||||
], interval: 80},
|
], interval: 80},
|
||||||
Spinners::SoccerHeader => SpinnerFrames {frames: vec![
|
Spinners::SoccerHeader => SpinnerFrames {frames: vec![
|
||||||
" 🧑⚽️ 🧑",
|
" 🧑⚽️ 🧑",
|
||||||
|
|
Loading…
Reference in a new issue