Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/triyanox/pgbar
A minimal progress bar written in rust
https://github.com/triyanox/pgbar
progress-bar rust
Last synced: 17 days ago
JSON representation
A minimal progress bar written in rust
- Host: GitHub
- URL: https://github.com/triyanox/pgbar
- Owner: triyanox
- License: mit
- Created: 2023-03-20T23:52:32.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-23T00:54:43.000Z (12 months ago)
- Last Synced: 2024-04-16T14:08:56.868Z (7 months ago)
- Topics: progress-bar, rust
- Language: Rust
- Homepage: https://crates.io/crates/pgbar
- Size: 14.6 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# pgbar - A minimal progress bar written in rust
[![Crates.io](https://img.shields.io/crates/v/pgbar.svg)](https://crates.io/crates/pgbar)
![Rust CI](https://github.com/triyanox/pgbar/workflows/Rust%20CI/badge.svg)This is a Rust library to create progress bars on terminal. It provides an easy way to track the progress of some task, allowing the user to customize its appearance and behavior.
## Installation
Add this to your `Cargo.toml`:
```toml
[dependencies]
pgbar = "*"
```## Usage
To use the library, first import it on your Rust project:
```rust
use pgbar::{ProgressBar, Style};
```Then, create a new progress bar object with the desired configuration using the `new()` method:
```rust
let mut pb = ProgressBar::new(100, 10, Style::default());
```The first parameter represents the maximum value of the progress bar, the second one is the estimated time to complete the task, and the third defines the style of the bar. You can customize it by creating a new `Style` struct with your preferred options.
After that, you can start tracking the progress of your task by calling the `track()` method:
```rust
pb.track();
```This will update the progress bar until it reaches the maximum value defined.
You can also update, reset or recover the progress bar using the methods `update()`, `reset()` and `recover()`, respectively.
```rust
pb.update(50);
pb.reset();
pb.recover();
```Finally, to finish the progress bar, call the `finish()` method:
```rust
pb.finish();
```## Customization
The progress bar can be customized with the following options:
- `symbol`: the character used to represent the progress of the task (default: `"*"`).
- `width`: the width of the progress bar in characters (default: `50`).
- `wrapper`: the characters used to wrap the progress bar (default: `"[]"`).
- `color`: the color of the progress bar (default: `Cyan`).
- `time_to_finish`: whether or not to show the estimated time to finish the task (default: `true`).To customize these options, create a new `Style` struct with your preferred configuration and pass it as a parameter to the `new()` method:
```rust
use termion::color;let style = Style {
symbol: "#".to_string(),
width: 30,
wrapper: "()".to_string(),
color: Some(&color::Red),
time_to_finish: false,
};
let mut pb = ProgressBar::new(100, 10, style);
```## Example
Here is a simple example showing how to use the progress bar library:
```rust
use pgbar::{ProgressBar, Style};
use std::thread;
use std::time::Duration;
use termion::color;fn main() {
let style = Style {
symbol: "=".to_string(),
width: 50,
wrapper: "||".to_string(),
color: Some(&color::Green),
time_to_finish: true,
};
let mut pb = ProgressBar::new(100, 5, style);for i in 0..=100 {
pb.update(i);
thread::sleep(Duration::from_millis(50));
}pb.finish();
}
```This will create a progress bar with green color, the symbol "=" and the wrapper "||", updating its progress every 50 milliseconds until it reaches the maximum value of 100.