97 lines
3.0 KiB
PHP
97 lines
3.0 KiB
PHP
|
<?php
|
||
|
|
||
|
/*
|
||
|
* This file is part of the Symfony package.
|
||
|
*
|
||
|
* (c) Fabien Potencier <fabien@symfony.com>
|
||
|
*
|
||
|
* For the full copyright and license information, please view the LICENSE
|
||
|
* file that was distributed with this source code.
|
||
|
*/
|
||
|
|
||
|
namespace Symfony\Contracts\EventDispatcher;
|
||
|
|
||
|
use Psr\EventDispatcher\StoppableEventInterface;
|
||
|
|
||
|
if (interface_exists(StoppableEventInterface::class)) {
|
||
|
/**
|
||
|
* Event is the base class for classes containing event data.
|
||
|
*
|
||
|
* This class contains no event data. It is used by events that do not pass
|
||
|
* state information to an event handler when an event is raised.
|
||
|
*
|
||
|
* You can call the method stopPropagation() to abort the execution of
|
||
|
* further listeners in your event listener.
|
||
|
*
|
||
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||
|
* @author Jonathan Wage <jonwage@gmail.com>
|
||
|
* @author Roman Borschel <roman@code-factory.org>
|
||
|
* @author Bernhard Schussek <bschussek@gmail.com>
|
||
|
* @author Nicolas Grekas <p@tchwork.com>
|
||
|
*/
|
||
|
class Event implements StoppableEventInterface
|
||
|
{
|
||
|
private $propagationStopped = false;
|
||
|
|
||
|
/**
|
||
|
* Returns whether further event listeners should be triggered.
|
||
|
*/
|
||
|
public function isPropagationStopped(): bool
|
||
|
{
|
||
|
return $this->propagationStopped;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Stops the propagation of the event to further event listeners.
|
||
|
*
|
||
|
* If multiple event listeners are connected to the same event, no
|
||
|
* further event listener will be triggered once any trigger calls
|
||
|
* stopPropagation().
|
||
|
*/
|
||
|
public function stopPropagation(): void
|
||
|
{
|
||
|
$this->propagationStopped = true;
|
||
|
}
|
||
|
}
|
||
|
} else {
|
||
|
/**
|
||
|
* Event is the base class for classes containing event data.
|
||
|
*
|
||
|
* This class contains no event data. It is used by events that do not pass
|
||
|
* state information to an event handler when an event is raised.
|
||
|
*
|
||
|
* You can call the method stopPropagation() to abort the execution of
|
||
|
* further listeners in your event listener.
|
||
|
*
|
||
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||
|
* @author Jonathan Wage <jonwage@gmail.com>
|
||
|
* @author Roman Borschel <roman@code-factory.org>
|
||
|
* @author Bernhard Schussek <bschussek@gmail.com>
|
||
|
* @author Nicolas Grekas <p@tchwork.com>
|
||
|
*/
|
||
|
class Event
|
||
|
{
|
||
|
private $propagationStopped = false;
|
||
|
|
||
|
/**
|
||
|
* Returns whether further event listeners should be triggered.
|
||
|
*/
|
||
|
public function isPropagationStopped(): bool
|
||
|
{
|
||
|
return $this->propagationStopped;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Stops the propagation of the event to further event listeners.
|
||
|
*
|
||
|
* If multiple event listeners are connected to the same event, no
|
||
|
* further event listener will be triggered once any trigger calls
|
||
|
* stopPropagation().
|
||
|
*/
|
||
|
public function stopPropagation(): void
|
||
|
{
|
||
|
$this->propagationStopped = true;
|
||
|
}
|
||
|
}
|
||
|
}
|