Вход Регистрация
Файл: forsoc.ru/vendor/twig/twig/lib/Twig/Profiler/Dumper/Text.php
Строк: 49
<?php

/*
 * This file is part of Twig.
 *
 * (c) 2015 Fabien Potencier
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

/**
 * @author Fabien Potencier <fabien@symfony.com>
 */
class Twig_Profiler_Dumper_Text
{
    private 
$root;

    public function 
dump(Twig_Profiler_Profile $profile)
    {
        return 
$this->dumpProfile($profile);
    }

    protected function 
formatTemplate(Twig_Profiler_Profile $profile$prefix)
    {
        return 
sprintf('%s└ %s'$prefix$profile->getTemplate());
    }

    protected function 
formatNonTemplate(Twig_Profiler_Profile $profile$prefix)
    {
        return 
sprintf('%s└ %s::%s(%s)'$prefix$profile->getTemplate(), $profile->getType(), $profile->getName());
    }

    protected function 
formatTime(Twig_Profiler_Profile $profile$percent)
    {
        return 
sprintf('%.2fms/%.0f%%'$profile->getDuration() * 1000$percent);
    }

    private function 
dumpProfile(Twig_Profiler_Profile $profile$prefix ''$sibling false)
    {
        if (
$profile->isRoot()) {
            
$this->root $profile->getDuration();
            
$start $profile->getName();
        } else {
            if (
$profile->isTemplate()) {
                
$start $this->formatTemplate($profile$prefix);
            } else {
                
$start $this->formatNonTemplate($profile$prefix);
            }
            
$prefix .= $sibling '│ ' '  ';
        }

        
$percent $this->root $profile->getDuration() / $this->root 100 0;

        if (
$profile->getDuration() * 1000 1) {
            
$str $start."n";
        } else {
            
$str sprintf("%s %sn"$start$this->formatTime($profile$percent));
        }

        
$nCount count($profile->getProfiles());
        foreach (
$profile as $i => $p) {
            
$str .= $this->dumpProfile($p$prefix$i !== $nCount);
        }

        return 
$str;
    }
}
Онлайн: 1
Реклама