2020-01-01 13:17:19 +08:00
|
|
|
<?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\VarDumper\Command\Descriptor;
|
|
|
|
|
|
|
|
use Symfony\Component\Console\Formatter\OutputFormatterStyle;
|
|
|
|
use Symfony\Component\Console\Input\ArrayInput;
|
|
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
|
|
use Symfony\Component\Console\Style\SymfonyStyle;
|
|
|
|
use Symfony\Component\VarDumper\Cloner\Data;
|
|
|
|
use Symfony\Component\VarDumper\Dumper\CliDumper;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Describe collected data clones for cli output.
|
|
|
|
*
|
|
|
|
* @author Maxime Steinhausser <maxime.steinhausser@gmail.com>
|
|
|
|
*
|
|
|
|
* @final
|
|
|
|
*/
|
|
|
|
class CliDescriptor implements DumpDescriptorInterface
|
|
|
|
{
|
|
|
|
private $dumper;
|
|
|
|
private $lastIdentifier;
|
|
|
|
private $supportsHref;
|
|
|
|
|
|
|
|
public function __construct(CliDumper $dumper)
|
|
|
|
{
|
|
|
|
$this->dumper = $dumper;
|
|
|
|
$this->supportsHref = method_exists(OutputFormatterStyle::class, 'setHref');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function describe(OutputInterface $output, Data $data, array $context, int $clientId): void
|
|
|
|
{
|
|
|
|
$io = $output instanceof SymfonyStyle ? $output : new SymfonyStyle(new ArrayInput([]), $output);
|
|
|
|
$this->dumper->setColors($output->isDecorated());
|
|
|
|
|
2021-08-04 18:44:24 +08:00
|
|
|
$rows = [['date', date('r', (int) $context['timestamp'])]];
|
2020-01-01 13:17:19 +08:00
|
|
|
$lastIdentifier = $this->lastIdentifier;
|
|
|
|
$this->lastIdentifier = $clientId;
|
|
|
|
|
|
|
|
$section = "Received from client #$clientId";
|
|
|
|
if (isset($context['request'])) {
|
|
|
|
$request = $context['request'];
|
|
|
|
$this->lastIdentifier = $request['identifier'];
|
|
|
|
$section = sprintf('%s %s', $request['method'], $request['uri']);
|
|
|
|
if ($controller = $request['controller']) {
|
|
|
|
$rows[] = ['controller', rtrim($this->dumper->dump($controller, true), "\n")];
|
|
|
|
}
|
|
|
|
} elseif (isset($context['cli'])) {
|
|
|
|
$this->lastIdentifier = $context['cli']['identifier'];
|
|
|
|
$section = '$ '.$context['cli']['command_line'];
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->lastIdentifier !== $lastIdentifier) {
|
|
|
|
$io->section($section);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($context['source'])) {
|
|
|
|
$source = $context['source'];
|
|
|
|
$sourceInfo = sprintf('%s on line %d', $source['name'], $source['line']);
|
|
|
|
$fileLink = $source['file_link'] ?? null;
|
|
|
|
if ($this->supportsHref && $fileLink) {
|
|
|
|
$sourceInfo = sprintf('<href=%s>%s</>', $fileLink, $sourceInfo);
|
|
|
|
}
|
|
|
|
$rows[] = ['source', $sourceInfo];
|
|
|
|
$file = $source['file_relative'] ?? $source['file'];
|
|
|
|
$rows[] = ['file', $file];
|
|
|
|
}
|
|
|
|
|
|
|
|
$io->table([], $rows);
|
|
|
|
|
|
|
|
if (!$this->supportsHref && isset($fileLink)) {
|
|
|
|
$io->writeln(['<info>Open source in your IDE/browser:</info>', $fileLink]);
|
|
|
|
$io->newLine();
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->dumper->dump($data);
|
|
|
|
$io->newLine();
|
|
|
|
}
|
|
|
|
}
|