From 17dc9f7ef37c9c2ae3d9b4e2bd16dc07f95953af Mon Sep 17 00:00:00 2001 From: unkmonster <106185616+unkmonster@users.noreply.github.com> Date: Fri, 2 Aug 2024 14:31:39 +0800 Subject: [PATCH] add support for print text during render progress bar --- progressbar.go | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/progressbar.go b/progressbar.go index e3bd67b..55e5144 100644 --- a/progressbar.go +++ b/progressbar.go @@ -1,6 +1,7 @@ package progressbar import ( + "bytes" "errors" "fmt" "io" @@ -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 @@ -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 { @@ -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 @@ -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...) + } +}