the whole shebang
This commit is contained in:
		
							
								
								
									
										153
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/ApplicationDescription.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										153
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/ApplicationDescription.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,153 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * This file is part of the Symfony package. | ||||
|  * | ||||
|  * (c) Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| namespace Symfony\Component\Console\Descriptor; | ||||
|  | ||||
| use Symfony\Component\Console\Application; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
|  | ||||
| /** | ||||
|  * @author Jean-François Simon <jeanfrancois.simon@sensiolabs.com> | ||||
|  */ | ||||
| class ApplicationDescription | ||||
| { | ||||
|     const GLOBAL_NAMESPACE = '_global'; | ||||
|  | ||||
|     /** | ||||
|      * @var Application | ||||
|      */ | ||||
|     private $application; | ||||
|  | ||||
|     /** | ||||
|      * @var null|string | ||||
|      */ | ||||
|     private $namespace; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $namespaces; | ||||
|  | ||||
|     /** | ||||
|      * @var Command[] | ||||
|      */ | ||||
|     private $commands; | ||||
|  | ||||
|     /** | ||||
|      * @var Command[] | ||||
|      */ | ||||
|     private $aliases; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param Application $application | ||||
|      * @param string|null $namespace | ||||
|      */ | ||||
|     public function __construct(Application $application, $namespace = null) | ||||
|     { | ||||
|         $this->application = $application; | ||||
|         $this->namespace = $namespace; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getNamespaces() | ||||
|     { | ||||
|         if (null === $this->namespaces) { | ||||
|             $this->inspectApplication(); | ||||
|         } | ||||
|  | ||||
|         return $this->namespaces; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return Command[] | ||||
|      */ | ||||
|     public function getCommands() | ||||
|     { | ||||
|         if (null === $this->commands) { | ||||
|             $this->inspectApplication(); | ||||
|         } | ||||
|  | ||||
|         return $this->commands; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return Command | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public function getCommand($name) | ||||
|     { | ||||
|         if (!isset($this->commands[$name]) && !isset($this->aliases[$name])) { | ||||
|             throw new \InvalidArgumentException(sprintf('Command %s does not exist.', $name)); | ||||
|         } | ||||
|  | ||||
|         return isset($this->commands[$name]) ? $this->commands[$name] : $this->aliases[$name]; | ||||
|     } | ||||
|  | ||||
|     private function inspectApplication() | ||||
|     { | ||||
|         $this->commands = array(); | ||||
|         $this->namespaces = array(); | ||||
|  | ||||
|         $all = $this->application->all($this->namespace ? $this->application->findNamespace($this->namespace) : null); | ||||
|         foreach ($this->sortCommands($all) as $namespace => $commands) { | ||||
|             $names = array(); | ||||
|  | ||||
|             /** @var Command $command */ | ||||
|             foreach ($commands as $name => $command) { | ||||
|                 if (!$command->getName()) { | ||||
|                     continue; | ||||
|                 } | ||||
|  | ||||
|                 if ($command->getName() === $name) { | ||||
|                     $this->commands[$name] = $command; | ||||
|                 } else { | ||||
|                     $this->aliases[$name] = $command; | ||||
|                 } | ||||
|  | ||||
|                 $names[] = $name; | ||||
|             } | ||||
|  | ||||
|             $this->namespaces[$namespace] = array('id' => $namespace, 'commands' => $names); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param array $commands | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     private function sortCommands(array $commands) | ||||
|     { | ||||
|         $namespacedCommands = array(); | ||||
|         foreach ($commands as $name => $command) { | ||||
|             $key = $this->application->extractNamespace($name, 1); | ||||
|             if (!$key) { | ||||
|                 $key = '_global'; | ||||
|             } | ||||
|  | ||||
|             $namespacedCommands[$key][$name] = $command; | ||||
|         } | ||||
|         ksort($namespacedCommands); | ||||
|  | ||||
|         foreach ($namespacedCommands as &$commands) { | ||||
|             ksort($commands); | ||||
|         } | ||||
|  | ||||
|         return $namespacedCommands; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										92
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/Descriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/Descriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * This file is part of the Symfony package. | ||||
|  * | ||||
|  * (c) Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| namespace Symfony\Component\Console\Descriptor; | ||||
|  | ||||
| use Symfony\Component\Console\Application; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
| use Symfony\Component\Console\Input\InputArgument; | ||||
| use Symfony\Component\Console\Input\InputDefinition; | ||||
| use Symfony\Component\Console\Input\InputOption; | ||||
|  | ||||
| /** | ||||
|  * @author Jean-François Simon <jeanfrancois.simon@sensiolabs.com> | ||||
|  */ | ||||
| abstract class Descriptor implements DescriptorInterface | ||||
| { | ||||
|     public function describe($object, array $options = array()) | ||||
|     { | ||||
|         switch (true) { | ||||
|             case $object instanceof InputArgument: | ||||
|                 return $this->describeInputArgument($object, $options); | ||||
|             case $object instanceof InputOption: | ||||
|                 return $this->describeInputOption($object, $options); | ||||
|             case $object instanceof InputDefinition: | ||||
|                 return $this->describeInputDefinition($object, $options); | ||||
|             case $object instanceof Command: | ||||
|                 return $this->describeCommand($object, $options); | ||||
|             case $object instanceof Application: | ||||
|                 return $this->describeApplication($object, $options); | ||||
|         } | ||||
|  | ||||
|         throw new \InvalidArgumentException(sprintf('Object of type "%s" is not describable.', get_class($object))); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Describes an InputArgument instance. | ||||
|      * | ||||
|      * @param InputArgument $argument | ||||
|      * @param array         $options | ||||
|      * | ||||
|      * @return string|mixed | ||||
|      */ | ||||
|     abstract protected function describeInputArgument(InputArgument $argument, array $options = array()); | ||||
|  | ||||
|     /** | ||||
|      * Describes an InputOption instance. | ||||
|      * | ||||
|      * @param InputOption $option | ||||
|      * @param array       $options | ||||
|      * | ||||
|      * @return string|mixed | ||||
|      */ | ||||
|     abstract protected function describeInputOption(InputOption $option, array $options = array()); | ||||
|  | ||||
|     /** | ||||
|      * Describes an InputDefinition instance. | ||||
|      * | ||||
|      * @param InputDefinition $definition | ||||
|      * @param array           $options | ||||
|      * | ||||
|      * @return string|mixed | ||||
|      */ | ||||
|     abstract protected function describeInputDefinition(InputDefinition $definition, array $options = array()); | ||||
|  | ||||
|     /** | ||||
|      * Describes a Command instance. | ||||
|      * | ||||
|      * @param Command $command | ||||
|      * @param array   $options | ||||
|      * | ||||
|      * @return string|mixed | ||||
|      */ | ||||
|     abstract protected function describeCommand(Command $command, array $options = array()); | ||||
|  | ||||
|     /** | ||||
|      * Describes an Application instance. | ||||
|      * | ||||
|      * @param Application $application | ||||
|      * @param array       $options | ||||
|      * | ||||
|      * @return string|mixed | ||||
|      */ | ||||
|     abstract protected function describeApplication(Application $application, array $options = array()); | ||||
| } | ||||
							
								
								
									
										30
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/DescriptorInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/DescriptorInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * This file is part of the Symfony package. | ||||
|  * | ||||
|  * (c) Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| namespace Symfony\Component\Console\Descriptor; | ||||
|  | ||||
| /** | ||||
|  * Descriptor interface. | ||||
|  * | ||||
|  * @author Jean-François Simon <contact@jfsimon.fr> | ||||
|  */ | ||||
| interface DescriptorInterface | ||||
| { | ||||
|     /** | ||||
|      * Describes an InputArgument instance. | ||||
|      * | ||||
|      * @param object $object | ||||
|      * @param array  $options | ||||
|      * | ||||
|      * @return string|mixed | ||||
|      */ | ||||
|     public function describe($object, array $options = array()); | ||||
| } | ||||
							
								
								
									
										129
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/JsonDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/JsonDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,129 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * This file is part of the Symfony package. | ||||
|  * | ||||
|  * (c) Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| namespace Symfony\Component\Console\Descriptor; | ||||
|  | ||||
| use Symfony\Component\Console\Application; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
| use Symfony\Component\Console\Input\InputArgument; | ||||
| use Symfony\Component\Console\Input\InputDefinition; | ||||
| use Symfony\Component\Console\Input\InputOption; | ||||
|  | ||||
| /** | ||||
|  * JSON descriptor. | ||||
|  * | ||||
|  * @author Jean-François Simon <contact@jfsimon.fr> | ||||
|  */ | ||||
| class JsonDescriptor extends Descriptor | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputArgument(InputArgument $argument, array $options = array()) | ||||
|     { | ||||
|         return $this->output(array( | ||||
|             'name'        => $argument->getName(), | ||||
|             'is_required' => $argument->isRequired(), | ||||
|             'is_array'    => $argument->isArray(), | ||||
|             'description' => $argument->getDescription(), | ||||
|             'default'     => $argument->getDefault(), | ||||
|         ), $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputOption(InputOption $option, array $options = array()) | ||||
|     { | ||||
|         return $this->output(array( | ||||
|             'name'              => '--'.$option->getName(), | ||||
|             'shortcut'          => $option->getShortcut() ? '-'.implode('|-', explode('|', $option->getShortcut())) : '', | ||||
|             'accept_value'      => $option->acceptValue(), | ||||
|             'is_value_required' => $option->isValueRequired(), | ||||
|             'is_multiple'       => $option->isArray(), | ||||
|             'description'       => $option->getDescription(), | ||||
|             'default'           => $option->getDefault(), | ||||
|         ), $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputDefinition(InputDefinition $definition, array $options = array()) | ||||
|     { | ||||
|         $inputArguments = array(); | ||||
|         foreach ($definition->getArguments() as $name => $argument) { | ||||
|             $inputArguments[$name] = $this->describeInputArgument($argument, array('as_array' => true)); | ||||
|         } | ||||
|  | ||||
|         $inputOptions = array(); | ||||
|         foreach ($definition->getOptions() as $name => $option) { | ||||
|             $inputOptions[$name] = $this->describeInputOption($option, array('as_array' => true)); | ||||
|         } | ||||
|  | ||||
|         return $this->output(array('arguments' => $inputArguments, 'options' => $inputOptions), $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeCommand(Command $command, array $options = array()) | ||||
|     { | ||||
|         $command->getSynopsis(); | ||||
|         $command->mergeApplicationDefinition(false); | ||||
|  | ||||
|         return $this->output(array( | ||||
|             'name'        => $command->getName(), | ||||
|             'usage'       => $command->getSynopsis(), | ||||
|             'description' => $command->getDescription(), | ||||
|             'help'        => $command->getProcessedHelp(), | ||||
|             'aliases'     => $command->getAliases(), | ||||
|             'definition'  => $this->describeInputDefinition($command->getNativeDefinition(), array('as_array' => true)), | ||||
|         ), $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeApplication(Application $application, array $options = array()) | ||||
|     { | ||||
|         $describedNamespace = isset($options['namespace']) ? $options['namespace'] : null; | ||||
|         $description = new ApplicationDescription($application, $describedNamespace); | ||||
|         $commands = array(); | ||||
|  | ||||
|         foreach ($description->getCommands() as $command) { | ||||
|             $commands[] = $this->describeCommand($command, array('as_array' => true)); | ||||
|         } | ||||
|  | ||||
|         $data = $describedNamespace | ||||
|             ? array('commands' => $commands, 'namespace' => $describedNamespace) | ||||
|             : array('commands' => $commands, 'namespaces' => array_values($description->getNamespaces())); | ||||
|  | ||||
|         return $this->output($data, $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Outputs data as array or string according to options. | ||||
|      * | ||||
|      * @param array $data | ||||
|      * @param array $options | ||||
|      * | ||||
|      * @return array|string | ||||
|      */ | ||||
|     private function output(array $data, array $options) | ||||
|     { | ||||
|         if (isset($options['as_array']) && $options['as_array']) { | ||||
|             return $data; | ||||
|         } | ||||
|  | ||||
|         return json_encode($data, isset($options['json_encoding']) ? $options['json_encoding'] : 0); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										129
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/MarkdownDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/MarkdownDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,129 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * This file is part of the Symfony package. | ||||
|  * | ||||
|  * (c) Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| namespace Symfony\Component\Console\Descriptor; | ||||
|  | ||||
| use Symfony\Component\Console\Application; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
| use Symfony\Component\Console\Input\InputArgument; | ||||
| use Symfony\Component\Console\Input\InputDefinition; | ||||
| use Symfony\Component\Console\Input\InputOption; | ||||
|  | ||||
| /** | ||||
|  * Markdown descriptor. | ||||
|  * | ||||
|  * @author Jean-François Simon <contact@jfsimon.fr> | ||||
|  */ | ||||
| class MarkdownDescriptor extends Descriptor | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputArgument(InputArgument $argument, array $options = array()) | ||||
|     { | ||||
|         return '**'.$argument->getName().':**'."\n\n" | ||||
|             .'* Name: '.($argument->getName() ?: '<none>')."\n" | ||||
|             .'* Is required: '.($argument->isRequired() ? 'yes' : 'no')."\n" | ||||
|             .'* Is array: '.($argument->isArray() ? 'yes' : 'no')."\n" | ||||
|             .'* Description: '.($argument->getDescription() ?: '<none>')."\n" | ||||
|             .'* Default: `'.str_replace("\n", '', var_export($argument->getDefault(), true)).'`'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputOption(InputOption $option, array $options = array()) | ||||
|     { | ||||
|         return '**'.$option->getName().':**'."\n\n" | ||||
|             .'* Name: `--'.$option->getName().'`'."\n" | ||||
|             .'* Shortcut: '.($option->getShortcut() ? '`-'.implode('|-', explode('|', $option->getShortcut())).'`' : '<none>')."\n" | ||||
|             .'* Accept value: '.($option->acceptValue() ? 'yes' : 'no')."\n" | ||||
|             .'* Is value required: '.($option->isValueRequired() ? 'yes' : 'no')."\n" | ||||
|             .'* Is multiple: '.($option->isArray() ? 'yes' : 'no')."\n" | ||||
|             .'* Description: '.($option->getDescription() ?: '<none>')."\n" | ||||
|             .'* Default: `'.str_replace("\n", '', var_export($option->getDefault(), true)).'`'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputDefinition(InputDefinition $definition, array $options = array()) | ||||
|     { | ||||
|         $blocks = array(); | ||||
|  | ||||
|         if (count($definition->getArguments()) > 0) { | ||||
|             $blocks[] = '### Arguments:'; | ||||
|             foreach ($definition->getArguments() as $argument) { | ||||
|                 $blocks[] = $this->describeInputArgument($argument); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (count($definition->getOptions()) > 0) { | ||||
|             $blocks[] = '### Options:'; | ||||
|             foreach ($definition->getOptions() as $option) { | ||||
|                 $blocks[] = $this->describeInputOption($option); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return implode("\n\n", $blocks); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeCommand(Command $command, array $options = array()) | ||||
|     { | ||||
|         $command->getSynopsis(); | ||||
|         $command->mergeApplicationDefinition(false); | ||||
|  | ||||
|         $markdown = $command->getName()."\n" | ||||
|             .str_repeat('-', strlen($command->getName()))."\n\n" | ||||
|             .'* Description: '.($command->getDescription() ?: '<none>')."\n" | ||||
|             .'* Usage: `'.$command->getSynopsis().'`'."\n" | ||||
|             .'* Aliases: '.(count($command->getAliases()) ? '`'.implode('`, `', $command->getAliases()).'`' : '<none>'); | ||||
|  | ||||
|         if ($help = $command->getProcessedHelp()) { | ||||
|             $markdown .= "\n\n".$help; | ||||
|         } | ||||
|  | ||||
|         if ($definitionMarkdown = $this->describeInputDefinition($command->getNativeDefinition())) { | ||||
|             $markdown .= "\n\n".$definitionMarkdown; | ||||
|         } | ||||
|  | ||||
|         return $markdown; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeApplication(Application $application, array $options = array()) | ||||
|     { | ||||
|         $describedNamespace = isset($options['namespace']) ? $options['namespace'] : null; | ||||
|         $description = new ApplicationDescription($application, $describedNamespace); | ||||
|         $blocks = array($application->getName()."\n".str_repeat('=', strlen($application->getName()))); | ||||
|  | ||||
|         foreach ($description->getNamespaces() as $namespace) { | ||||
|             if (ApplicationDescription::GLOBAL_NAMESPACE !== $namespace['id']) { | ||||
|                 $blocks[] = '**'.$namespace['id'].':**'; | ||||
|             } | ||||
|  | ||||
|             $blocks[] = implode("\n", array_map(function ($commandName) { | ||||
|                 return '* '.$commandName; | ||||
|             } , $namespace['commands'])); | ||||
|         } | ||||
|  | ||||
|         foreach ($description->getCommands() as $command) { | ||||
|             $blocks[] = $this->describeCommand($command); | ||||
|         } | ||||
|  | ||||
|         return implode("\n\n", $blocks); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										210
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/TextDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										210
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/TextDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,210 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * This file is part of the Symfony package. | ||||
|  * | ||||
|  * (c) Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| namespace Symfony\Component\Console\Descriptor; | ||||
|  | ||||
| use Symfony\Component\Console\Application; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
| use Symfony\Component\Console\Input\InputArgument; | ||||
| use Symfony\Component\Console\Input\InputDefinition; | ||||
| use Symfony\Component\Console\Input\InputOption; | ||||
|  | ||||
| /** | ||||
|  * Text descriptor. | ||||
|  * | ||||
|  * @author Jean-François Simon <contact@jfsimon.fr> | ||||
|  */ | ||||
| class TextDescriptor extends Descriptor | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputArgument(InputArgument $argument, array $options = array()) | ||||
|     { | ||||
|         if (null !== $argument->getDefault() && (!is_array($argument->getDefault()) || count($argument->getDefault()))) { | ||||
|             $default = sprintf('<comment> (default: %s)</comment>', $this->formatDefaultValue($argument->getDefault())); | ||||
|         } else { | ||||
|             $default = ''; | ||||
|         } | ||||
|  | ||||
|         $nameWidth = isset($options['name_width']) ? $options['name_width'] : strlen($argument->getName()); | ||||
|         $output = str_replace("\n", "\n".str_repeat(' ', $nameWidth + 2), $argument->getDescription()); | ||||
|         $output = sprintf(" <info>%-${nameWidth}s</info> %s%s", $argument->getName(), $output, $default); | ||||
|  | ||||
|         return isset($options['raw_text']) && $options['raw_text'] ? strip_tags($output) : $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputOption(InputOption $option, array $options = array()) | ||||
|     { | ||||
|         if ($option->acceptValue() && null !== $option->getDefault() && (!is_array($option->getDefault()) || count($option->getDefault()))) { | ||||
|             $default = sprintf('<comment> (default: %s)</comment>', $this->formatDefaultValue($option->getDefault())); | ||||
|         } else { | ||||
|             $default = ''; | ||||
|         } | ||||
|  | ||||
|         $nameWidth = isset($options['name_width']) ? $options['name_width'] : strlen($option->getName()); | ||||
|         $nameWithShortcutWidth = $nameWidth - strlen($option->getName()) - 2; | ||||
|  | ||||
|         $output = sprintf(" <info>%s</info> %-${nameWithShortcutWidth}s%s%s%s", | ||||
|             '--'.$option->getName(), | ||||
|             $option->getShortcut() ? sprintf('(-%s) ', $option->getShortcut()) : '', | ||||
|             str_replace("\n", "\n".str_repeat(' ', $nameWidth + 2), $option->getDescription()), | ||||
|             $default, | ||||
|             $option->isArray() ? '<comment> (multiple values allowed)</comment>' : '' | ||||
|         ); | ||||
|  | ||||
|         return isset($options['raw_text']) && $options['raw_text'] ? strip_tags($output) : $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputDefinition(InputDefinition $definition, array $options = array()) | ||||
|     { | ||||
|         $nameWidth = 0; | ||||
|         foreach ($definition->getOptions() as $option) { | ||||
|             $nameLength = strlen($option->getName()) + 2; | ||||
|             if ($option->getShortcut()) { | ||||
|                 $nameLength += strlen($option->getShortcut()) + 3; | ||||
|             } | ||||
|             $nameWidth = max($nameWidth, $nameLength); | ||||
|         } | ||||
|         foreach ($definition->getArguments() as $argument) { | ||||
|             $nameWidth = max($nameWidth, strlen($argument->getName())); | ||||
|         } | ||||
|         ++$nameWidth; | ||||
|  | ||||
|         $messages = array(); | ||||
|  | ||||
|         if ($definition->getArguments()) { | ||||
|             $messages[] = '<comment>Arguments:</comment>'; | ||||
|             foreach ($definition->getArguments() as $argument) { | ||||
|                 $messages[] = $this->describeInputArgument($argument, array('name_width' => $nameWidth)); | ||||
|             } | ||||
|             $messages[] = ''; | ||||
|         } | ||||
|  | ||||
|         if ($definition->getOptions()) { | ||||
|             $messages[] = '<comment>Options:</comment>'; | ||||
|             foreach ($definition->getOptions() as $option) { | ||||
|                 $messages[] = $this->describeInputOption($option, array('name_width' => $nameWidth)); | ||||
|             } | ||||
|             $messages[] = ''; | ||||
|         } | ||||
|  | ||||
|         $output = implode("\n", $messages); | ||||
|  | ||||
|         return isset($options['raw_text']) && $options['raw_text'] ? strip_tags($output) : $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeCommand(Command $command, array $options = array()) | ||||
|     { | ||||
|         $command->getSynopsis(); | ||||
|         $command->mergeApplicationDefinition(false); | ||||
|         $messages = array('<comment>Usage:</comment>', ' '.$command->getSynopsis(), ''); | ||||
|  | ||||
|         if ($command->getAliases()) { | ||||
|             $messages[] = '<comment>Aliases:</comment> <info>'.implode(', ', $command->getAliases()).'</info>'; | ||||
|         } | ||||
|  | ||||
|         $messages[] = $this->describeInputDefinition($command->getNativeDefinition()); | ||||
|  | ||||
|         if ($help = $command->getProcessedHelp()) { | ||||
|             $messages[] = '<comment>Help:</comment>'; | ||||
|             $messages[] = ' '.str_replace("\n", "\n ", $help)."\n"; | ||||
|         } | ||||
|  | ||||
|         $output = implode("\n", $messages); | ||||
|  | ||||
|         return isset($options['raw_text']) && $options['raw_text'] ? strip_tags($output) : $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeApplication(Application $application, array $options = array()) | ||||
|     { | ||||
|         $describedNamespace = isset($options['namespace']) ? $options['namespace'] : null; | ||||
|         $description = new ApplicationDescription($application, $describedNamespace); | ||||
|         $messages = array(); | ||||
|  | ||||
|         if (isset($options['raw_text']) && $options['raw_text']) { | ||||
|             $width = $this->getColumnWidth($description->getCommands()); | ||||
|  | ||||
|             foreach ($description->getCommands() as $command) { | ||||
|                 $messages[] = sprintf("%-${width}s %s", $command->getName(), $command->getDescription()); | ||||
|             } | ||||
|         } else { | ||||
|             $width = $this->getColumnWidth($description->getCommands()); | ||||
|  | ||||
|             $messages[] = $application->getHelp(); | ||||
|             $messages[] = ''; | ||||
|  | ||||
|             if ($describedNamespace) { | ||||
|                 $messages[] = sprintf("<comment>Available commands for the \"%s\" namespace:</comment>", $describedNamespace); | ||||
|             } else { | ||||
|                 $messages[] = '<comment>Available commands:</comment>'; | ||||
|             } | ||||
|  | ||||
|             // add commands by namespace | ||||
|             foreach ($description->getNamespaces() as $namespace) { | ||||
|                 if (!$describedNamespace && ApplicationDescription::GLOBAL_NAMESPACE !== $namespace['id']) { | ||||
|                     $messages[] = '<comment>'.$namespace['id'].'</comment>'; | ||||
|                 } | ||||
|  | ||||
|                 foreach ($namespace['commands'] as $name) { | ||||
|                     $messages[] = sprintf("  <info>%-${width}s</info> %s", $name, $description->getCommand($name)->getDescription()); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $output = implode("\n", $messages); | ||||
|  | ||||
|         return isset($options['raw_text']) && $options['raw_text'] ? strip_tags($output) : $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Formats input option/argument default value. | ||||
|      * | ||||
|      * @param mixed $default | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     private function formatDefaultValue($default) | ||||
|     { | ||||
|         if (version_compare(PHP_VERSION, '5.4', '<')) { | ||||
|             return str_replace('\/', '/', json_encode($default)); | ||||
|         } | ||||
|  | ||||
|         return json_encode($default, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param Command[] $commands | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     private function getColumnWidth(array $commands) | ||||
|     { | ||||
|         $width = 0; | ||||
|         foreach ($commands as $command) { | ||||
|             $width = strlen($command->getName()) > $width ? strlen($command->getName()) : $width; | ||||
|         } | ||||
|  | ||||
|         return $width + 2; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										212
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/XmlDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										212
									
								
								vendor/symfony/console/Symfony/Component/Console/Descriptor/XmlDescriptor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,212 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * This file is part of the Symfony package. | ||||
|  * | ||||
|  * (c) Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| namespace Symfony\Component\Console\Descriptor; | ||||
|  | ||||
| use Symfony\Component\Console\Application; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
| use Symfony\Component\Console\Input\InputArgument; | ||||
| use Symfony\Component\Console\Input\InputDefinition; | ||||
| use Symfony\Component\Console\Input\InputOption; | ||||
|  | ||||
| /** | ||||
|  * XML descriptor. | ||||
|  * | ||||
|  * @author Jean-François Simon <contact@jfsimon.fr> | ||||
|  */ | ||||
| class XmlDescriptor extends Descriptor | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputArgument(InputArgument $argument, array $options = array()) | ||||
|     { | ||||
|         $dom = new \DOMDocument('1.0', 'UTF-8'); | ||||
|  | ||||
|         $dom->appendChild($objectXML = $dom->createElement('argument')); | ||||
|         $objectXML->setAttribute('name', $argument->getName()); | ||||
|         $objectXML->setAttribute('is_required', $argument->isRequired() ? 1 : 0); | ||||
|         $objectXML->setAttribute('is_array', $argument->isArray() ? 1 : 0); | ||||
|         $objectXML->appendChild($descriptionXML = $dom->createElement('description')); | ||||
|         $descriptionXML->appendChild($dom->createTextNode($argument->getDescription())); | ||||
|  | ||||
|         $objectXML->appendChild($defaultsXML = $dom->createElement('defaults')); | ||||
|         $defaults = is_array($argument->getDefault()) ? $argument->getDefault() : (is_bool($argument->getDefault()) ? array(var_export($argument->getDefault(), true)) : ($argument->getDefault() ? array($argument->getDefault()) : array())); | ||||
|         foreach ($defaults as $default) { | ||||
|             $defaultsXML->appendChild($defaultXML = $dom->createElement('default')); | ||||
|             $defaultXML->appendChild($dom->createTextNode($default)); | ||||
|         } | ||||
|  | ||||
|         return $this->output($dom, $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputOption(InputOption $option, array $options = array()) | ||||
|     { | ||||
|         $dom = new \DOMDocument('1.0', 'UTF-8'); | ||||
|  | ||||
|         $dom->appendChild($objectXML = $dom->createElement('option')); | ||||
|         $objectXML->setAttribute('name', '--'.$option->getName()); | ||||
|         $pos = strpos($option->getShortcut(), '|'); | ||||
|         if (false !== $pos) { | ||||
|             $objectXML->setAttribute('shortcut', '-'.substr($option->getShortcut(), 0, $pos)); | ||||
|             $objectXML->setAttribute('shortcuts', '-'.implode('|-', explode('|', $option->getShortcut()))); | ||||
|         } else { | ||||
|             $objectXML->setAttribute('shortcut', $option->getShortcut() ? '-'.$option->getShortcut() : ''); | ||||
|         } | ||||
|         $objectXML->setAttribute('accept_value', $option->acceptValue() ? 1 : 0); | ||||
|         $objectXML->setAttribute('is_value_required', $option->isValueRequired() ? 1 : 0); | ||||
|         $objectXML->setAttribute('is_multiple', $option->isArray() ? 1 : 0); | ||||
|         $objectXML->appendChild($descriptionXML = $dom->createElement('description')); | ||||
|         $descriptionXML->appendChild($dom->createTextNode($option->getDescription())); | ||||
|  | ||||
|         if ($option->acceptValue()) { | ||||
|             $defaults = is_array($option->getDefault()) ? $option->getDefault() : (is_bool($option->getDefault()) ? array(var_export($option->getDefault(), true)) : ($option->getDefault() ? array($option->getDefault()) : array())); | ||||
|             $objectXML->appendChild($defaultsXML = $dom->createElement('defaults')); | ||||
|  | ||||
|             if (!empty($defaults)) { | ||||
|                 foreach ($defaults as $default) { | ||||
|                     $defaultsXML->appendChild($defaultXML = $dom->createElement('default')); | ||||
|                     $defaultXML->appendChild($dom->createTextNode($default)); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this->output($dom, $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeInputDefinition(InputDefinition $definition, array $options = array()) | ||||
|     { | ||||
|         $dom = new \DOMDocument('1.0', 'UTF-8'); | ||||
|         $dom->appendChild($definitionXML = $dom->createElement('definition')); | ||||
|  | ||||
|         $definitionXML->appendChild($argumentsXML = $dom->createElement('arguments')); | ||||
|         foreach ($definition->getArguments() as $argument) { | ||||
|             $this->appendDocument($argumentsXML, $this->describeInputArgument($argument, array('as_dom' => true))); | ||||
|         } | ||||
|  | ||||
|         $definitionXML->appendChild($optionsXML = $dom->createElement('options')); | ||||
|         foreach ($definition->getOptions() as $option) { | ||||
|             $this->appendDocument($optionsXML, $this->describeInputOption($option, array('as_dom' => true))); | ||||
|         } | ||||
|  | ||||
|         return $this->output($dom, $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeCommand(Command $command, array $options = array()) | ||||
|     { | ||||
|         $dom = new \DOMDocument('1.0', 'UTF-8'); | ||||
|         $dom->appendChild($commandXML = $dom->createElement('command')); | ||||
|  | ||||
|         $command->getSynopsis(); | ||||
|         $command->mergeApplicationDefinition(false); | ||||
|  | ||||
|         $commandXML->setAttribute('id', $command->getName()); | ||||
|         $commandXML->setAttribute('name', $command->getName()); | ||||
|  | ||||
|         $commandXML->appendChild($usageXML = $dom->createElement('usage')); | ||||
|         $usageXML->appendChild($dom->createTextNode(sprintf($command->getSynopsis(), ''))); | ||||
|  | ||||
|         $commandXML->appendChild($descriptionXML = $dom->createElement('description')); | ||||
|         $descriptionXML->appendChild($dom->createTextNode(str_replace("\n", "\n ", $command->getDescription()))); | ||||
|  | ||||
|         $commandXML->appendChild($helpXML = $dom->createElement('help')); | ||||
|         $helpXML->appendChild($dom->createTextNode(str_replace("\n", "\n ", $command->getProcessedHelp()))); | ||||
|  | ||||
|         $commandXML->appendChild($aliasesXML = $dom->createElement('aliases')); | ||||
|         foreach ($command->getAliases() as $alias) { | ||||
|             $aliasesXML->appendChild($aliasXML = $dom->createElement('alias')); | ||||
|             $aliasXML->appendChild($dom->createTextNode($alias)); | ||||
|         } | ||||
|  | ||||
|         $definitionXML = $this->describeInputDefinition($command->getNativeDefinition(), array('as_dom' => true)); | ||||
|         $this->appendDocument($commandXML, $definitionXML->getElementsByTagName('definition')->item(0)); | ||||
|  | ||||
|         return $this->output($dom, $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function describeApplication(Application $application, array $options = array()) | ||||
|     { | ||||
|         $dom = new \DOMDocument('1.0', 'UTF-8'); | ||||
|         $dom->appendChild($rootXml = $dom->createElement('symfony')); | ||||
|         $rootXml->appendChild($commandsXML = $dom->createElement('commands')); | ||||
|  | ||||
|         $describedNamespace = isset($options['namespace']) ? $options['namespace'] : null; | ||||
|         $description = new ApplicationDescription($application, $describedNamespace); | ||||
|  | ||||
|         if ($describedNamespace) { | ||||
|             $commandsXML->setAttribute('namespace', $describedNamespace); | ||||
|         } | ||||
|  | ||||
|         foreach ($description->getCommands() as $command) { | ||||
|             $this->appendDocument($commandsXML, $this->describeCommand($command, array('as_dom' => true))); | ||||
|         } | ||||
|  | ||||
|         if (!$describedNamespace) { | ||||
|             $rootXml->appendChild($namespacesXML = $dom->createElement('namespaces')); | ||||
|  | ||||
|             foreach ($description->getNamespaces() as $namespace) { | ||||
|                 $namespacesXML->appendChild($namespaceArrayXML = $dom->createElement('namespace')); | ||||
|                 $namespaceArrayXML->setAttribute('id', $namespace['id']); | ||||
|  | ||||
|                 foreach ($namespace['commands'] as $name) { | ||||
|                     $namespaceArrayXML->appendChild($commandXML = $dom->createElement('command')); | ||||
|                     $commandXML->appendChild($dom->createTextNode($name)); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this->output($dom, $options); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Appends document children to parent node. | ||||
|      * | ||||
|      * @param \DOMNode $parentNode | ||||
|      * @param \DOMNode $importedParent | ||||
|      */ | ||||
|     private function appendDocument(\DOMNode $parentNode, \DOMNode $importedParent) | ||||
|     { | ||||
|         foreach ($importedParent->childNodes as $childNode) { | ||||
|             $parentNode->appendChild($parentNode->ownerDocument->importNode($childNode, true)); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Outputs document as DOMDocument or string according to options. | ||||
|      * | ||||
|      * @param \DOMDocument $dom | ||||
|      * @param array        $options | ||||
|      * | ||||
|      * @return \DOMDocument|string | ||||
|      */ | ||||
|     private function output(\DOMDocument $dom, array $options) | ||||
|     { | ||||
|         if (isset($options['as_dom']) && $options['as_dom']) { | ||||
|             return $dom; | ||||
|         } | ||||
|  | ||||
|         $dom->formatOutput = true; | ||||
|  | ||||
|         return $dom->saveXML(); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user