HtmlDumper.php
TLDR
This file contains the HtmlDumper
class which extends BaseHtmlDumper
and is used to dump variables with their source file and line. It also includes methods for creating a new HTML dumper instance, registering it as the default dumper, and dumping a variable with its source file and line.
Methods
__construct($basePath, $compiledViewPath)
The constructor method of the HtmlDumper
class. It initializes the basePath
and compiledViewPath
properties of the instance.
register($basePath, $compiledViewPath)
A static method of the HtmlDumper
class that creates a new HTML dumper instance and registers it as the default dumper. It takes the basePath
and compiledViewPath
as parameters.
dumpWithSource($data)
A method of the HtmlDumper
class that dumps a variable with its source file and line. It takes a Data
object as a parameter.
getDumpSourceContent()
A protected method of the HtmlDumper
class that returns the dump's source HTML content.
Classes
HtmlDumper
The HtmlDumper
class extends the BaseHtmlDumper
class and is used to dump variables with their source file and line.
<?php
namespace Illuminate\Foundation\Http;
use Illuminate\Foundation\Concerns\ResolvesDumpSource;
use Symfony\Component\VarDumper\Caster\ReflectionCaster;
use Symfony\Component\VarDumper\Cloner\Data;
use Symfony\Component\VarDumper\Cloner\VarCloner;
use Symfony\Component\VarDumper\Dumper\HtmlDumper as BaseHtmlDumper;
use Symfony\Component\VarDumper\VarDumper;
class HtmlDumper extends BaseHtmlDumper
{
use ResolvesDumpSource;
/**
* Where the source should be placed on "expanded" kind of dumps.
*
* @var string
*/
const EXPANDED_SEPARATOR = 'class=sf-dump-expanded>';
/**
* Where the source should be placed on "non expanded" kind of dumps.
*
* @var string
*/
const NON_EXPANDED_SEPARATOR = "\n</pre><script>";
/**
* The base path of the application.
*
* @var string
*/
protected $basePath;
/**
* The compiled view path of the application.
*
* @var string
*/
protected $compiledViewPath;
/**
* If the dumper is currently dumping.
*
* @var bool
*/
protected $dumping = false;
/**
* Create a new HTML dumper instance.
*
* @param string $basePath
* @param string $compiledViewPath
* @return void
*/
public function __construct($basePath, $compiledViewPath)
{
parent::__construct();
$this->basePath = $basePath;
$this->compiledViewPath = $compiledViewPath;
}
/**
* Create a new HTML dumper instance and register it as the default dumper.
*
* @param string $basePath
* @param string $compiledViewPath
* @return void
*/
public static function register($basePath, $compiledViewPath)
{
$cloner = tap(new VarCloner())->addCasters(ReflectionCaster::UNSET_CLOSURE_FILE_INFO);
$dumper = new static($basePath, $compiledViewPath);
VarDumper::setHandler(fn ($value) => $dumper->dumpWithSource($cloner->cloneVar($value)));
}
/**
* Dump a variable with its source file / line.
*
* @param \Symfony\Component\VarDumper\Cloner\Data $data
* @return void
*/
public function dumpWithSource(Data $data)
{
if ($this->dumping) {
$this->dump($data);
return;
}
$this->dumping = true;
$output = (string) $this->dump($data, true);
$output = match (true) {
str_contains($output, static::EXPANDED_SEPARATOR) => str_replace(
static::EXPANDED_SEPARATOR,
static::EXPANDED_SEPARATOR.$this->getDumpSourceContent(),
$output,
),
str_contains($output, static::NON_EXPANDED_SEPARATOR) => str_replace(
static::NON_EXPANDED_SEPARATOR,
$this->getDumpSourceContent().static::NON_EXPANDED_SEPARATOR,
$output,
),
default => $output,
};
fwrite($this->outputStream, $output);
$this->dumping = false;
}
/**
* Get the dump's source HTML content.
*
* @return string
*/
protected function getDumpSourceContent()
{
if (is_null($dumpSource = $this->resolveDumpSource())) {
return '';
}
[$file, $relativeFile, $line] = $dumpSource;
$source = sprintf('%s%s', $relativeFile, is_null($line) ? '' : ":$line");
if ($href = $this->resolveSourceHref($file, $line)) {
$source = sprintf('<a href="%s">%s</a>', $href, $source);
}
return sprintf('<span style="color: #A0A0A0;"> // %s</span>', $source);
}
}