leilukin-tumbleblog/includes/lib/Twig/Profiler/Dumper/HtmlDumper.php

48 lines
1.4 KiB
PHP
Raw Permalink Normal View History

2024-06-20 14:10:42 +00:00
<?php
/*
* This file is part of Twig.
*
* (c) Fabien Potencier
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Twig\Profiler\Dumper;
use Twig\Profiler\Profile;
/**
* @author Fabien Potencier <fabien@symfony.com>
*/
final class HtmlDumper extends BaseDumper
{
private static $colors = [
'block' => '#dfd',
'macro' => '#ddf',
'template' => '#ffd',
'big' => '#d44',
];
public function dump(Profile $profile): string
{
return '<pre>'.parent::dump($profile).'</pre>';
}
protected function formatTemplate(Profile $profile, $prefix): string
{
2024-09-05 17:51:48 +00:00
return \sprintf('%s└ <span style="background-color: %s">%s</span>', $prefix, self::$colors['template'], $profile->getTemplate());
2024-06-20 14:10:42 +00:00
}
protected function formatNonTemplate(Profile $profile, $prefix): string
{
2024-09-05 17:51:48 +00:00
return \sprintf('%s└ %s::%s(<span style="background-color: %s">%s</span>)', $prefix, $profile->getTemplate(), $profile->getType(), self::$colors[$profile->getType()] ?? 'auto', $profile->getName());
2024-06-20 14:10:42 +00:00
}
protected function formatTime(Profile $profile, $percent): string
{
2024-09-05 17:51:48 +00:00
return \sprintf('<span style="color: %s">%.2fms/%.0f%%</span>', $percent > 20 ? self::$colors['big'] : 'auto', $profile->getDuration() * 1000, $percent);
2024-06-20 14:10:42 +00:00
}
}