Mercurial > hg > isophonics-drupal-site
diff vendor/consolidation/annotated-command/src/Hooks/Dispatchers/CommandEventHookDispatcher.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/vendor/consolidation/annotated-command/src/Hooks/Dispatchers/CommandEventHookDispatcher.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,37 @@ +<?php + +namespace Consolidation\AnnotatedCommand\Hooks\Dispatchers; + +use Consolidation\AnnotatedCommand\Hooks\HookManager; +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\ConsoleEvents; +use Symfony\Component\Console\Event\ConsoleCommandEvent; +use Symfony\Component\EventDispatcher\EventSubscriberInterface; +use Symfony\Component\EventDispatcher\EventDispatcherInterface; + +/** + * Call hooks + */ +class CommandEventHookDispatcher extends HookDispatcher +{ + /** + * @param ConsoleCommandEvent $event + */ + public function callCommandEventHooks(ConsoleCommandEvent $event) + { + $hooks = [ + HookManager::PRE_COMMAND_EVENT, + HookManager::COMMAND_EVENT, + HookManager::POST_COMMAND_EVENT + ]; + $commandEventHooks = $this->getHooks($hooks); + foreach ($commandEventHooks as $commandEvent) { + if ($commandEvent instanceof EventDispatcherInterface) { + $commandEvent->dispatch(ConsoleEvents::COMMAND, $event); + } + if (is_callable($commandEvent)) { + $commandEvent($event); + } + } + } +}