2009-12-21 17:38:14 +00:00
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* This software consists of voluntary contributions made by many individuals
|
|
|
|
* and is licensed under the LGPL. For more information, see
|
|
|
|
* <http://www.doctrine-project.org>.
|
|
|
|
*/
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2010-03-24 02:37:45 +00:00
|
|
|
namespace Doctrine\Common\CLI;
|
2009-12-21 17:38:14 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CLI Namespace class
|
|
|
|
*
|
|
|
|
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
|
|
|
* @link www.doctrine-project.org
|
|
|
|
* @since 2.0
|
|
|
|
* @version $Revision$
|
|
|
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
|
|
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
|
|
|
* @author Jonathan Wage <jonwage@gmail.com>
|
|
|
|
* @author Roman Borschel <roman@code-factory.org>
|
|
|
|
*/
|
|
|
|
class TaskNamespace extends AbstractNamespace
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var boolean CLI Tasks flag to check if they are already initialized
|
|
|
|
*/
|
|
|
|
private $_initialized = false;
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* @var string CLI Namespace full name
|
|
|
|
*/
|
|
|
|
private $_fullName = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string CLI Namespace name
|
|
|
|
*/
|
|
|
|
private $_name = null;
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* @var array Available tasks
|
|
|
|
*/
|
|
|
|
private $_tasks = array();
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* The CLI namespace
|
|
|
|
*
|
|
|
|
* @param string $name CLI Namespace name
|
|
|
|
*/
|
|
|
|
public function __construct($name)
|
|
|
|
{
|
|
|
|
$this->_name = self::formatName($name);
|
2010-03-05 16:35:00 +00:00
|
|
|
}
|
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Retrieve an instantiated CLI Task by given its name.
|
|
|
|
*
|
|
|
|
* @param string $name CLI Task name
|
|
|
|
*
|
|
|
|
* @return AbstractTask
|
|
|
|
*/
|
|
|
|
public function getTask($name)
|
|
|
|
{
|
2010-03-05 16:35:00 +00:00
|
|
|
// Check if task exists in namespace
|
2009-12-21 17:38:14 +00:00
|
|
|
if ($this->hasTask($name)) {
|
|
|
|
$taskClass = $this->_tasks[self::formatName($name)];
|
|
|
|
|
|
|
|
return new $taskClass($this);
|
2010-03-05 16:35:00 +00:00
|
|
|
}
|
|
|
|
|
2010-03-24 02:37:45 +00:00
|
|
|
throw CLIException::taskDoesNotExist($name, $this->getFullName());
|
2009-12-21 17:38:14 +00:00
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Retrieve all CLI Task in this Namespace.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getTasks()
|
|
|
|
{
|
|
|
|
return $this->_tasks;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Retrieve all defined CLI Tasks
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getAvailableTasks()
|
|
|
|
{
|
|
|
|
$tasks = parent::getAvailableTasks();
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
foreach ($this->_tasks as $taskName => $taskClass) {
|
|
|
|
$fullName = $this->getFullName() . ':' . $taskName;
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
$tasks[$fullName] = $taskClass;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
return $tasks;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Add a single task to CLI Namespace.
|
|
|
|
* Example of inclusion support to a single task:
|
|
|
|
*
|
|
|
|
* [php]
|
|
|
|
* $cliOrmNamespace->addTask('my-custom-task', 'MyProject\Cli\Tasks\MyCustomTask');
|
|
|
|
*
|
|
|
|
* @param string $name CLI Task name
|
|
|
|
* @param string $class CLI Task class (FQCN - Fully Qualified Class Name)
|
|
|
|
*
|
|
|
|
* @return TaskNamespace This object instance
|
|
|
|
*/
|
|
|
|
public function addTask($name, $class)
|
|
|
|
{
|
|
|
|
$name = self::formatName($name);
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
if ($this->hasTask($name)) {
|
2010-03-24 02:37:45 +00:00
|
|
|
throw CLIException::cannotOverrideTask($name);
|
2009-12-21 17:38:14 +00:00
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
return $this->overrideTask($name, $class);
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Overrides task on CLI Namespace.
|
|
|
|
* Example of inclusion support to a single task:
|
|
|
|
*
|
|
|
|
* [php]
|
|
|
|
* $cliOrmNamespace->overrideTask('schema-tool', 'MyProject\Cli\Tasks\MyCustomTask');
|
|
|
|
*
|
|
|
|
* @param string $name CLI Task name
|
|
|
|
* @param string $class CLI Task class (FQCN - Fully Qualified Class Name)
|
|
|
|
*
|
|
|
|
* @return TaskNamespace This object instance
|
|
|
|
*/
|
|
|
|
public function overrideTask($name, $class)
|
2010-03-05 16:35:00 +00:00
|
|
|
{
|
2009-12-21 17:38:14 +00:00
|
|
|
$name = self::formatName($name);
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
$this->_tasks[$name] = $class;
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
return $this;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Check existance of a CLI Task
|
|
|
|
*
|
|
|
|
* @param string CLI Task name
|
|
|
|
*
|
|
|
|
* @return boolean TRUE if CLI Task if defined, false otherwise
|
|
|
|
*/
|
|
|
|
public function hasTask($name)
|
|
|
|
{
|
|
|
|
$name = self::formatName($name);
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
return isset($this->_tasks[$name]);
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Retrieves the CLI Namespace name
|
|
|
|
*
|
|
|
|
* @return string CLI Namespace name
|
|
|
|
*/
|
|
|
|
public function getName()
|
|
|
|
{
|
|
|
|
return $this->_name;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Retrieves the full CLI Namespace name
|
|
|
|
*
|
|
|
|
* @return string CLI Namespace full name
|
|
|
|
*/
|
|
|
|
public function getFullName()
|
|
|
|
{
|
|
|
|
if ($this->_fullName === null) {
|
|
|
|
$str = $this->_name;
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
while (
|
2010-03-05 16:35:00 +00:00
|
|
|
($parentNamespace = $this->getParentNamespace()) !== null &&
|
2009-12-21 17:38:14 +00:00
|
|
|
! ($parentNamespace instanceof CliController)
|
|
|
|
) {
|
|
|
|
$str = $parentNamespace->getFullName() . ':' . $str;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
$this->_fullName = $str;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
return $this->_fullName;
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
/**
|
|
|
|
* Effectively instantiate and execute a given CLI Task
|
|
|
|
*
|
|
|
|
* @param string $name CLI Task name
|
|
|
|
* @param array $arguments CLI Task arguments
|
|
|
|
*/
|
|
|
|
public function runTask($name, $arguments = array())
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$task = $this->getTask($name);
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2010-01-06 17:55:55 +00:00
|
|
|
// Merge global configuration if it exists
|
|
|
|
if (($globalArgs = $this->getConfiguration()->getAttribute('globalArguments')) !== null) {
|
|
|
|
$arguments = array_merge($globalArgs, $arguments);
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
$task->setArguments($arguments);
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
if ((isset($arguments['help']) && $arguments['help']) || (isset($arguments['h']) && $arguments['h'])) {
|
|
|
|
$task->extendedHelp(); // User explicitly asked for help option
|
|
|
|
} else if (isset($arguments['basic-help']) && $arguments['basic-help']) {
|
|
|
|
$task->basicHelp(); // User explicitly asked for basic help option
|
|
|
|
} else if ($task->validate()) {
|
|
|
|
$task->run();
|
|
|
|
}
|
2010-03-24 02:37:45 +00:00
|
|
|
} catch (CLIException $e) {
|
2009-12-21 17:38:14 +00:00
|
|
|
$message = $this->getFullName() . ':' . $name . ' => ' . $e->getMessage();
|
|
|
|
$printer = $this->getPrinter();
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
// If we want the trace of calls, append to error message
|
|
|
|
if (isset($arguments['trace']) && $arguments['trace']) {
|
|
|
|
$message .= PHP_EOL . PHP_EOL . $e->getTraceAsString();
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2010-03-08 21:03:04 +00:00
|
|
|
$printer->writeln($message, 'ERROR');
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
// Unable instantiate task or task is not valid
|
2010-03-16 19:35:41 +00:00
|
|
|
if (isset($task) && $task !== null) {
|
2009-12-21 17:38:14 +00:00
|
|
|
$printer->write(PHP_EOL);
|
|
|
|
$task->basicHelp(); // Fallback of not-valid task arguments
|
|
|
|
}
|
2010-03-05 16:35:00 +00:00
|
|
|
|
2009-12-21 17:38:14 +00:00
|
|
|
$printer->write(PHP_EOL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|