DebugExtension.php

Same filename and directory in other branches
  1. 9 core/lib/Drupal/Core/Template/DebugExtension.php
  2. 10 core/lib/Drupal/Core/Template/DebugExtension.php

Namespace

Drupal\Core\Template

File

core/lib/Drupal/Core/Template/DebugExtension.php

View source
<?php

namespace Drupal\Core\Template;

use Twig\Environment;
use Twig\Extension\AbstractExtension;
use Twig\TwigFunction;

/**
 * A class providing Drupal Twig Debug extension.
 */
final class DebugExtension extends AbstractExtension {
    
    /**
     * The Symfony VarDumper class.
     *
     * Defined as a string because the Symfony VarDumper does not always exist.
     *
     * @var string
     */
    private const SYMFONY_VAR_DUMPER_CLASS = '\\Symfony\\Component\\VarDumper\\VarDumper';
    
    /**
     * {@inheritdoc}
     */
    public function getFunctions() : array {
        // Override Twig built in debugger when Symfony VarDumper is available to
        // improve developer experience.
        // @see \Twig\Extension\DebugExtension
        // @see \Symfony\Component\VarDumper\VarDumper
        if (class_exists(self::SYMFONY_VAR_DUMPER_CLASS)) {
            return [
                new TwigFunction('dump', [
                    self::class,
                    'dump',
                ], [
                    'needs_context' => TRUE,
                    'needs_environment' => TRUE,
                    'is_variadic' => TRUE,
                ]),
            ];
        }
        return [];
    }
    
    /**
     * Dumps information about variables using Symfony VarDumper.
     *
     * @param \Twig\Environment $env
     *   The Twig environment.
     * @param array $context
     *   Variables from the Twig template.
     * @param array $variables
     *   (optional) Variable(s) to dump.
     */
    public static function dump(Environment $env, array $context, ...$variables) : void {
        if (!$env->isDebug()) {
            return;
        }
        if (class_exists(self::SYMFONY_VAR_DUMPER_CLASS)) {
            if (func_num_args() === 2) {
                call_user_func(self::SYMFONY_VAR_DUMPER_CLASS . '::dump', $context);
            }
            else {
                array_walk($variables, self::SYMFONY_VAR_DUMPER_CLASS . '::dump');
            }
        }
        else {
            throw new \LogicException('Could not dump the variable because symfony/var-dumper component is not installed.');
        }
    }

}

Classes

Title Deprecated Summary
DebugExtension A class providing Drupal Twig Debug extension.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.