diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-10 20:01:15 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-10 20:01:15 +0200 |
| commit | 71e431af2e65196ad4e7bc3404e772b1726d3338 (patch) | |
| tree | 935e3b1af7c5b0033caf13ea00cf9655686b6ec9 /internal/clients/stats.go | |
| parent | f6e23930da2900c43a5389a2e7d1e38d8221a76f (diff) | |
Introduce client runtime boundaries
Diffstat (limited to 'internal/clients/stats.go')
| -rw-r--r-- | internal/clients/stats.go | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/internal/clients/stats.go b/internal/clients/stats.go index 5880fd1..1ce04e6 100644 --- a/internal/clients/stats.go +++ b/internal/clients/stats.go @@ -8,8 +8,6 @@ import ( "sync" "time" - "github.com/mimecast/dtail/internal/color" - "github.com/mimecast/dtail/internal/config" "github.com/mimecast/dtail/internal/io/dlog" "github.com/mimecast/dtail/internal/protocol" ) @@ -24,13 +22,22 @@ type stats struct { connected int // To synchronize concurrent access. mutex sync.Mutex + // Formats interrupt-driven stats output. + formatter interruptMessageFormatter + // Controls how long interrupt output remains visible. + interruptPause time.Duration } -func newTailStats(servers int) *stats { +func newTailStats(servers int, formatter interruptMessageFormatter, interruptPause time.Duration) *stats { + if interruptPause <= 0 { + interruptPause = 3 * time.Second + } return &stats{ servers: servers, connectionsEstCh: make(chan struct{}, servers), connected: 0, + formatter: formatter, + interruptPause: interruptPause, } } @@ -84,17 +91,13 @@ func (s *stats) Start(ctx context.Context, throttleCh <-chan struct{}, func (s *stats) printStatsDueInterrupt(messages []string) { dlog.Client.Pause() for i, message := range messages { - if i > 0 && config.Client.TermColorsEnable { - fmt.Println(color.PaintStrWithAttr(message, - config.Client.TermColors.Client.ClientFg, - config.Client.TermColors.Client.ClientBg, - config.Client.TermColors.Client.ClientAttr, - )) + if s.formatter != nil { + fmt.Println(s.formatter.FormatInterruptMessage(i, message)) continue } fmt.Printf(" %s\n", message) } - time.Sleep(time.Second * time.Duration(config.InterruptTimeoutS)) + time.Sleep(s.interruptPause) dlog.Client.Resume() } |
