<?php /* * This file is part of Psy Shell. * * (c) 2012-2023 Justin Hileman * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Psy\Command; use Psy\Formatter\TraceFormatter; use Psy\Input\FilterOptions; use Psy\Output\ShellOutput; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Output\OutputInterface; /** * Show the current stack trace. */ class TraceCommand extends Command { protected $filter; /** * {@inheritdoc} */ public function __construct($name = null) { $this->filter = new FilterOptions(); parent::__construct($name); } /** * {@inheritdoc} */ protected function configure() { list($grep, $insensitive, $invert) = FilterOptions::getOptions(); $this ->setName('trace') ->setDefinition([ new InputOption('include-psy', 'p', InputOption::VALUE_NONE, 'Include Psy in the call stack.'), new InputOption('num', 'n', InputOption::VALUE_REQUIRED, 'Only include NUM lines.'), $grep, $insensitive, $invert, ]) ->setDescription('Show the current call stack.') ->setHelp( <<<'HELP' Show the current call stack. Optionally, include PsySH in the call stack by passing the <info>--include-psy</info> option. e.g. <return>> trace -n10</return> <return>> trace --include-psy</return> HELP ); } /** * {@inheritdoc} * * @return int 0 if everything went fine, or an exit code */ protected function execute(InputInterface $input, OutputInterface $output) { $this->filter->bind($input); $trace = $this->getBacktrace(new \Exception(), $input->getOption('num'), $input->getOption('include-psy')); $output->page($trace, ShellOutput::NUMBER_LINES); return 0; } /** * Get a backtrace for an exception or error. * * Optionally limit the number of rows to include with $count, and exclude * Psy from the trace. * * @param \Throwable $e The exception or error with a backtrace * @param int $count (default: PHP_INT_MAX) * @param bool $includePsy (default: true) * * @return array Formatted stacktrace lines */ protected function getBacktrace(\Throwable $e, int $count = null, bool $includePsy = true): array { return TraceFormatter::formatTrace($e, $this->filter, $count, $includePsy); } }
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
ListCommand | Folder | 0755 |
|
|
TimeitCommand | Folder | 0755 |
|
|
BufferCommand.php | File | 2.43 KB | 0644 |
|
ClearCommand.php | File | 1.1 KB | 0644 |
|
Command.php | File | 7.67 KB | 0644 |
|
DocCommand.php | File | 9.03 KB | 0644 |
|
DumpCommand.php | File | 2.55 KB | 0644 |
|
EditCommand.php | File | 5.72 KB | 0644 |
|
ExitCommand.php | File | 1.13 KB | 0644 |
|
HelpCommand.php | File | 2.95 KB | 0644 |
|
HistoryCommand.php | File | 7.51 KB | 0644 |
|
ListCommand.php | File | 9.81 KB | 0644 |
|
ParseCommand.php | File | 4.67 KB | 0644 |
|
PsyVersionCommand.php | File | 953 B | 0644 |
|
ReflectingCommand.php | File | 11.6 KB | 0644 |
|
ShowCommand.php | File | 9.64 KB | 0644 |
|
SudoCommand.php | File | 3.76 KB | 0644 |
|
ThrowUpCommand.php | File | 4.36 KB | 0644 |
|
TimeitCommand.php | File | 5.29 KB | 0644 |
|
TraceCommand.php | File | 2.63 KB | 0644 |
|
WhereamiCommand.php | File | 4.26 KB | 0644 |
|
WtfCommand.php | File | 3.76 KB | 0644 |
|