當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ConsoleOptionParser::subcommands方法代碼示例

本文整理匯總了PHP中Cake\Console\ConsoleOptionParser::subcommands方法的典型用法代碼示例。如果您正苦於以下問題:PHP ConsoleOptionParser::subcommands方法的具體用法?PHP ConsoleOptionParser::subcommands怎麽用?PHP ConsoleOptionParser::subcommands使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Cake\Console\ConsoleOptionParser的用法示例。


在下文中一共展示了ConsoleOptionParser::subcommands方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: _generateUsage

 /**
  * Generate the usage for a shell based on its arguments and options.
  * Usage strings favor short options over the long ones. and optional args will
  * be indicated with []
  *
  * @return string
  */
 protected function _generateUsage()
 {
     $usage = ['cake ' . $this->_parser->command()];
     $subcommands = $this->_parser->subcommands();
     if (!empty($subcommands)) {
         $usage[] = '[subcommand]';
     }
     $options = [];
     foreach ($this->_parser->options() as $option) {
         $options[] = $option->usage();
     }
     if (count($options) > $this->_maxOptions) {
         $options = ['[options]'];
     }
     $usage = array_merge($usage, $options);
     $args = [];
     foreach ($this->_parser->arguments() as $argument) {
         $args[] = $argument->usage();
     }
     if (count($args) > $this->_maxArgs) {
         $args = ['[arguments]'];
     }
     $usage = array_merge($usage, $args);
     return implode(' ', $usage);
 }
開發者ID:rlugojr,項目名稱:cakephp,代碼行數:32,代碼來源:HelpFormatter.php

示例2: runCommand

 /**
  * Runs the Shell with the provided argv.
  *
  * Delegates calls to Tasks and resolves methods inside the class. Commands are looked
  * up with the following order:
  *
  * - Method on the shell.
  * - Matching task name.
  * - `main()` method.
  *
  * If a shell implements a `main()` method, all missing method calls will be sent to
  * `main()` with the original method name in the argv.
  *
  * For tasks to be invoked they *must* be exposed as subcommands. If you define any subcommands,
  * you must define all the subcommands your shell needs, whether they be methods on this class
  * or methods on tasks.
  *
  * @param array $argv Array of arguments to run the shell with. This array should be missing the shell name.
  * @param bool $autoMethod Set to true to allow any public method to be called even if it
  *   was not defined as a subcommand. This is used by ShellDispatcher to make building simple shells easy.
  * @param array $extra Extra parameters that you can manually pass to the Shell
  * to be dispatched.
  * Built-in extra parameter is :
  * - `requested` : if used, will prevent the Shell welcome message to be displayed
  * @return mixed
  * @link http://book.cakephp.org/3.0/en/console-and-shells.html#the-cakephp-console
  */
 public function runCommand($argv, $autoMethod = false, $extra = [])
 {
     $command = isset($argv[0]) ? $argv[0] : null;
     $this->OptionParser = $this->getOptionParser();
     try {
         list($this->params, $this->args) = $this->OptionParser->parse($argv);
     } catch (ConsoleException $e) {
         $this->err('<error>Error: ' . $e->getMessage() . '</error>');
         $this->out($this->OptionParser->help($command));
         return false;
     }
     if (!empty($extra) && is_array($extra)) {
         $this->params = array_merge($this->params, $extra);
     }
     if (!empty($this->params['quiet'])) {
         $this->_io->level(ConsoleIo::QUIET);
         $this->_io->setLoggers(false);
     }
     if (!empty($this->params['verbose'])) {
         $this->_io->level(ConsoleIo::VERBOSE);
     }
     if (!empty($this->params['plugin'])) {
         Plugin::load($this->params['plugin']);
     }
     $this->command = $command;
     if (!empty($this->params['help'])) {
         return $this->_displayHelp($command);
     }
     $subcommands = $this->OptionParser->subcommands();
     $method = Inflector::camelize($command);
     $isMethod = $this->hasMethod($method);
     if ($isMethod && $autoMethod && count($subcommands) === 0) {
         array_shift($this->args);
         $this->startup();
         return call_user_func_array([$this, $method], $this->args);
     }
     if ($isMethod && isset($subcommands[$command])) {
         $this->startup();
         return call_user_func_array([$this, $method], $this->args);
     }
     if ($this->hasTask($command) && isset($subcommands[$command])) {
         $this->startup();
         array_shift($argv);
         return $this->{$method}->runCommand($argv, false);
     }
     if ($this->hasMethod('main')) {
         $this->startup();
         return call_user_func_array([$this, 'main'], $this->args);
     }
     $this->out($this->OptionParser->help($command));
     return false;
 }
開發者ID:eddiePower,項目名稱:cakephp,代碼行數:79,代碼來源:Shell.php

示例3: testRemoveSubcommand

 /**
  * test removeSubcommand with an object.
  *
  * @return void
  */
 public function testRemoveSubcommand()
 {
     $parser = new ConsoleOptionParser('test', false);
     $parser->addSubcommand(new ConsoleInputSubcommand('test'));
     $result = $parser->subcommands();
     $this->assertEquals(1, count($result));
     $parser->removeSubcommand('test');
     $result = $parser->subcommands();
     $this->assertEquals(0, count($result), 'Remove a subcommand does not work');
 }
開發者ID:JesseDarellMoore,項目名稱:CS499,代碼行數:15,代碼來源:ConsoleOptionParserTest.php

示例4: testAddSubcommandObject

 /**
  * test addSubcommand with an object.
  *
  * @return void
  */
 public function testAddSubcommandObject()
 {
     $parser = new ConsoleOptionParser('test', false);
     $parser->addSubcommand(new ConsoleInputSubcommand('test'));
     $result = $parser->subcommands();
     $this->assertEquals(1, count($result));
     $this->assertEquals('test', $result['test']->name());
 }
開發者ID:ripzappa0924,項目名稱:carte0.0.1,代碼行數:13,代碼來源:ConsoleOptionParserTest.php


注:本文中的Cake\Console\ConsoleOptionParser::subcommands方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。