#progress-bar #progress #tui

bin+lib multi-progressbar

A library for displaying multiple progress bars in the terminal designed to not stand in your way

1 unstable release

0.1.0 Jul 12, 2023

#119 in #progress-bar

Download history 2/week @ 2024-12-11 10/week @ 2025-01-08 27/week @ 2025-01-15 6/week @ 2025-01-22 53/week @ 2025-02-12 21/week @ 2025-02-19 9/week @ 2025-02-26 23/week @ 2025-03-05

106 downloads per month

Apache-2.0

14KB
252 lines

multi-progress

multi-progress is a library to show multiple progress bars along with log outputs in terminal.

Usage

  1. Implement TaskProgress trait for your task.
  2. Create a MultiProgressBar with a ProgressBar implementation (provided in the bar module).
  3. Call MultiProgressBar::draw to draw progress bars when needed.
use multi_progressbar::{
    MultiProgressBar, TaskProgress,
    bar::classic::ClassicProgressBar
};

struct Task {
    name: String,
    progress: u64,
    total: u64,
}

impl TaskProgress for Task {
    fn progress(&self) -> (u64, u64) {
        (self.progress, self.total)
    }
    fn after(&self) -> Option<String> {
        Some(format!("{}/{} completed", self.progress, self.total))
    }
    fn before(&self) -> Option<String> {
        Some(self.name.clone())
    }
}

let mp = MultiProgressBar::new(ClassicProgressBar::new());
let task1 = Task {
   name: "task1".to_string(),
   progress: 0,
   total: 100,
};
let task2 = Task {
    name: "task2".to_string(),
    progress: 33,
    total: 100,
};
let tasks = vec![task1, task2];
mp.draw(&tasks).unwrap();

Dependencies

~1–13MB
~80K SLoC