podman/vendor/github.com/vbauerster/mpb/v7
dependabot[bot] 9457549fff build(deps): bump github.com/vbauerster/mpb/v7 from 7.5.2 to 7.5.3
Bumps [github.com/vbauerster/mpb/v7](https://github.com/vbauerster/mpb) from 7.5.2 to 7.5.3.
- [Release notes](https://github.com/vbauerster/mpb/releases)
- [Commits](https://github.com/vbauerster/mpb/compare/v7.5.2...v7.5.3)

---
updated-dependencies:
- dependency-name: github.com/vbauerster/mpb/v7
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Also bump the go module to 1.17 to be able to compile the new code.
Given containers/common and others already require go 1.17+ we're
safe to go.

Signed-off-by: dependabot[bot] <support@github.com>
Signed-off-by: Valentin Rothberg <vrothberg@redhat.com>
2022-09-13 08:58:22 +02:00
..
cwriter Bump github.com/vbauerster/mpb/v7 from 7.4.2 to 7.5.2 2022-08-26 12:16:50 +00:00
decor Bump github.com/vbauerster/mpb/v7 from 7.4.2 to 7.5.2 2022-08-26 12:16:50 +00:00
internal vendor c/common 2022-01-10 16:25:37 +01:00
.gitignore Vendor in containers/common v0.40.0 2021-06-17 14:59:42 -04:00
README.md vendor c/common 2022-01-10 16:25:37 +01:00
UNLICENSE Vendor in containers/common v0.40.0 2021-06-17 14:59:42 -04:00
bar.go Bump github.com/vbauerster/mpb/v7 from 7.4.2 to 7.5.2 2022-08-26 12:16:50 +00:00
bar_filler.go vendor c/common 2022-01-10 16:25:37 +01:00
bar_filler_bar.go Bump github.com/vbauerster/mpb/v7 from 7.3.2 to 7.4.1 2022-03-10 12:10:45 +00:00
bar_filler_nop.go vendor c/common 2022-01-10 16:25:37 +01:00
bar_filler_spinner.go Bump github.com/containers/image/v5 from 5.18.0 to 5.19.0 2022-01-26 15:15:46 +00:00
bar_option.go Bump github.com/vbauerster/mpb/v7 from 7.4.2 to 7.5.2 2022-08-26 12:16:50 +00:00
container_option.go build(deps): bump github.com/vbauerster/mpb/v7 from 7.5.2 to 7.5.3 2022-09-13 08:58:22 +02:00
doc.go Vendor in containers/common v0.40.0 2021-06-17 14:59:42 -04:00
priority_queue.go Bump github.com/vbauerster/mpb/v7 from 7.4.2 to 7.5.2 2022-08-26 12:16:50 +00:00
progress.go build(deps): bump github.com/vbauerster/mpb/v7 from 7.5.2 to 7.5.3 2022-09-13 08:58:22 +02:00
proxyreader.go build(deps): bump github.com/vbauerster/mpb/v7 from 7.5.2 to 7.5.3 2022-09-13 08:58:22 +02:00

README.md

Multi Progress Bar

GoDoc Test status Donate with PayPal

mpb is a Go lib for rendering progress bars in terminal applications.

Features

  • Multiple Bars: Multiple progress bars are supported
  • Dynamic Total: Set total while bar is running
  • Dynamic Add/Remove: Dynamically add or remove bars
  • Cancellation: Cancel whole rendering process
  • Predefined Decorators: Elapsed time, ewma based ETA, Percentage, Bytes counter
  • Decorator's width sync: Synchronized decorator's width among multiple bars

Usage

Rendering single bar

package main

import (
    "math/rand"
    "time"

    "github.com/vbauerster/mpb/v7"
    "github.com/vbauerster/mpb/v7/decor"
)

func main() {
    // initialize progress container, with custom width
    p := mpb.New(mpb.WithWidth(64))

    total := 100
    name := "Single Bar:"
    // create a single bar, which will inherit container's width
    bar := p.New(int64(total),
        // BarFillerBuilder with custom style
        mpb.BarStyle().Lbound("╢").Filler("▌").Tip("▌").Padding("░").Rbound("╟"),
        mpb.PrependDecorators(
            // display our name with one space on the right
            decor.Name(name, decor.WC{W: len(name) + 1, C: decor.DidentRight}),
            // replace ETA decorator with "done" message, OnComplete event
            decor.OnComplete(
                decor.AverageETA(decor.ET_STYLE_GO, decor.WC{W: 4}), "done",
            ),
        ),
        mpb.AppendDecorators(decor.Percentage()),
    )
    // simulating some work
    max := 100 * time.Millisecond
    for i := 0; i < total; i++ {
        time.Sleep(time.Duration(rand.Intn(10)+1) * max / 10)
        bar.Increment()
    }
    // wait for our bar to complete and flush
    p.Wait()
}

Rendering multiple bars

    var wg sync.WaitGroup
    // passed wg will be accounted at p.Wait() call
    p := mpb.New(mpb.WithWaitGroup(&wg))
    total, numBars := 100, 3
    wg.Add(numBars)

    for i := 0; i < numBars; i++ {
        name := fmt.Sprintf("Bar#%d:", i)
        bar := p.AddBar(int64(total),
            mpb.PrependDecorators(
                // simple name decorator
                decor.Name(name),
                // decor.DSyncWidth bit enables column width synchronization
                decor.Percentage(decor.WCSyncSpace),
            ),
            mpb.AppendDecorators(
                // replace ETA decorator with "done" message, OnComplete event
                decor.OnComplete(
                    // ETA decorator with ewma age of 60
                    decor.EwmaETA(decor.ET_STYLE_GO, 60, decor.WCSyncWidth), "done",
                ),
            ),
        )
        // simulating some work
        go func() {
            defer wg.Done()
            rng := rand.New(rand.NewSource(time.Now().UnixNano()))
            max := 100 * time.Millisecond
            for i := 0; i < total; i++ {
                // start variable is solely for EWMA calculation
                // EWMA's unit of measure is an iteration's duration
                start := time.Now()
                time.Sleep(time.Duration(rng.Intn(10)+1) * max / 10)
                bar.Increment()
                // we need to call DecoratorEwmaUpdate to fulfill ewma decorator's contract
                bar.DecoratorEwmaUpdate(time.Since(start))
            }
        }()
    }
    // wait for passed wg and for all bars to complete and flush
    p.Wait()

Dynamic total

dynamic total

Complex example

complex

Bytes counters

byte counters