Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

DataCollector.php

Namespace

Symfony\Component\HttpKernel\DataCollector

File

vendor/symfony/http-kernel/DataCollector/DataCollector.php

View source
<?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\HttpKernel\DataCollector;

use Symfony\Component\VarDumper\Caster\CutStub;
use Symfony\Component\VarDumper\Caster\ReflectionCaster;
use Symfony\Component\VarDumper\Cloner\ClonerInterface;
use Symfony\Component\VarDumper\Cloner\Data;
use Symfony\Component\VarDumper\Cloner\Stub;
use Symfony\Component\VarDumper\Cloner\VarCloner;

/**
 * DataCollector.
 *
 * Children of this class must store the collected data in the data property.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 * @author Bernhard Schussek <bschussek@symfony.com>
 */
abstract class DataCollector implements DataCollectorInterface {
    protected array|Data $data = [];
    private ClonerInterface $cloner;
    
    /**
     * Converts the variable into a serializable Data instance.
     *
     * This array can be displayed in the template using
     * the VarDumper component.
     */
    protected function cloneVar(mixed $var) : Data {
        if ($var instanceof Data) {
            return $var;
        }
        if (!isset($this->cloner)) {
            $this->cloner = new VarCloner();
            $this->cloner
                ->setMaxItems(-1);
            $this->cloner
                ->addCasters($this->getCasters());
        }
        return $this->cloner
            ->cloneVar($var);
    }
    
    /**
     * @return callable[] The casters to add to the cloner
     */
    protected function getCasters() : array {
        return [
            '*' => function ($v, array $a, Stub $s, $isNested) {
                if (!$v instanceof Stub) {
                    $b = $a;
                    foreach ($a as $k => $v) {
                        if (!\is_object($v) || $v instanceof \DateTimeInterface || $v instanceof Stub) {
                            continue;
                        }
                        try {
                            $a[$k] = $s = new CutStub($v);
                            if ($b[$k] === $s) {
                                // we've hit a non-typed reference
                                $a[$k] = $v;
                            }
                        } catch (\TypeError $e) {
                            // we've hit a typed reference
                        }
                    }
                }
                return $a;
            },
        ] + ReflectionCaster::UNSET_CLOSURE_FILE_INFO;
    }
    public function __sleep() : array {
        return [
            'data',
        ];
    }
    public function __wakeup() : void {
    }
    
    /**
     * @internal to prevent implementing \Serializable
     */
    protected final function serialize() : void {
    }
    
    /**
     * @internal to prevent implementing \Serializable
     */
    protected final function unserialize(string $data) : void {
    }
    
    /**
     * @return void
     */
    public function reset() {
        $this->data = [];
    }

}

Classes

Title Deprecated Summary
DataCollector DataCollector.
RSS feed
Powered by Drupal