Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Manager ¶
type Manager interface { // Subscribe subscribes a handler to an event type with a priority // and returns a func that can be run to unsubscribe the handler. // // HandlerFunc should return as soon as possible and start long-running tasks in parallel. // The Type can be any type, pointer to type or reflect.Type and the handler is only run for // the exact type subscribed for. // // HandlerFunc always gets the fired event of the same subscribed eventType or the same type as // represented by reflect.Type. Subscribe(eventType any, priority int, fn HandlerFunc) (unsubscribe func()) // Fire fires an event in the calling goroutine and returns after all subscribers are complete handling it. // Any panic by a subscriber is caught so firing the event to the next subscriber can proceed. Fire(Event) // FireParallel fires an event in a new goroutine B and returns immediately. // It optionally runs handlers in goroutine B after all subscribers are done and passes // the potentially modified version of the fired event. // If an "after" handler returns false or panics no further handlers in the slice are run. FireParallel(event Event, after ...HandlerFunc) // Wait blocks until no event handlers are running. Wait() // HasSubscribers determines whether the given event has any subscribers. HasSubscribers(event Event) bool }
Manager is an event manager to subscribe, fire events and decouple the event source and sink in a complex system.
var Nop Manager = &nopMgr{}
Nop is an event Manager that does nothing.
Click to show internal directories.
Click to hide internal directories.