A super easy PHP Framework for web development!
				https://github.com/exacti/phacil-framework
			
			
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					63 lines
				
				1.8 KiB
			
		
		
			
		
	
	
					63 lines
				
				1.8 KiB
			| 
								 
											7 years ago
										 
									 | 
							
								<?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.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @author Fabien Potencier <fabien@symfony.com>
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								abstract class Twig_Profiler_Dumper_Base
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    private $root;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function dump(Twig_Profiler_Profile $profile)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return $this->dumpProfile($profile);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    abstract protected function formatTemplate(Twig_Profiler_Profile $profile, $prefix);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    abstract protected function formatNonTemplate(Twig_Profiler_Profile $profile, $prefix);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    abstract protected function formatTime(Twig_Profiler_Profile $profile, $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 %s\n", $start, $this->formatTime($profile, $percent));
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $nCount = count($profile->getProfiles());
							 | 
						||
| 
								 | 
							
								        foreach ($profile as $i => $p) {
							 | 
						||
| 
								 | 
							
								            $str .= $this->dumpProfile($p, $prefix, $i + 1 !== $nCount);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return $str;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class_alias('Twig_Profiler_Dumper_Base', 'Twig\Profiler\Dumper\BaseDumper', false);
							 | 
						||
| 
								 | 
							
								class_exists('Twig_Profiler_Profile');
							 |