Welcome to mirror list, hosted at ThFree Co, Russian Federation.

ErrorHandler.php « core - github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: f2bcde168c99e03c7b5e03b2c159ded4aa8b51e4 (plain)
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
<?php
/**
 * Piwik - Open source web analytics
 *
 * @link http://piwik.org
 * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
 *
 * @category Piwik
 * @package Piwik
 */

/**
 * Error handler used to display nicely errors in Piwik
 *
 * @param int $errno    Error number
 * @param string $errstr   Error message
 * @param string $errfile  File name
 * @param int $errline  Line number
 * @return void
 */
function Piwik_ErrorHandler($errno, $errstr, $errfile, $errline)
{
    // if the error has been suppressed by the @ we don't handle the error
    if (error_reporting() == 0) {
        return;
    }

    if (function_exists('debug_backtrace')) {
        $backtrace = '';
        $bt = @debug_backtrace();
        if ($bt !== null && isset($bt[0])) {
            foreach ($bt as $i => $debug) {
                $backtrace .= "#$i  "
                    . (isset($debug['class']) ? $debug['class'] : '')
                    . (isset($debug['type']) ? $debug['type'] : '')
                    . (isset($debug['function']) ? $debug['function'] : '')
                    . '(...) called at ['
                    . (isset($debug['file']) ? $debug['file'] : '') . ':'
                    . (isset($debug['line']) ? $debug['line'] : '') . ']' . "\n";
            }
        }
    } else {
        ob_start();
        @debug_print_backtrace();
        $backtrace = ob_get_contents();
        ob_end_clean();
    }

    try {
        Zend_Registry::get('logger_error')->logEvent($errno, $errstr, $errfile, $errline, $backtrace);
    } catch (Exception $e) {
        // in case the error occurs before the logger creation, we simply display it
        print("<pre>$errstr \nin '$errfile' at the line $errline\n\n$backtrace\n</pre>");
        exit;
    }
    switch ($errno) {
        case E_ERROR:
        case E_PARSE:
        case E_CORE_ERROR:
        case E_CORE_WARNING:
        case E_COMPILE_ERROR:
        case E_COMPILE_WARNING:
        case E_USER_ERROR:
            exit;
            break;

        case E_WARNING:
        case E_NOTICE:
        case E_USER_WARNING:
        case E_USER_NOTICE:
        case E_STRICT:
        case E_RECOVERABLE_ERROR:
        case E_DEPRECATED:
        case E_USER_DEPRECATED:
        default:
            // do not exit
            break;
    }
}