#progress-bar #watcher #utilities #tool #minimal #no-deps

yanked utls

A simple utilities library for stuff I actually use sometimes, with a large focus on convenience and lack of dependencies

13 releases (8 breaking)

0.13.10 Dec 16, 2024
0.11.10 Dec 13, 2024

#40 in #minimal

Download history 303/week @ 2024-12-02 529/week @ 2024-12-09 311/week @ 2024-12-16

1,143 downloads per month

GPL-3.0 license

150KB
3K SLoC

Utils (utls)

A Rust utility library providing thread-safe progress bars and value watching functionality.

Features

  • Progress Bars: Highly customizable, thread-safe progress bars with:

    • Multiple built-in styles (Classic, Modern, Minimal, Fancy, ASCII, Dots, Arrows, Box)
    • Customizable appearance and behavior
    • Real-time statistics tracking
    • Spinner animations
    • Threading support
    • Formatted message templates
  • Value Watcher: Thread-safe value monitoring system

Usage Examples

Progress Bar

use utls::prog::PB;
use std::thread;
use std::time::Duration;

fn main() {
    let pb = PB::modern(100);  // Create a modern style progress bar with 100 steps
    let (handle, pb_ref) = pb.threaded_start(); // Start the bar rendering in a new thread

    PB::inc_until_arc(pb_ref.clone(), || { // Run the Fn closure then increment until the bar finishes
        thread::sleep(Duration::from_millis(10)); // (or some work)
    });

    handle.join().unwrap();
    pb_ref.lock().unwrap().finish_with_message("Complete!");
}

Value Watcher

use utls::watcher::Watcher;
use std::sync::{atomic::AtomicBool, Arc, Mutex};

fn main() {
    let shutdown = Arc::new(Mutex::new(AtomicBool::new(false)));
    let watcher = Watcher::new(0, 100, shutdown); // Initial value 0, poll every 100ms

    watcher.set_value(42);
    if watcher.has_changed() {
        println!("Value changed to: {}", watcher.get_value());
    }
}

Progress Bar Styles

  • PB::classic() - Traditional ASCII style
  • PB::modern() - Unicode blocks style
  • PB::minimal() - Minimalistic appearance
  • PB::fancy() - Decorative Unicode style
  • PB::ascii() - Pure ASCII characters
  • PB::dots() - Braille pattern style
  • PB::arrows() - Arrow-based style
  • PB::box_heavy() - Heavy box drawing characters

Message Formatting

Progress bars support the following template variables in messages if formatting is enabled:

  • {p} - Progress percentage
  • {c} - Current value
  • {m} - Maximum value
  • {e} - Elapsed time
  • {r} - Estimated remaining time (highly inaccurate)

Note: enabling formatting can decrease performance

Building

Requires Rust nightly due to #![feature(unboxed_closures)].

Examples

See the /examples directory for more usage examples:

  • Progress bar demos: PB
  • Watcher demos: Watcher

License

License

Dependencies