Файл: 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';
}
}