You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
84 lines
2.1 KiB
84 lines
2.1 KiB
<?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\Caster;
|
|
|
|
use Symfony\Component\VarDumper\Cloner\Stub;
|
|
|
|
/**
|
|
* Casts a caster's Stub.
|
|
*
|
|
* @author Nicolas Grekas <p@tchwork.com>
|
|
*
|
|
* @final
|
|
*/
|
|
class StubCaster
|
|
{
|
|
public static function castStub(Stub $c, array $a, Stub $stub, bool $isNested)
|
|
{
|
|
if ($isNested) {
|
|
$stub->type = $c->type;
|
|
$stub->class = $c->class;
|
|
$stub->value = $c->value;
|
|
$stub->handle = $c->handle;
|
|
$stub->cut = $c->cut;
|
|
$stub->attr = $c->attr;
|
|
|
|
if (Stub::TYPE_REF === $c->type && !$c->class && \is_string($c->value) && !preg_match('//u', $c->value)) {
|
|
$stub->type = Stub::TYPE_STRING;
|
|
$stub->class = Stub::STRING_BINARY;
|
|
}
|
|
|
|
$a = [];
|
|
}
|
|
|
|
return $a;
|
|
}
|
|
|
|
public static function castCutArray(CutArrayStub $c, array $a, Stub $stub, bool $isNested)
|
|
{
|
|
return $isNested ? $c->preservedSubset : $a;
|
|
}
|
|
|
|
public static function cutInternals($obj, array $a, Stub $stub, bool $isNested)
|
|
{
|
|
if ($isNested) {
|
|
$stub->cut += \count($a);
|
|
|
|
return [];
|
|
}
|
|
|
|
return $a;
|
|
}
|
|
|
|
public static function castEnum(EnumStub $c, array $a, Stub $stub, bool $isNested)
|
|
{
|
|
if ($isNested) {
|
|
$stub->class = $c->dumpKeys ? '' : null;
|
|
$stub->handle = 0;
|
|
$stub->value = null;
|
|
$stub->cut = $c->cut;
|
|
$stub->attr = $c->attr;
|
|
|
|
$a = [];
|
|
|
|
if ($c->value) {
|
|
foreach (array_keys($c->value) as $k) {
|
|
$keys[] = !isset($k[0]) || "\0" !== $k[0] ? Caster::PREFIX_VIRTUAL.$k : $k;
|
|
}
|
|
// Preserve references with array_combine()
|
|
$a = array_combine($keys, $c->value);
|
|
}
|
|
}
|
|
|
|
return $a;
|
|
}
|
|
}
|