Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/emersonford/tracing-indicatif
Tracing layer that automatically creates and manages progress bars for active spans.
https://github.com/emersonford/tracing-indicatif
indicatif progress-bar rust tracing
Last synced: 7 days ago
JSON representation
Tracing layer that automatically creates and manages progress bars for active spans.
- Host: GitHub
- URL: https://github.com/emersonford/tracing-indicatif
- Owner: emersonford
- License: mit
- Created: 2023-02-04T06:11:09.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-02T08:02:53.000Z (21 days ago)
- Last Synced: 2024-12-09T03:12:12.129Z (14 days ago)
- Topics: indicatif, progress-bar, rust, tracing
- Language: Rust
- Homepage:
- Size: 15 MB
- Stars: 195
- Watchers: 5
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# tracing-indicatif
[![Documentation](https://docs.rs/tracing-indicatif/badge.svg)](https://docs.rs/tracing-indicatif/)
[![Crates.io](https://img.shields.io/crates/v/tracing-indicatif.svg)](https://crates.io/crates/tracing-indicatif)A [tracing](https://docs.rs/tracing/latest/tracing/) layer that automatically creates and manages [indicatif](https://docs.rs/indicatif/latest/indicatif/index.html) progress bars for active spans.
Progress bars are a great way to make your CLIs feel more responsive. However,
adding and managing progress bars in your libraries can be invasive, unergonomic,
and difficult to keep track of.This library aims to make it easy to show progress bars for your CLI by tying
progress bars to [tracing spans](https://docs.rs/tracing/latest/tracing/#spans).
For CLIs/libraries already using tracing spans, this allow for a dead simple (3
line) code change to enable a smooth progress bar experience for your program.
This eliminates having to have code in your libraries to manually manage
progress bar instances.This ends up working quite well as progress bars are fundamentally tracking the
lifetime of some "span" (whether that "span" is defined explicitly or implicitly),
so might as well make that relationship explicit.## Demo
See the [`examples`](https://github.com/emersonford/tracing-indicatif/tree/main/examples)
folder for demo code.### [Default Configuration](https://github.com/emersonford/tracing-indicatif/blob/main/examples/basic.rs)
![demo using basic example](basic.gif)### [Default Configuration with Child Spans](https://github.com/emersonford/tracing-indicatif/blob/main/examples/child_spans.rs)
![demo using child_spans example](child_spans.gif)### [Progress Bar](https://github.com/emersonford/tracing-indicatif/blob/main/examples/progress_bar.rs)
![demo using progress_bar example](progress_bar.gif)### [Build Console Like](https://github.com/emersonford/tracing-indicatif/blob/main/examples/build_console.rs)
A recreation of `buck2`'s [superconsole](https://github.com/facebookincubator/superconsole).
![demo using build_console example](build_console.gif)## Features
* Customize progress bars using the same [`ProgressStyle`](https://docs.rs/indicatif/latest/indicatif/style/struct.ProgressStyle.html#method.template)
API as indicatif.
* Supports displaying parent-child span relationship between progress bars.
* Limit the number of progress bars visible on the terminal.
* Prevents progress bars from clobbering tracing logs.