// +build !windows
package mpb
import (
"fmt"
"os"
"os/signal"
"syscall"
"time"
"github.com/vbauerster/mpb/cwriter"
)
func (p *Progress) serve(s *pState) {
winch := make(chan os.Signal, 2)
signal.Notify(winch, syscall.SIGWINCH)
var numP, numA int
var timer *time.Timer
var tickerResumer <-chan time.Time
resumeDelay := s.rr * 2
for {
select {
case op := <-p.operateState:
op(s)
case <-s.ticker.C:
if s.zeroWait {
s.ticker.Stop()
signal.Stop(winch)
if s.shutdownNotifier != nil {
close(s.shutdownNotifier)
}
close(p.done)
return
}
if s.heapUpdated {
numP = s.bHeap.maxNumP()
numA = s.bHeap.maxNumA()
s.heapUpdated = false
}
tw, _, _ := cwriter.TermSize()
err := s.writeAndFlush(tw, numP, numA)
if err != nil {
fmt.Fprintf(s.debugOut, "%s %s %v\n", "[mpb]", time.Now(), err)
}
case <-winch:
if s.heapUpdated {
numP = s.bHeap.maxNumP()
numA = s.bHeap.maxNumA()
s.heapUpdated = false
}
tw, _, _ := cwriter.TermSize()
err := s.writeAndFlush(tw-tw/8, numP, numA)
if err != nil {
fmt.Fprintf(s.debugOut, "%s %s %v\n", "[mpb]", time.Now(), err)
}
if timer != nil && timer.Reset(resumeDelay) {
break
}
s.ticker.Stop()
timer = time.NewTimer(resumeDelay)
tickerResumer = timer.C
case <-tickerResumer:
s.ticker = time.NewTicker(s.rr)
tickerResumer = nil
timer = nil
}
}
}