From 20702b5af89e35b4b7e3f42796977b48ddb8c9dc Mon Sep 17 00:00:00 2001 From: Kyle Carberry Date: Tue, 29 Mar 2022 11:07:15 -0500 Subject: [PATCH] Add ForceOutput to write the spinner regardless of running in a TTY This isn't a breaking change, but relates to #131. --- spinner.go | 31 ++++++++++++++++--------------- 1 file changed, 16 insertions(+), 15 deletions(-) diff --git a/spinner.go b/spinner.go index f6bb029..137a7c7 100644 --- a/spinner.go +++ b/spinner.go @@ -174,20 +174,21 @@ func validColor(c string) bool { // Spinner struct to hold the provided options. type Spinner struct { - mu *sync.RWMutex - Delay time.Duration // Delay is the speed of the indicator - chars []string // chars holds the chosen character set - Prefix string // Prefix is the text preppended to the indicator - Suffix string // Suffix is the text appended to the indicator - FinalMSG string // string displayed after Stop() is called - lastOutput string // last character(set) written - color func(a ...interface{}) string // default color is white - Writer io.Writer // to make testing better, exported so users have access. Use `WithWriter` to update after initialization. - active bool // active holds the state of the spinner - stopChan chan struct{} // stopChan is a channel used to stop the indicator - HideCursor bool // hideCursor determines if the cursor is visible - PreUpdate func(s *Spinner) // will be triggered before every spinner update - PostUpdate func(s *Spinner) // will be triggered after every spinner update + mu *sync.RWMutex + Delay time.Duration // Delay is the speed of the indicator + chars []string // chars holds the chosen character set + Prefix string // Prefix is the text preppended to the indicator + Suffix string // Suffix is the text appended to the indicator + FinalMSG string // string displayed after Stop() is called + lastOutput string // last character(set) written + color func(a ...interface{}) string // default color is white + Writer io.Writer // to make testing better, exported so users have access. Use `WithWriter` to update after initialization. + active bool // active holds the state of the spinner + stopChan chan struct{} // stopChan is a channel used to stop the indicator + ForceOutput bool // ForceOutput outputs the spinner to the writer whether running in a TTY or not. + HideCursor bool // hideCursor determines if the cursor is visible + PreUpdate func(s *Spinner) // will be triggered before every spinner update + PostUpdate func(s *Spinner) // will be triggered after every spinner update } // New provides a pointer to an instance of Spinner with the supplied options. @@ -272,7 +273,7 @@ func (s *Spinner) Active() bool { // Start will start the indicator. func (s *Spinner) Start() { s.mu.Lock() - if s.active || !isRunningInTerminal() { + if !s.ForceOutput && (s.active || !isRunningInTerminal()) { s.mu.Unlock() return }