/adei/trunk

To get this branch, use:
bzr branch http://darksoft.org/webbzr/adei/trunk
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<?php

/*
require_once("Benchmark/Profiler.php");


function __profile__($cmd) {
        static $log, $last_time, $total;
	
        list($usec, $sec) = explode(" ", microtime());
        $now = (float) $usec + (float) $sec;
	
        if($cmd) {
                if($cmd == 'get') {
                        unregister_tick_function('__profile__');
                        foreach($log as $function => $time) {
                                if($function != '__profile__') {
                                        $by_function[$function] = round($time / $total * 100, 2);
                                }
                        }
                        arsort($by_function);
                        return $by_function;
                }
                else if($cmd == 'init') {
                        $last_time = $now;
                        return;
                }
		else if($cmd == 'restart') {
			register_tick_function('__profile__', $this);
			return;
		}
        }
        $delta = $now - $last_time;
        $last_time = $now;
        $trace = debug_backtrace();
        $caller = $trace[1]['function'];
        @$log[$caller] += $delta;
        $total += $delta;
}

class PROFILER {
 var $profiler;
 
 function __construct() {
    $this->Start();
 }
 
 function __destruct() {
    $this->Display(false);
 }
 
 function Start() {
    global $profiler;
    
    __profile__('init');
    register_tick_function('__profile__', $this);
    declare(ticks=1); 


    $this->profiler = new Benchmark_Profiler(true);
    $this->profiler->start();
 }


 function Display($prof = true) {
    if ($prof) {
	$this->profiler->stop();
	$this->profiler->display();
    }

    print_r(__profile__('get'));
    echo("\n");
 }

 function Restart() {
    $this->profiler->start();
    __profile__('restart');
 }


 function EnterSection($name) {
    $this->profiler->enterSection($name);
 }

 function LeaveSection($name) {
    $this->profiler->leaveSection($name);
 }
}

//$adei_profiler = new PROFILER();
*/

?>