Documentation ¶
Overview ¶
Example (XOutOfY) ¶
bar := NewOptions(100, OptionSetPredictTime(true)) for i := 0; i < 100; i++ { bar.Add(1) time.Sleep(1 * time.Millisecond) }
Output:
Index ¶
- type Option
- func OptionClearOnFinish() Option
- func OptionEnableColorCodes(colorCodes bool) Option
- func OptionFullWidth() Option
- func OptionOnCompletion(cmpl func()) Option
- func OptionSetDescription(description string) Option
- func OptionSetElapsedTime(elapsedTime bool) Option
- func OptionSetItsString(iterationString string) Option
- func OptionSetPredictTime(predictTime bool) Option
- func OptionSetRenderBlankState(r bool) Option
- func OptionSetTheme(t Theme) Option
- func OptionSetVisibility(visibility bool) Option
- func OptionSetWidth(s int) Option
- func OptionSetWriter(w io.Writer) Option
- func OptionShowBytes(val bool) Option
- func OptionShowCount() Option
- func OptionShowDescriptionAtLineEnd() Option
- func OptionShowElapsedTimeOnFinish() Option
- func OptionShowIts() Option
- func OptionSpinnerCustom(spinner []string) Option
- func OptionSpinnerType(spinnerType int) Option
- func OptionThrottle(duration time.Duration) Option
- func OptionUseANSICodes(val bool) Option
- type ProgressBar
- func Default(max int64, description ...string) *ProgressBar
- func DefaultBytes(maxBytes int64, description ...string) *ProgressBar
- func DefaultBytesSilent(maxBytes int64, description ...string) *ProgressBar
- func DefaultSilent(max int64, description ...string) *ProgressBar
- func New(max int) *ProgressBar
- func New64(max int64) *ProgressBar
- func NewOptions(max int, options ...Option) *ProgressBar
- func NewOptions64(max int64, options ...Option) *ProgressBar
- func (p *ProgressBar) Add(num int) error
- func (p *ProgressBar) Add64(num int64) error
- func (p *ProgressBar) ChangeMax(newMax int)
- func (p *ProgressBar) ChangeMax64(newMax int64)
- func (p *ProgressBar) Clear() error
- func (p *ProgressBar) Close() (err error)
- func (p *ProgressBar) Describe(description string)
- func (p *ProgressBar) Exit() error
- func (p *ProgressBar) Finish() error
- func (p *ProgressBar) GetMax() int
- func (p *ProgressBar) GetMax64() int64
- func (p *ProgressBar) IsFinished() bool
- func (p *ProgressBar) Read(b []byte) (n int, err error)
- func (p *ProgressBar) RenderBlank() error
- func (p *ProgressBar) Reset()
- func (p *ProgressBar) Set(num int) error
- func (p *ProgressBar) Set64(num int64) error
- func (p *ProgressBar) State() State
- func (p *ProgressBar) String() string
- func (p *ProgressBar) Write(b []byte) (n int, err error)
- type Reader
- type State
- type Theme
Examples ¶
- Package (XOutOfY)
- Default
- OptionClearOnFinish
- OptionSetPredictTime
- OptionSetRenderBlankState
- OptionShowBytes (Spinner)
- OptionShowCount (Minuscule)
- OptionShowDescriptionAtLineEnd
- OptionShowDescriptionAtLineEnd (Spinner)
- OptionShowIts
- OptionShowIts (Count)
- OptionShowIts (Spinner)
- OptionThrottle
- ProgressBar
- ProgressBar (Basic)
- ProgressBar (Invisible)
- ProgressBar.ChangeMax
- ProgressBar.Finish
- ProgressBar.Set
- ProgressBar.Set64
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Option ¶
type Option func(p *ProgressBar)
Option is the type all options need to adhere to
func OptionClearOnFinish ¶
func OptionClearOnFinish() Option
OptionClearOnFinish will clear the bar once its finished
Example ¶
bar := NewOptions(100, OptionSetWidth(10), OptionClearOnFinish()) bar.Reset() bar.Finish() fmt.Println("Finished")
Output: Finished
func OptionEnableColorCodes ¶
OptionEnableColorCodes enables or disables support for color codes using mitchellh/colorstring
func OptionFullWidth ¶ added in v3.3.0
func OptionFullWidth() Option
OptionFullWidth sets the bar to be full width
func OptionOnCompletion ¶
func OptionOnCompletion(cmpl func()) Option
OptionOnCompletion will invoke cmpl function once its finished
func OptionSetDescription ¶
OptionSetDescription sets the description of the bar to render in front of it
func OptionSetElapsedTime ¶ added in v3.9.0
OptionSetElapsedTime will enable elapsed time. Always enabled if OptionSetPredictTime is true.
func OptionSetItsString ¶ added in v3.4.0
OptionSetItsString sets what's displayed for iterations a second. The default is "it" which would display: "it/s"
func OptionSetPredictTime ¶
OptionSetPredictTime will also attempt to predict the time remaining.
Example ¶
bar := NewOptions(100, OptionSetWidth(10), OptionSetPredictTime(false)) _ = bar.Add(10)
Output: 10% |█ |
func OptionSetRenderBlankState ¶
OptionSetRenderBlankState sets whether or not to render a 0% bar on construction
Example ¶
NewOptions(10, OptionSetWidth(10), OptionSetRenderBlankState(true))
Output: 0% | | [0s:0s]
func OptionSetTheme ¶
OptionSetTheme sets the elements the bar is constructed of
func OptionSetVisibility ¶ added in v3.5.0
OptionSetVisibility sets the visibility
func OptionSetWriter ¶
OptionSetWriter sets the output writer (defaults to os.StdOut)
func OptionShowBytes ¶
OptionShowBytes will update the progress bar configuration settings to display/hide kBytes/Sec
Example (Spinner) ¶
/* Spinner test with iterations and count */ bar := NewOptions(-1, OptionSetWidth(10), OptionShowBytes(true), ) bar.Reset() time.Sleep(1 * time.Second) // since 10 is the width and we don't know the max bytes // it will do a infinite scrolling. bar.Add(11)
Output: - (11 B/s) [1s]
func OptionShowCount ¶
func OptionShowCount() Option
OptionShowCount will also print current count out of total
Example (Minuscule) ¶
bar := NewOptions(10000, OptionSetWidth(10), OptionShowCount(), OptionSetPredictTime(false)) bar.Add(1)
Output: 0% | | (1/10000)
func OptionShowDescriptionAtLineEnd ¶ added in v3.11.0
func OptionShowDescriptionAtLineEnd() Option
OptionShowDescriptionAtLineEnd defines whether description should be written at line end instead of line start
Example ¶
bar := NewOptions(100, OptionSetWidth(10), OptionShowDescriptionAtLineEnd(), OptionSetDescription("hello")) _ = bar.Add(10)
Output: 10% |█ | [0s:0s] hello
Example (Spinner) ¶
bar := NewOptions(-1, OptionSetWidth(10), OptionShowDescriptionAtLineEnd(), OptionSetDescription("hello")) _ = bar.Add(1)
Output: | [0s] hello
func OptionShowElapsedTimeOnFinish ¶ added in v3.10.0
func OptionShowElapsedTimeOnFinish() Option
OptionShowElapsedOnFinish will keep the display of elapsed time on finish
func OptionShowIts ¶
func OptionShowIts() Option
OptionShowIts will also print the iterations/second
Example ¶
bar := NewOptions(100, OptionSetWidth(10), OptionShowIts(), OptionSetPredictTime(false)) bar.Reset() time.Sleep(1 * time.Second) bar.Add(10)
Output: 10% |█ | (10 it/s)
Example (Count) ¶
bar := NewOptions(100, OptionSetWidth(10), OptionShowIts(), OptionShowCount()) bar.Reset() time.Sleep(1 * time.Second) bar.Add(10)
Output: 10% |█ | (10/100, 10 it/s) [1s:9s]
Example (Spinner) ¶
/* Spinner test with iteration count and iteration rate */ bar := NewOptions(-1, OptionSetWidth(10), OptionShowIts(), OptionShowCount(), ) bar.Reset() time.Sleep(1 * time.Second) bar.Add(5)
Output: - (5/-, 5 it/s) [1s]
func OptionSpinnerCustom ¶ added in v3.13.0
OptionSpinnerCustom sets the spinner used for indeterminate bars to the passed slice of string
func OptionSpinnerType ¶ added in v3.2.0
OptionSpinnerType sets the type of spinner used for indeterminate bars
func OptionThrottle ¶
OptionThrottle will wait the specified duration before updating again. The default duration is 0 seconds.
Example ¶
bar := NewOptions(100, OptionSetWidth(10), OptionThrottle(100*time.Millisecond)) bar.Reset() bar.Add(5) time.Sleep(150 * time.Millisecond) bar.Add(5) bar.Add(10)
Output: 10% |█ | [0s:1s]
func OptionUseANSICodes ¶ added in v3.7.0
OptionUseANSICodes will use more optimized terminal i/o.
Only useful in environments with support for ANSI escape sequences.
type ProgressBar ¶
type ProgressBar struct {
// contains filtered or unexported fields
}
ProgressBar is a thread-safe, simple progress bar
Example ¶
bar := New(100) bar.Add(10)
Output: 10% |████ | [0s:0s]
Example (Basic) ¶
bar := NewOptions(100, OptionSetWidth(10)) bar.Reset() time.Sleep(1 * time.Second) bar.Add(10)
Output: 10% |█ | [1s:9s]
Example (Invisible) ¶
bar := NewOptions(100, OptionSetWidth(10), OptionSetRenderBlankState(true), OptionSetVisibility(false)) bar.Reset() fmt.Println("hello, world") time.Sleep(1 * time.Second) bar.Add(10)
Output: hello, world
func Default ¶ added in v3.3.0
func Default(max int64, description ...string) *ProgressBar
Default provides a progressbar with recommended defaults. Set max to -1 to use as a spinner.
Example ¶
bar := Default(100) for i := 0; i < 50; i++ { bar.Add(1) time.Sleep(10 * time.Millisecond) }
Output:
func DefaultBytes ¶ added in v3.3.0
func DefaultBytes(maxBytes int64, description ...string) *ProgressBar
DefaultBytes provides a progressbar to measure byte throughput with recommended defaults. Set maxBytes to -1 to use as a spinner.
func DefaultBytesSilent ¶ added in v3.8.0
func DefaultBytesSilent(maxBytes int64, description ...string) *ProgressBar
DefaultBytesSilent is the same as DefaultBytes, but does not output anywhere. String() can be used to get the output instead.
func DefaultSilent ¶ added in v3.8.0
func DefaultSilent(max int64, description ...string) *ProgressBar
DefaultSilent is the same as Default, but does not output anywhere. String() can be used to get the output instead.
func New64 ¶
func New64(max int64) *ProgressBar
New64 returns a new ProgressBar with the specified maximum
func NewOptions ¶
func NewOptions(max int, options ...Option) *ProgressBar
NewOptions constructs a new instance of ProgressBar, with any options you specify
func NewOptions64 ¶
func NewOptions64(max int64, options ...Option) *ProgressBar
NewOptions64 constructs a new instance of ProgressBar, with any options you specify
func (*ProgressBar) Add ¶
func (p *ProgressBar) Add(num int) error
Add will add the specified amount to the progressbar
func (*ProgressBar) Add64 ¶
func (p *ProgressBar) Add64(num int64) error
Add64 will add the specified amount to the progressbar
func (*ProgressBar) ChangeMax ¶ added in v3.1.0
func (p *ProgressBar) ChangeMax(newMax int)
ChangeMax takes in a int and changes the max value of the progress bar
Example ¶
bar := NewOptions(100, OptionSetWidth(10), OptionSetPredictTime(false)) bar.ChangeMax(50) bar.Add(50)
Output: 100% |██████████|
func (*ProgressBar) ChangeMax64 ¶ added in v3.1.0
func (p *ProgressBar) ChangeMax64(newMax int64)
ChangeMax64 is basically the same as ChangeMax, but takes in a int64 to avoid casting
func (*ProgressBar) Clear ¶
func (p *ProgressBar) Clear() error
Clear erases the progress bar from the current line
func (*ProgressBar) Close ¶ added in v3.8.0
func (p *ProgressBar) Close() (err error)
func (*ProgressBar) Describe ¶
func (p *ProgressBar) Describe(description string)
Describe will change the description shown before the progress, which can be changed on the fly (as for a slow running process).
func (*ProgressBar) Exit ¶ added in v3.12.0
func (p *ProgressBar) Exit() error
Exit will exit the bar to keep current state
func (*ProgressBar) Finish ¶
func (p *ProgressBar) Finish() error
Finish will fill the bar to full
Example ¶
bar := NewOptions(100, OptionSetWidth(10)) bar.Finish()
Output: 100% |██████████|
func (*ProgressBar) GetMax64 ¶
func (p *ProgressBar) GetMax64() int64
GetMax64 returns the current max
func (*ProgressBar) IsFinished ¶ added in v3.6.0
func (p *ProgressBar) IsFinished() bool
IsFinished returns true if progress bar is completed
func (*ProgressBar) Read ¶
func (p *ProgressBar) Read(b []byte) (n int, err error)
Read implement io.Reader
func (*ProgressBar) RenderBlank ¶
func (p *ProgressBar) RenderBlank() error
RenderBlank renders the current bar state, you can use this to render a 0% state
func (*ProgressBar) Reset ¶
func (p *ProgressBar) Reset()
Reset will reset the clock that is used to calculate current time and the time left.
func (*ProgressBar) Set ¶
func (p *ProgressBar) Set(num int) error
Set will set the bar to a current number
Example ¶
bar := New(100) bar.Set(10)
Output: 10% |████ | [0s:0s]
func (*ProgressBar) Set64 ¶
func (p *ProgressBar) Set64(num int64) error
Set64 will set the bar to a current number
Example ¶
bar := New(100) bar.Set64(10)
Output: 10% |████ | [0s:0s]
func (*ProgressBar) String ¶ added in v3.8.0
func (p *ProgressBar) String() string
String returns the current rendered version of the progress bar. It will never return an empty string while the progress bar is running.
type Reader ¶
Reader is the progressbar io.Reader struct
func NewReader ¶ added in v3.6.2
func NewReader(r io.Reader, bar *ProgressBar) Reader
NewReader return a new Reader with a given progress bar.