module Athena::EventDispatcher::StoppableEvent
#
An AED::Event
whose processing may be interrupted when the event has been handled.
AED::EventDispatcherInterface
implementations MUST check to determine if an AED::Event
is marked as stopped after each listener is called.
If it is, then the dispatcher should return immediately without calling any further listeners.
class MyEvent < AED::Event; end
dispatcher = AED::EventDispatcher.new
dispatcher.listener(MyEvent) { pp "callback1" }
dispatcher.listener(MyEvent) { |e| pp "callback2"; e.stop_propagation }
dispatcher.listener(MyEvent) { pp "callback3" }
dispatcher.dispatch MyEvent.new
# =>
# "callback1"
# "callback2"
Direct including types
Athena::EventDispatcher::Event
Methods#
#propagate? : Bool
#
If future listeners should be executed.
#stop_propagation : Nil
#
Prevent future listeners from executing once any listener calls #stop_propagation
.