Skip to content

Commit

Permalink
add support for print text during render progress bar
Browse files Browse the repository at this point in the history
  • Loading branch information
unkmonster committed Aug 2, 2024
1 parent a47c25c commit 17dc9f7
Showing 1 changed file with 21 additions and 0 deletions.
21 changes: 21 additions & 0 deletions progressbar.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package progressbar

import (
"bytes"
"errors"
"fmt"
"io"
Expand Down Expand Up @@ -121,6 +122,8 @@ type config struct {

// showDescriptionAtLineEnd specifies whether description should be written at line end instead of line start
showDescriptionAtLineEnd bool

stdBuffer bytes.Buffer
}

// Theme defines the elements of the bar
Expand Down Expand Up @@ -689,6 +692,7 @@ func (p *ProgressBar) render() error {
if !p.state.finished && p.state.currentNum >= p.config.max {
p.state.finished = true
if !p.config.clearOnFinish {
io.Copy(p.config.writer, &p.config.stdBuffer)
renderProgressBar(p.config, &p.state)
}
if p.config.onCompletion != nil {
Expand All @@ -707,6 +711,7 @@ func (p *ProgressBar) render() error {
}

// then, re-render the current progress bar
io.Copy(p.config.writer, &p.config.stdBuffer)
w, err := renderProgressBar(p.config, &p.state)
if err != nil {
return err
Expand Down Expand Up @@ -1142,3 +1147,19 @@ var termWidth = func() (width int, err error) {

return 0, err
}

func Bprintln(pb *ProgressBar, a ...interface{}) (int, error) {
if pb.state.finished {
return fmt.Fprintln(pb.config.writer, a...)
} else {
return fmt.Fprintln(&pb.config.stdBuffer, a...)
}
}

func Bprintf(pb *ProgressBar, format string, a ...interface{}) (int, error) {
if pb.state.finished {
return fmt.Fprintf(pb.config.writer, format, a...)
} else {
return fmt.Fprintf(&pb.config.stdBuffer, format, a...)
}
}

0 comments on commit 17dc9f7

Please sign in to comment.