/var/www/hkosl.com/nick/codeigniter/application/vendor/phpunit/phpunit/src/Util/ErrorHandler.php


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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<?php
/*
 * This file is part of PHPUnit.
 *
 * (c) Sebastian Bergmann <sebastian@phpunit.de>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

// Workaround for http://bugs.php.net/bug.php?id=47987,
// see https://github.com/sebastianbergmann/phpunit/issues#issue/125 for details
// Use dirname(__DIR__) instead of using /../ because of https://github.com/facebook/hhvm/issues/5215
require_once dirname(__DIR__) . '/Framework/Error.php';
require_once 
dirname(__DIR__) . '/Framework/Error/Notice.php';
require_once 
dirname(__DIR__) . '/Framework/Error/Warning.php';
require_once 
dirname(__DIR__) . '/Framework/Error/Deprecated.php';

/**
 * Error handler that converts PHP errors and warnings to exceptions.
 */
class PHPUnit_Util_ErrorHandler
{
    protected static 
$errorStack = [];

    
/**
     * Returns the error stack.
     *
     * @return array
     */
    
public static function getErrorStack()
    {
        return 
self::$errorStack;
    }

    
/**
     * @param int    $errno
     * @param string $errstr
     * @param string $errfile
     * @param int    $errline
     *
     * @throws PHPUnit_Framework_Error
     */
    
public static function handleError($errno$errstr$errfile$errline)
    {
        if (!(
$errno error_reporting())) {
            return 
false;
        }

        
self::$errorStack[] = [$errno$errstr$errfile$errline];

        
$trace debug_backtrace(false);
        
array_shift($trace);

        foreach (
$trace as $frame) {
            if (
$frame['function'] == '__toString') {
                return 
false;
            }
        }

        if (
$errno == E_NOTICE || $errno == E_USER_NOTICE || $errno == E_STRICT) {
            if (
PHPUnit_Framework_Error_Notice::$enabled !== true) {
                return 
false;
            }

            
$exception 'PHPUnit_Framework_Error_Notice';
        } elseif (
$errno == E_WARNING || $errno == E_USER_WARNING) {
            if (
PHPUnit_Framework_Error_Warning::$enabled !== true) {
                return 
false;
            }

            
$exception 'PHPUnit_Framework_Error_Warning';
        } elseif (
$errno == E_DEPRECATED || $errno == E_USER_DEPRECATED) {
            if (
PHPUnit_Framework_Error_Deprecated::$enabled !== true) {
                return 
false;
            }

            
$exception 'PHPUnit_Framework_Error_Deprecated';
        } else {
            
$exception 'PHPUnit_Framework_Error';
        }

        throw new 
$exception($errstr$errno$errfile$errline);
    }

    
/**
     * Registers an error handler and returns a function that will restore
     * the previous handler when invoked
     *
     * @param int $severity PHP predefined error constant
     *
     * @throws Exception if event of specified severity is emitted
     */
    
public static function handleErrorOnce($severity E_WARNING)
    {
        
$terminator = function () {
            static 
$expired false;
            if (!
$expired) {
                
$expired true;
                
// cleans temporary error handler
                
return restore_error_handler();
            }
        };

        
set_error_handler(function ($errno$errstr) use ($severity) {
            if (
$errno === $severity) {
                return;
            }

            return 
false;
        });

        return 
$terminator;
    }
}