2010-04-08 01:03:04 -03:00
|
|
|
<?php
|
|
|
|
|
2010-08-23 08:21:41 +02:00
|
|
|
namespace Symfony\Component\Console\Helper;
|
2010-04-08 01:03:04 -03:00
|
|
|
|
2010-08-23 08:21:41 +02:00
|
|
|
use Symfony\Component\Console\Command\Command;
|
2010-04-08 01:03:04 -03:00
|
|
|
|
|
|
|
/*
|
2010-10-30 13:24:50 +02:00
|
|
|
* This file is part of the Symfony framework.
|
2010-04-08 01:03:04 -03:00
|
|
|
*
|
|
|
|
* (c) Fabien Potencier <fabien.potencier@symfony-project.com>
|
|
|
|
*
|
|
|
|
* This source file is subject to the MIT license that is bundled
|
|
|
|
* with this source code in the file LICENSE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* HelperSet represents a set of helpers to be used with a command.
|
|
|
|
*
|
2010-10-30 13:24:50 +02:00
|
|
|
* @author Fabien Potencier <fabien.potencier@symfony-project.com>
|
2010-04-08 01:03:04 -03:00
|
|
|
*/
|
|
|
|
class HelperSet
|
|
|
|
{
|
2010-10-30 13:24:50 +02:00
|
|
|
protected $helpers;
|
|
|
|
protected $command;
|
2010-04-08 01:03:04 -03:00
|
|
|
|
2010-10-30 13:24:50 +02:00
|
|
|
/**
|
|
|
|
* @param Helper[] $helpers An array of helper.
|
|
|
|
*/
|
|
|
|
public function __construct(array $helpers = array())
|
2010-04-08 01:03:04 -03:00
|
|
|
{
|
2010-10-30 13:24:50 +02:00
|
|
|
$this->helpers = array();
|
|
|
|
foreach ($helpers as $alias => $helper) {
|
|
|
|
$this->set($helper, is_int($alias) ? null : $alias);
|
|
|
|
}
|
2010-04-08 01:03:04 -03:00
|
|
|
}
|
|
|
|
|
2010-10-30 13:24:50 +02:00
|
|
|
/**
|
|
|
|
* Sets a helper.
|
|
|
|
*
|
|
|
|
* @param HelperInterface $value The helper instance
|
|
|
|
* @param string $alias An alias
|
|
|
|
*/
|
|
|
|
public function set(HelperInterface $helper, $alias = null)
|
2010-04-08 01:03:04 -03:00
|
|
|
{
|
2010-10-30 13:24:50 +02:00
|
|
|
$this->helpers[$helper->getName()] = $helper;
|
|
|
|
if (null !== $alias) {
|
|
|
|
$this->helpers[$alias] = $helper;
|
|
|
|
}
|
2010-04-08 01:03:04 -03:00
|
|
|
|
2010-10-30 13:24:50 +02:00
|
|
|
$helper->setHelperSet($this);
|
|
|
|
}
|
2010-04-08 01:03:04 -03:00
|
|
|
|
2010-10-30 13:24:50 +02:00
|
|
|
/**
|
|
|
|
* Returns true if the helper if defined.
|
|
|
|
*
|
|
|
|
* @param string $name The helper name
|
|
|
|
*
|
|
|
|
* @return Boolean true if the helper is defined, false otherwise
|
|
|
|
*/
|
|
|
|
public function has($name)
|
2010-04-08 01:03:04 -03:00
|
|
|
{
|
2010-10-30 13:24:50 +02:00
|
|
|
return isset($this->helpers[$name]);
|
2010-04-08 01:03:04 -03:00
|
|
|
}
|
|
|
|
|
2010-10-30 13:24:50 +02:00
|
|
|
/**
|
|
|
|
* Gets a helper value.
|
|
|
|
*
|
|
|
|
* @param string $name The helper name
|
|
|
|
*
|
|
|
|
* @return HelperInterface The helper instance
|
|
|
|
*
|
|
|
|
* @throws \InvalidArgumentException if the helper is not defined
|
|
|
|
*/
|
|
|
|
public function get($name)
|
|
|
|
{
|
|
|
|
if (!$this->has($name)) {
|
|
|
|
throw new \InvalidArgumentException(sprintf('The helper "%s" is not defined.', $name));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->helpers[$name];
|
|
|
|
}
|
2010-04-08 01:03:04 -03:00
|
|
|
|
2010-10-30 13:24:50 +02:00
|
|
|
/**
|
|
|
|
* Sets the command associated with this helper set.
|
|
|
|
*
|
|
|
|
* @param Command $command A Command instance
|
|
|
|
*/
|
|
|
|
public function setCommand(Command $command = null)
|
|
|
|
{
|
|
|
|
$this->command = $command;
|
|
|
|
}
|
2010-04-08 01:03:04 -03:00
|
|
|
|
2010-10-30 13:24:50 +02:00
|
|
|
/**
|
|
|
|
* Gets the command associated with this helper set.
|
|
|
|
*
|
|
|
|
* @return Command A Command instance
|
|
|
|
*/
|
|
|
|
public function getCommand()
|
|
|
|
{
|
|
|
|
return $this->command;
|
|
|
|
}
|
2010-04-08 01:03:04 -03:00
|
|
|
}
|