Maslosoft Signals API
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
<?php
/**
* This software package is licensed under `AGPL, Commercial` license[s].
*
* @package maslosoft/signals
* @license AGPL, Commercial
*
* @copyright Copyright (c) Peter Maselkowski <pmaselkowski@gmail.com>
* @link https://maslosoft.com/signals/
*/
namespace Maslosoft\Signals\Application\Commands;
use Maslosoft\Addendum\Interfaces\AnnotatedInterface;
use Maslosoft\Cli\Shared\Log\Logger;
use Maslosoft\Signals\Signal;
use Maslosoft\Signals\Utility;
use Maslosoft\Sitcom\Command;
use Psr\Log\NullLogger;
use Symfony\Component\Console\Command\Command as ConsoleCommand;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
/**
* SignalsCommand
*
* @author Piotr Maselkowski <pmaselkowski at gmail.com>
* @codeCoverageIgnore
*/
class BuildCommand extends ConsoleCommand implements AnnotatedInterface
{
protected function configure()
{
$this->setName("build");
$this->setDescription("Build signals list");
$this->setDefinition([
]);
$help = <<<EOT
The <info>build</info> command will scan files for signals and save them to file.
EOT;
$this->setHelp($help);
}
protected function execute(InputInterface $input, OutputInterface $output)
{
$signal = new Signal();
// Set default logger if not configured
$currentLogger = $signal->getLogger();
if ($currentLogger instanceof NullLogger)
{
$signal->setLogger(new Logger($output));
}
(new Utility($signal))->generate();
}
/**
* @SlotFor(Maslosoft\Sitcom\Command)
* @param Command $signal
*/
public function reactOn(Command $signal)
{
$signal->add($this, 'signals');
}
}
API documentation generated by ApiGen