source: trunk/client/inc/hpdf5/spipu/html2pdf/src/Debug/Debug.php@ 424

Last change on this file since 424 was 347, checked in by roby, 4 years ago

Aggiornamento per compatibilità con php7.4

File size: 3.0 KB
Line 
1<?php
2/**
3 * Html2Pdf Library
4 *
5 * HTML => PDF converter
6 * distributed under the OSL-3.0 License
7 *
8 * @package Html2pdf
9 * @author Laurent MINGUET <webmaster@html2pdf.fr>
10 * @copyright 2017 Laurent MINGUET
11 */
12
13namespace Spipu\Html2Pdf\Debug;
14
15/**
16 * Class Debug
17 */
18class Debug implements DebugInterface
19{
20 /**
21 * @var float
22 */
23 protected $startTime;
24
25 /**
26 * @var float
27 */
28 protected $lastTime;
29
30 /**
31 * @var int
32 */
33 protected $level = 0;
34
35 /**
36 * @var bool
37 */
38 protected $htmlOutput;
39
40 /**
41 * Debug constructor
42 *
43 * @param bool $htmlOutput
44 */
45 public function __construct($htmlOutput = true)
46 {
47 $this->htmlOutput = $htmlOutput;
48 }
49
50 /**
51 * display a debug line
52 *
53 * @param string $name
54 * @param string $timeTotal
55 * @param string $timeStep
56 * @param string $memoryUsage
57 * @param string $memoryPeak
58 *
59 * @return void
60 */
61 protected function displayLine($name, $timeTotal, $timeStep, $memoryUsage, $memoryPeak)
62 {
63 $output =
64 str_pad($name, 30, ' ', STR_PAD_RIGHT).
65 str_pad($timeTotal, 12, ' ', STR_PAD_LEFT).
66 str_pad($timeStep, 12, ' ', STR_PAD_LEFT).
67 str_pad($memoryUsage, 15, ' ', STR_PAD_LEFT).
68 str_pad($memoryPeak, 15, ' ', STR_PAD_LEFT);
69
70 if ($this->htmlOutput) {
71 $output = '<pre style="padding:0; margin:0">'.$output.'</pre>';
72 }
73
74 echo $output."\n";
75 }
76
77 /**
78 * Start the debugger
79 *
80 * @return Debug
81 */
82 public function start()
83 {
84 $time = microtime(true);
85
86 $this->startTime = $time;
87 $this->lastTime = $time;
88
89 $this->displayLine('step', 'time', 'delta', 'memory', 'peak');
90 $this->addStep('Init debug');
91
92 return $this;
93 }
94
95 /**
96 * stop the debugger
97 *
98 * @return Debug
99 */
100 public function stop()
101 {
102 $this->addStep('Before output');
103 return $this;
104 }
105
106 /**
107 * add a debug step
108 *
109 * @param string $name step name
110 * @param boolean $level (true=up, false=down, null=nothing to do)
111 *
112 * @return Debug
113 */
114 public function addStep($name, $level = null)
115 {
116 // if true : UP
117 if ($level === true) {
118 $this->level++;
119 }
120
121 $time = microtime(true);
122 $usage = memory_get_usage();
123 $peak = memory_get_peak_usage();
124 $type = ($level === true ? ' Begin' : ($level === false ? ' End' : ''));
125
126 $this->displayLine(
127 str_repeat(' ', $this->level) . $name . $type,
128 number_format(($time - $this->startTime)*1000, 1, '.', ' ').' ms',
129 number_format(($time - $this->lastTime)*1000, 1, '.', ' ').' ms',
130 number_format($usage/1024, 1, '.', ' ').' Ko',
131 number_format($peak/1024, 1, '.', ' ').' Ko'
132 );
133
134 $this->lastTime = $time;
135
136 // it false : DOWN
137 if ($level === false) {
138 $this->level--;
139 }
140
141 return $this;
142 }
143}
Note: See TracBrowser for help on using the repository browser.