#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

#96 in #progress-bar

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–12MB
~79K SLoC