use defer for ticker.

This commit is contained in:
Miroslav Šedivý 2021-08-19 21:19:02 +02:00
parent bdff2ddabe
commit 01c0f269ee
2 changed files with 7 additions and 10 deletions

View File

@ -40,14 +40,15 @@ func screencastNew(enabled bool, pipelineStr string) *ScreencastManagerCtx {
} }
go func() { go func() {
ticker := time.NewTicker(screencastTimeout)
manager.logger.Debug().Msg("started emitting samples") manager.logger.Debug().Msg("started emitting samples")
ticker := time.NewTicker(screencastTimeout)
defer ticker.Stop()
for { for {
select { select {
case <-manager.emitStop: case <-manager.emitStop:
manager.logger.Debug().Msg("stopped emitting samples") manager.logger.Debug().Msg("stopped emitting samples")
ticker.Stop()
return return
case <-manager.emitUpdate: case <-manager.emitUpdate:
manager.logger.Debug().Msg("update emitting samples") manager.logger.Debug().Msg("update emitting samples")

View File

@ -18,7 +18,6 @@ var mu = sync.Mutex{}
type DesktopManagerCtx struct { type DesktopManagerCtx struct {
logger zerolog.Logger logger zerolog.Logger
cleanup *time.Ticker
shutdown chan bool shutdown chan bool
emmiter events.EventEmmiter emmiter events.EventEmmiter
config *config.Desktop config *config.Desktop
@ -27,7 +26,6 @@ type DesktopManagerCtx struct {
func New(config *config.Desktop) *DesktopManagerCtx { func New(config *config.Desktop) *DesktopManagerCtx {
return &DesktopManagerCtx{ return &DesktopManagerCtx{
logger: log.With().Str("module", "desktop").Logger(), logger: log.With().Str("module", "desktop").Logger(),
cleanup: time.NewTicker(1 * time.Second),
shutdown: make(chan bool), shutdown: make(chan bool),
emmiter: events.New(), emmiter: events.New(),
config: config, config: config,
@ -64,16 +62,15 @@ func (manager *DesktopManagerCtx) Start() {
}) })
go func() { go func() {
defer func() { ticker := time.NewTicker(1 * time.Second)
xorg.DisplayClose() defer ticker.Stop()
manager.logger.Info().Msg("shutdown")
}()
for { for {
select { select {
case <-manager.shutdown: case <-manager.shutdown:
xorg.DisplayClose()
return return
case <-manager.cleanup.C: case <-ticker.C:
xorg.CheckKeys(time.Second * 10) xorg.CheckKeys(time.Second * 10)
} }
} }
@ -95,7 +92,6 @@ func (manager *DesktopManagerCtx) OnAfterScreenSizeChange(listener func()) {
func (manager *DesktopManagerCtx) Shutdown() error { func (manager *DesktopManagerCtx) Shutdown() error {
manager.logger.Info().Msgf("desktop shutting down") manager.logger.Info().Msgf("desktop shutting down")
manager.cleanup.Stop()
manager.shutdown <- true manager.shutdown <- true
return nil return nil
} }