Compare commits
31 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 6a6096ea11 | |||
| b2a89a6f72 | |||
| c08c1731d1 | |||
| 846e195efa | |||
| 85df6626c1 | |||
| 79f430d898 | |||
| 7f5c4127e1 | |||
| f22a2a70b6 | |||
| 4ec09dcafd | |||
| 34bae8fc44 | |||
| 04d2d3094b | |||
| ca5ce86ee3 | |||
| a6e5c46844 | |||
| 30e9b3e51d | |||
| e035b6248e | |||
| 0e4d0efdb3 | |||
| 64d4767a66 | |||
| e56458f2dc | |||
| 29410876e1 | |||
| f22d8463e3 | |||
| af3ed4a235 | |||
| ffefd79006 | |||
| d96aec90b7 | |||
| 9580aebffd | |||
| 745308577d | |||
| 6bc22c92a5 | |||
| 3bb1398e31 | |||
| af647afb93 | |||
| acce084300 | |||
| 38f6830190 | |||
| a44cfb70b1 |
+1
-1
@@ -12,6 +12,6 @@ namespace PHPSTORM_META {
|
|||||||
// override(\make(0), map('@'));
|
// override(\make(0), map('@'));
|
||||||
override(\di(0), map('@'));
|
override(\di(0), map('@'));
|
||||||
override(\duplicate(0), map('@'));
|
override(\duplicate(0), map('@'));
|
||||||
override(Context::getContext(0), map('@'));
|
override(Context::get(0), map('@'));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
+27
-23
@@ -1,13 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
namespace Kiri\Events;
|
namespace Kiri\Events;
|
||||||
|
|
||||||
use Kiri;
|
|
||||||
use Kiri\Abstracts\Component;
|
use Kiri\Abstracts\Component;
|
||||||
use Psr\Container\ContainerExceptionInterface;
|
|
||||||
use Psr\Container\NotFoundExceptionInterface;
|
|
||||||
use Psr\EventDispatcher\EventDispatcherInterface;
|
use Psr\EventDispatcher\EventDispatcherInterface;
|
||||||
use Psr\EventDispatcher\StoppableEventInterface;
|
use Psr\EventDispatcher\StoppableEventInterface;
|
||||||
|
use SplPriorityQueue;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -18,32 +17,37 @@ class EventDispatch extends Component implements EventDispatcherInterface
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param EventProvider $eventProvider
|
* @param object $event
|
||||||
* @param array $config
|
* @return object
|
||||||
* @throws \Exception
|
*/
|
||||||
*/
|
public function dispatch(object $event): object
|
||||||
public function __construct(public EventProvider $eventProvider, array $config = [])
|
|
||||||
{
|
{
|
||||||
parent::__construct($config);
|
$lists = make(EventProvider::class)->getListenersForEvent($event);
|
||||||
|
|
||||||
|
return $this->execute($lists, $event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param object $event
|
* @param SplPriorityQueue $lists
|
||||||
* @return object
|
* @param object $event
|
||||||
* @throws ContainerExceptionInterface
|
* @return object
|
||||||
* @throws NotFoundExceptionInterface
|
*/
|
||||||
*/
|
public function execute(SplPriorityQueue $lists, object $event): object
|
||||||
public function dispatch(object $event): object
|
|
||||||
{
|
{
|
||||||
$lists = $this->eventProvider->getListenersForEvent($event);
|
if ($lists->isEmpty()) {
|
||||||
foreach ($lists as $listener) {
|
return $event;
|
||||||
/** @var Struct $list */
|
|
||||||
$listener($event);
|
|
||||||
if ($event instanceof StoppableEventInterface && $event->isPropagationStopped()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
foreach ($lists as $item) {
|
||||||
|
try {
|
||||||
|
call_user_func($item, $event);
|
||||||
|
} catch (\Throwable $exception) {
|
||||||
|
\Kiri::getLogger()->json_log($exception);
|
||||||
|
}
|
||||||
|
if ($event instanceof StoppableEventInterface && $event->isPropagationStopped()) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
return $event;
|
return $event;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,14 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kiri\Events;
|
||||||
|
|
||||||
|
interface EventInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param object $event
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function process(object $event): void;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,39 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kiri\Events;
|
||||||
|
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
use Kiri\Di\Interface\InjectTargetInterface;
|
||||||
|
|
||||||
|
#[\Attribute]
|
||||||
|
readonly class EventListener implements InjectTargetInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $event
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public function __construct(public string $event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $class
|
||||||
|
* @return void
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public function dispatch(string $class): void
|
||||||
|
{
|
||||||
|
// TODO: Implement dispatch() method.
|
||||||
|
$target = \Kiri::getDi()->getReflectionClass($class)->newInstanceWithoutConstructor();
|
||||||
|
|
||||||
|
if (!($target instanceof EventInterface)) {
|
||||||
|
throw new Exception("Event listen must implement " . EventInterface::class);
|
||||||
|
}
|
||||||
|
on($this->event, [$target, "process"]);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
+44
-36
@@ -1,9 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
namespace Kiri\Events;
|
namespace Kiri\Events;
|
||||||
|
|
||||||
|
|
||||||
|
use Closure;
|
||||||
use Psr\EventDispatcher\ListenerProviderInterface;
|
use Psr\EventDispatcher\ListenerProviderInterface;
|
||||||
|
use SplPriorityQueue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@@ -11,49 +14,54 @@ use Psr\EventDispatcher\ListenerProviderInterface;
|
|||||||
class EventProvider implements ListenerProviderInterface
|
class EventProvider implements ListenerProviderInterface
|
||||||
{
|
{
|
||||||
|
|
||||||
/** @var Struct[] */
|
/** @var Struct[] */
|
||||||
private array $_listeners = [];
|
private array $_listeners = [];
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param object $event
|
* @param object $event
|
||||||
* @return iterable
|
* @return SplPriorityQueue
|
||||||
*/
|
*/
|
||||||
public function getListenersForEvent(object $event): iterable
|
public function getListenersForEvent(object $event): SplPriorityQueue
|
||||||
{
|
{
|
||||||
$queue = new \SplPriorityQueue();
|
$queue = new SplPriorityQueue();
|
||||||
// TODO: Implement getListenersForEvent() method.
|
$queue->setExtractFlags(SplPriorityQueue::EXTR_DATA);
|
||||||
foreach ($this->_listeners[get_class($event)] ?? [] as $listener) {
|
// TODO: Implement getListenersForEvent() method.
|
||||||
$queue->insert($listener->listener, $listener->priority);
|
foreach ($this->_listeners[get_class($event)] ?? [] as $listener) {
|
||||||
}
|
$queue->insert($listener->listener, $listener->priority);
|
||||||
return $queue;
|
}
|
||||||
}
|
return $queue;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $event
|
* @param string $event
|
||||||
* @param callable $handler
|
* @param array|Closure|string $handler
|
||||||
* @param int $zOrder
|
* @param int $zOrder
|
||||||
*/
|
* @throws
|
||||||
public function on(string $event, callable $handler, int $zOrder = 1)
|
*/
|
||||||
{
|
public function on(string $event, array|Closure|string $handler, int $zOrder = 1): void
|
||||||
$this->_listeners[$event][] = new Struct($event, $handler, $zOrder);
|
{
|
||||||
}
|
if (is_string($handler) && !is_callable($handler, true)) {
|
||||||
|
throw new \Exception('Event handler must is execute function.');
|
||||||
|
}
|
||||||
|
$this->_listeners[$event][] = new Struct($event, $handler, $zOrder);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $event
|
* @param string $event
|
||||||
* @param callable $handler
|
* @param callable $handler
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function off(string $event, callable $handler)
|
public function off(string $event, callable $handler): void
|
||||||
{
|
{
|
||||||
$events = $this->_listeners[$event] ?? [];
|
$events = $this->_listeners[$event] ?? [];
|
||||||
|
|
||||||
$this->_listeners[$event] = array_filter($events, function ($value) use ($handler) {
|
$this->_listeners[$event] = array_filter($events, function ($value) use ($handler) {
|
||||||
return $value->listener !== $handler;
|
return $value->listener !== $handler;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
+8
-2
@@ -12,11 +12,17 @@ class Struct
|
|||||||
|
|
||||||
public string $event;
|
public string $event;
|
||||||
|
|
||||||
public array|\Closure $listener;
|
public array|\Closure|string $listener;
|
||||||
|
|
||||||
public int $priority;
|
public int $priority;
|
||||||
|
|
||||||
public function __construct(string $event, callable $listener, int $priority)
|
|
||||||
|
/**
|
||||||
|
* @param string $event
|
||||||
|
* @param array|\Closure|string $listener
|
||||||
|
* @param int $priority
|
||||||
|
*/
|
||||||
|
public function __construct(string $event, array|\Closure|string $listener, int $priority)
|
||||||
{
|
{
|
||||||
$this->event = $event;
|
$this->event = $event;
|
||||||
$this->listener = $listener;
|
$this->listener = $listener;
|
||||||
|
|||||||
@@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kiri\Events;
|
||||||
|
|
||||||
|
class TestListener implements EventInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param object $event
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function process(object $event): void
|
||||||
|
{
|
||||||
|
// TODO: Implement process() method.
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
+1
-1
@@ -9,7 +9,7 @@
|
|||||||
],
|
],
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"require": {
|
"require": {
|
||||||
"php": ">=8.0",
|
"php": ">=8.5",
|
||||||
"psr/event-dispatcher": "^1.0"
|
"psr/event-dispatcher": "^1.0"
|
||||||
},
|
},
|
||||||
"autoload": {
|
"autoload": {
|
||||||
|
|||||||
Reference in New Issue
Block a user