moebius/events

Event emitter implementation for Moebius

1.0.0 2022-06-24 14:17 UTC

This package is not auto-updated.

Last update: 2024-04-27 20:52:46 UTC


README

A simple event emitter implementation for Moebius. Provides interfaces and traits for event emitters.

Listener API

  • EventEmitterInterface::on( string $eventName, callable $handler ) Subscribe to an event.

  • EventEmitterInterface::off( string $eventName = null, callable $handler = null ) Unsubscribe from an event.

  • EventEmitterInterface::emit( EventInterface|string $eventName, mixed ...$arguments) Emit an event. You can emit either an EventInterface object, or a named event with any number of argumnents.

Static Event Emitters

In some circumstances you want to subscribe to events from objects that don't exist yet. This is enabled by the static event emitter.

  • StaticEventEmitterInterface::events(): EventEmitterInterface

This particular event emitter will take into account which class you're subscribed to, in the PHP class hierarchy. So if you subscribe to a root class, you will receive events from all extending classes that emit events as well. If you subscribe to a child class, you will not receive events emitted higher up in the class hierarchy.