当前位置: 首页>>代码示例>>PHP>>正文


PHP OutputInterface::getVerbosity方法代码示例

本文整理汇总了PHP中Symfony\Components\Console\Output\OutputInterface::getVerbosity方法的典型用法代码示例。如果您正苦于以下问题:PHP OutputInterface::getVerbosity方法的具体用法?PHP OutputInterface::getVerbosity怎么用?PHP OutputInterface::getVerbosity使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Symfony\Components\Console\Output\OutputInterface的用法示例。


在下文中一共展示了OutputInterface::getVerbosity方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: renderException

 /**
  * Renders a catched exception.
  *
  * @param Exception       $e      An exception instance
  * @param OutputInterface $output An OutputInterface instance
  */
 public function renderException($e, $output)
 {
     $strlen = function ($string) {
         return function_exists('mb_strlen') ? mb_strlen($string) : strlen($string);
     };
     $title = sprintf('  [%s]  ', get_class($e));
     $len = $strlen($title);
     $lines = array();
     foreach (explode("\n", $e->getMessage()) as $line) {
         $lines[] = sprintf('  %s  ', $line);
         $len = max($strlen($line) + 4, $len);
     }
     $messages = array(str_repeat(' ', $len), $title . str_repeat(' ', $len - $strlen($title)));
     foreach ($lines as $line) {
         $messages[] = $line . str_repeat(' ', $len - $strlen($line));
     }
     $messages[] = str_repeat(' ', $len);
     $output->writeln("\n");
     foreach ($messages as $message) {
         $output->writeln("<error>{$message}</error>");
     }
     $output->writeln("\n");
     if (null !== $this->runningCommand) {
         $output->writeln(sprintf('<info>%s</info>', sprintf($this->runningCommand->getSynopsis(), $this->getName())));
         $output->writeln("\n");
     }
     if (Output::VERBOSITY_VERBOSE === $output->getVerbosity()) {
         $output->writeln('</comment>Exception trace:</comment>');
         // exception related properties
         $trace = $e->getTrace();
         array_unshift($trace, array('function' => '', 'file' => $e->getFile() != null ? $e->getFile() : 'n/a', 'line' => $e->getLine() != null ? $e->getLine() : 'n/a', 'args' => array()));
         for ($i = 0, $count = count($trace); $i < $count; $i++) {
             $class = isset($trace[$i]['class']) ? $trace[$i]['class'] : '';
             $type = isset($trace[$i]['type']) ? $trace[$i]['type'] : '';
             $function = $trace[$i]['function'];
             $file = isset($trace[$i]['file']) ? $trace[$i]['file'] : 'n/a';
             $line = isset($trace[$i]['line']) ? $trace[$i]['line'] : 'n/a';
             $output->writeln(sprintf(' %s%s%s() at <info>%s:%s</info>', $class, $type, $function, $file, $line));
         }
         $output->writeln("\n");
     }
 }
开发者ID:poulikov,项目名称:readlater,代码行数:48,代码来源:Application.php


注:本文中的Symfony\Components\Console\Output\OutputInterface::getVerbosity方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。