Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 100ce506ea | |||
| a4c50f975e | |||
| f7630a4c2a | |||
| bf3182660b | |||
| df7b50563f | |||
| b5f20d7d4b | |||
| 244e84772e | |||
| 9529907710 |
+34
-34
@@ -1,34 +1,34 @@
|
|||||||
# Created by .ignore support plugin (hsz.mobi)
|
# Created by .ignore support plugin (hsz.mobi)
|
||||||
### Yii template
|
### Yii template
|
||||||
assets/*
|
assets/*
|
||||||
!assets/.gitignore
|
!assets/.gitignore
|
||||||
protected/runtime/*
|
protected/runtime/*
|
||||||
!protected/runtime/.gitignore
|
!protected/runtime/.gitignore
|
||||||
protected/data/*.db
|
protected/data/*.db
|
||||||
themes/classic/views/
|
themes/classic/views/
|
||||||
|
|
||||||
### Example user template template
|
### Example user template template
|
||||||
### Example user template
|
### Example user template
|
||||||
|
|
||||||
# IntelliJ project files
|
# IntelliJ project files
|
||||||
.idea
|
.idea
|
||||||
*.iml
|
*.iml
|
||||||
out
|
out
|
||||||
gen
|
gen
|
||||||
|
|
||||||
composer.lock
|
composer.lock
|
||||||
|
|
||||||
*.log
|
*.log
|
||||||
commands/result
|
commands/result
|
||||||
config/setting.php
|
config/setting.php
|
||||||
tests/
|
tests/
|
||||||
vendor/
|
vendor/
|
||||||
runtime/
|
runtime/
|
||||||
|
|
||||||
*.xml
|
*.xml
|
||||||
*.lock
|
*.lock
|
||||||
|
|
||||||
oot
|
oot
|
||||||
d
|
d
|
||||||
|
|
||||||
composer.lock
|
composer.lock
|
||||||
|
|||||||
+17
-17
@@ -1,17 +1,17 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace PHPSTORM_META {
|
namespace PHPSTORM_META {
|
||||||
|
|
||||||
// Reflect
|
// Reflect
|
||||||
use Http\Context\Context;
|
use Kiri\Message\Context\Context;
|
||||||
use Kiri\Di\Container;
|
use Kiri\Di\Container;
|
||||||
|
|
||||||
override(Container::get(0), map('@'));
|
override(Container::get(0), map('@'));
|
||||||
override(Container::newObject(0), map('@'));
|
override(Container::newObject(0), map('@'));
|
||||||
// override(\Hyperf\Utils\Context::get(0), map('@'));
|
// override(\Hyperf\Utils\Context::get(0), map('@'));
|
||||||
// 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::getContext(0), map('@'));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
+51
-37
@@ -1,37 +1,51 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Kiri\Events;
|
namespace Kiri\Events;
|
||||||
|
|
||||||
use Kiri\Abstracts\Component;
|
use Kiri;
|
||||||
use Kiri\Kiri;
|
use Kiri\Abstracts\Component;
|
||||||
use Psr\EventDispatcher\EventDispatcherInterface;
|
use Psr\Container\ContainerExceptionInterface;
|
||||||
use Psr\EventDispatcher\StoppableEventInterface;
|
use Psr\Container\NotFoundExceptionInterface;
|
||||||
|
use Psr\EventDispatcher\EventDispatcherInterface;
|
||||||
|
use Psr\EventDispatcher\StoppableEventInterface;
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
/**
|
||||||
class EventDispatch extends Component implements EventDispatcherInterface
|
*
|
||||||
{
|
*/
|
||||||
|
class EventDispatch extends Component implements EventDispatcherInterface
|
||||||
|
{
|
||||||
/**
|
|
||||||
* @param object $event
|
|
||||||
* @return object
|
/**
|
||||||
* @throws \ReflectionException
|
* @param EventProvider $eventProvider
|
||||||
*/
|
* @param array $config
|
||||||
public function dispatch(object $event): object
|
* @throws \Exception
|
||||||
{
|
*/
|
||||||
$lists = $this->eventProvider->getListenersForEvent($event);
|
public function __construct(public EventProvider $eventProvider, array $config = [])
|
||||||
foreach ($lists as $listener) {
|
{
|
||||||
/** @var Struct $list */
|
parent::__construct($config);
|
||||||
$listener($event);
|
}
|
||||||
if ($event instanceof StoppableEventInterface && $event->isPropagationStopped()) {
|
|
||||||
break;
|
|
||||||
}
|
/**
|
||||||
}
|
* @param object $event
|
||||||
return $event;
|
* @return object
|
||||||
}
|
* @throws ContainerExceptionInterface
|
||||||
|
* @throws NotFoundExceptionInterface
|
||||||
|
*/
|
||||||
}
|
public function dispatch(object $event): object
|
||||||
|
{
|
||||||
|
$lists = $this->eventProvider->getListenersForEvent($event);
|
||||||
|
foreach ($lists as $listener) {
|
||||||
|
/** @var Struct $list */
|
||||||
|
$listener($event);
|
||||||
|
if ($event instanceof StoppableEventInterface && $event->isPropagationStopped()) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $event;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|||||||
+59
-44
@@ -1,44 +1,59 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Kiri\Events;
|
namespace Kiri\Events;
|
||||||
|
|
||||||
|
|
||||||
use Psr\EventDispatcher\ListenerProviderInterface;
|
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 iterable
|
||||||
*/
|
*/
|
||||||
public function getListenersForEvent(object $event): iterable
|
public function getListenersForEvent(object $event): iterable
|
||||||
{
|
{
|
||||||
$queue = new \SplPriorityQueue();
|
$queue = new \SplPriorityQueue();
|
||||||
// TODO: Implement getListenersForEvent() method.
|
// TODO: Implement getListenersForEvent() method.
|
||||||
foreach ($this->_listeners[get_class($event)] ?? [] as $listener) {
|
foreach ($this->_listeners[get_class($event)] ?? [] as $listener) {
|
||||||
$queue->insert($listener->listener, $listener->priority);
|
$queue->insert($listener->listener, $listener->priority);
|
||||||
}
|
}
|
||||||
return $queue;
|
return $queue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $event
|
* @param string $event
|
||||||
* @param callable $handler
|
* @param callable $handler
|
||||||
* @param int $zOrder
|
* @param int $zOrder
|
||||||
*/
|
*/
|
||||||
public function on(string $event, callable $handler, int $zOrder = 1)
|
public function on(string $event, callable $handler, int $zOrder = 1)
|
||||||
{
|
{
|
||||||
$this->_listeners[$event][] = new Struct($event, $handler, $zOrder);
|
$this->_listeners[$event][] = new Struct($event, $handler, $zOrder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
/**
|
||||||
|
* @param string $event
|
||||||
|
* @param callable $handler
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function off(string $event, callable $handler)
|
||||||
|
{
|
||||||
|
$events = $this->_listeners[$event] ?? [];
|
||||||
|
|
||||||
|
$this->_listeners[$event] = array_filter($events, function ($value) use ($handler) {
|
||||||
|
return $value->listener !== $handler;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|||||||
+25
-25
@@ -1,25 +1,25 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
declare(strict_types=1);
|
declare(strict_types=1);
|
||||||
|
|
||||||
namespace Kiri\Events;
|
namespace Kiri\Events;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
class Struct
|
class Struct
|
||||||
{
|
{
|
||||||
|
|
||||||
public string $event;
|
public string $event;
|
||||||
|
|
||||||
public array|\Closure $listener;
|
public array|\Closure $listener;
|
||||||
|
|
||||||
public int $priority;
|
public int $priority;
|
||||||
|
|
||||||
public function __construct(string $event, callable $listener, int $priority)
|
public function __construct(string $event, callable $listener, int $priority)
|
||||||
{
|
{
|
||||||
$this->event = $event;
|
$this->event = $event;
|
||||||
$this->listener = $listener;
|
$this->listener = $listener;
|
||||||
$this->priority = $priority;
|
$this->priority = $priority;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,7 +10,6 @@
|
|||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"require": {
|
"require": {
|
||||||
"php": ">=8.0",
|
"php": ">=8.0",
|
||||||
"ext-json": "*",
|
|
||||||
"psr/event-dispatcher": "^1.0"
|
"psr/event-dispatcher": "^1.0"
|
||||||
},
|
},
|
||||||
"autoload": {
|
"autoload": {
|
||||||
@@ -19,6 +18,5 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"kwn/php-rdkafka-stubs": "^2.0"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user