mirror of
https://github.com/torrentpier/torrentpier-lts.git
synced 2025-03-01 15:21:02 +03:00
145 lines
4.1 KiB
PHP
145 lines
4.1 KiB
PHP
<?php
|
|
/**
|
|
* Zend Framework (http://framework.zend.com/)
|
|
*
|
|
* @link http://github.com/zendframework/zf2 for the canonical source repository
|
|
* @copyright Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
*/
|
|
|
|
namespace Zend\EventManager;
|
|
|
|
use Traversable;
|
|
use Zend\Stdlib\CallbackHandler;
|
|
|
|
/**
|
|
* Interface for messengers
|
|
*/
|
|
interface EventManagerInterface extends SharedEventManagerAwareInterface
|
|
{
|
|
/**
|
|
* Trigger an event
|
|
*
|
|
* Should allow handling the following scenarios:
|
|
* - Passing Event object only
|
|
* - Passing event name and Event object only
|
|
* - Passing event name, target, and Event object
|
|
* - Passing event name, target, and array|ArrayAccess of arguments
|
|
*
|
|
* Can emulate triggerUntil() if the last argument provided is a callback.
|
|
*
|
|
* @param string $event
|
|
* @param object|string $target
|
|
* @param array|object $argv
|
|
* @param null|callable $callback
|
|
* @return ResponseCollection
|
|
*/
|
|
public function trigger($event, $target = null, $argv = array(), $callback = null);
|
|
|
|
/**
|
|
* Trigger an event until the given callback returns a boolean true
|
|
*
|
|
* Should allow handling the following scenarios:
|
|
* - Passing Event object and callback only
|
|
* - Passing event name, Event object, and callback only
|
|
* - Passing event name, target, Event object, and callback
|
|
* - Passing event name, target, array|ArrayAccess of arguments, and callback
|
|
*
|
|
* @param string $event
|
|
* @param object|string $target
|
|
* @param array|object $argv
|
|
* @param callable $callback
|
|
* @return ResponseCollection
|
|
*/
|
|
public function triggerUntil($event, $target, $argv = null, $callback = null);
|
|
|
|
/**
|
|
* Attach a listener to an event
|
|
*
|
|
* @param string $event
|
|
* @param callable $callback
|
|
* @param int $priority Priority at which to register listener
|
|
* @return CallbackHandler
|
|
*/
|
|
public function attach($event, $callback = null, $priority = 1);
|
|
|
|
/**
|
|
* Detach an event listener
|
|
*
|
|
* @param CallbackHandler|ListenerAggregateInterface $listener
|
|
* @return bool
|
|
*/
|
|
public function detach($listener);
|
|
|
|
/**
|
|
* Get a list of events for which this collection has listeners
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getEvents();
|
|
|
|
/**
|
|
* Retrieve a list of listeners registered to a given event
|
|
*
|
|
* @param string $event
|
|
* @return array|object
|
|
*/
|
|
public function getListeners($event);
|
|
|
|
/**
|
|
* Clear all listeners for a given event
|
|
*
|
|
* @param string $event
|
|
* @return void
|
|
*/
|
|
public function clearListeners($event);
|
|
|
|
/**
|
|
* Set the event class to utilize
|
|
*
|
|
* @param string $class
|
|
* @return EventManagerInterface
|
|
*/
|
|
public function setEventClass($class);
|
|
|
|
/**
|
|
* Get the identifier(s) for this EventManager
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getIdentifiers();
|
|
|
|
/**
|
|
* Set the identifiers (overrides any currently set identifiers)
|
|
*
|
|
* @param string|int|array|Traversable $identifiers
|
|
* @return EventManagerInterface
|
|
*/
|
|
public function setIdentifiers($identifiers);
|
|
|
|
/**
|
|
* Add some identifier(s) (appends to any currently set identifiers)
|
|
*
|
|
* @param string|int|array|Traversable $identifiers
|
|
* @return EventManagerInterface
|
|
*/
|
|
public function addIdentifiers($identifiers);
|
|
|
|
/**
|
|
* Attach a listener aggregate
|
|
*
|
|
* @param ListenerAggregateInterface $aggregate
|
|
* @param int $priority If provided, a suggested priority for the aggregate to use
|
|
* @return mixed return value of {@link ListenerAggregateInterface::attach()}
|
|
*/
|
|
public function attachAggregate(ListenerAggregateInterface $aggregate, $priority = 1);
|
|
|
|
/**
|
|
* Detach a listener aggregate
|
|
*
|
|
* @param ListenerAggregateInterface $aggregate
|
|
* @return mixed return value of {@link ListenerAggregateInterface::detach()}
|
|
*/
|
|
public function detachAggregate(ListenerAggregateInterface $aggregate);
|
|
}
|