TYPO3  7.6
HelpCommand.php
Go to the documentation of this file.
1 <?php
2 
3 /*
4  * This file is part of the Symfony package.
5  *
6  * (c) Fabien Potencier <fabien@symfony.com>
7  *
8  * For the full copyright and license information, please view the LICENSE
9  * file that was distributed with this source code.
10  */
11 
13 
19 
25 class HelpCommand extends Command
26 {
27  private $command;
28 
32  protected function configure()
33  {
34  $this->ignoreValidationErrors();
35 
36  $this
37  ->setName('help')
38  ->setDefinition(array(
39  new InputArgument('command_name', InputArgument::OPTIONAL, 'The command name', 'help'),
40  new InputOption('xml', null, InputOption::VALUE_NONE, 'To output help as XML'),
41  new InputOption('format', null, InputOption::VALUE_REQUIRED, 'The output format (txt, xml, json, or md)', 'txt'),
42  new InputOption('raw', null, InputOption::VALUE_NONE, 'To output raw command help'),
43  ))
44  ->setDescription('Displays help for a command')
45  ->setHelp(<<<EOF
46 The <info>%command.name%</info> command displays help for a given command:
47 
48  <info>php %command.full_name% list</info>
49 
50 You can also output the help in other formats by using the <comment>--format</comment> option:
51 
52  <info>php %command.full_name% --format=xml list</info>
53 
54 To display the list of available commands, please use the <info>list</info> command.
55 EOF
56  )
57  ;
58  }
59 
65  public function setCommand(Command $command)
66  {
67  $this->command = $command;
68  }
69 
73  protected function execute(InputInterface $input, OutputInterface $output)
74  {
75  if (null === $this->command) {
76  $this->command = $this->getApplication()->find($input->getArgument('command_name'));
77  }
78 
79  if ($input->getOption('xml')) {
80  @trigger_error('The --xml option was deprecated in version 2.7 and will be removed in version 3.0. Use the --format option instead.', E_USER_DEPRECATED);
81 
82  $input->setOption('format', 'xml');
83  }
84 
85  $helper = new DescriptorHelper();
86  $helper->describe($output, $this->command, array(
87  'format' => $input->getOption('format'),
88  'raw_text' => $input->getOption('raw'),
89  ));
90 
91  $this->command = null;
92  }
93 }