Файл: symfony-2.7/src/Symfony/Bridge/Twig/Extension/ProfilerExtension.php
Строк: 52
<?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 SymfonyBridgeTwigExtension;
use SymfonyComponentStopwatchStopwatch;
/**
 * @author Fabien Potencier <fabien@symfony.com>
 */
class ProfilerExtension extends Twig_Extension_Profiler
{
    private $stopwatch;
    private $events;
    public function __construct(Twig_Profiler_Profile $profile, Stopwatch $stopwatch = null)
    {
        parent::__construct($profile);
        $this->stopwatch = $stopwatch;
        $this->events = new SplObjectStorage();
    }
    public function enter(Twig_Profiler_Profile $profile)
    {
        if ($this->stopwatch && $profile->isTemplate()) {
            $this->events[$profile] = $this->stopwatch->start($profile->getName(), 'template');
        }
        parent::enter($profile);
    }
    public function leave(Twig_Profiler_Profile $profile)
    {
        parent::leave($profile);
        if ($this->stopwatch && $profile->isTemplate()) {
            $this->events[$profile]->stop();
            unset($this->events[$profile]);
        }
    }
    /**
     * {@inheritdoc}
     */
    public function getName()
    {
        return 'native_profiler';
    }
}