mirror of
https://github.com/optim-enterprises-bv/kubernetes.git
synced 2025-11-02 19:28:16 +00:00
54 lines
1.1 KiB
Go
54 lines
1.1 KiB
Go
package clockwork
|
|
|
|
import "time"
|
|
|
|
// Timer provides an interface which can be used instead of directly using
|
|
// [time.Timer]. The real-time timer t provides events through t.C which becomes
|
|
// t.Chan() to make this channel requirement definable in this interface.
|
|
type Timer interface {
|
|
Chan() <-chan time.Time
|
|
Reset(d time.Duration) bool
|
|
Stop() bool
|
|
}
|
|
|
|
type realTimer struct{ *time.Timer }
|
|
|
|
func (r realTimer) Chan() <-chan time.Time {
|
|
return r.C
|
|
}
|
|
|
|
type fakeTimer struct {
|
|
firer
|
|
|
|
// reset and stop provide the implmenetation of the respective exported
|
|
// functions.
|
|
reset func(d time.Duration) bool
|
|
stop func() bool
|
|
|
|
// If present when the timer fires, the timer calls afterFunc in its own
|
|
// goroutine rather than sending the time on Chan().
|
|
afterFunc func()
|
|
}
|
|
|
|
func (f *fakeTimer) Reset(d time.Duration) bool {
|
|
return f.reset(d)
|
|
}
|
|
|
|
func (f *fakeTimer) Stop() bool {
|
|
return f.stop()
|
|
}
|
|
|
|
func (f *fakeTimer) expire(now time.Time) *time.Duration {
|
|
if f.afterFunc != nil {
|
|
go f.afterFunc()
|
|
return nil
|
|
}
|
|
|
|
// Never block on expiration.
|
|
select {
|
|
case f.c <- now:
|
|
default:
|
|
}
|
|
return nil
|
|
}
|