/var/www/hkosl.com/imusiccircle/webadmin/libraies/filp/whoops/src/Whoops/Exception/FrameCollection.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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
<?php
/**
 * Whoops - php errors for cool kids
 * @author Filipe Dobreira <http://github.com/filp>
 */

namespace Whoops\Exception;

use 
ArrayAccess;
use 
ArrayIterator;
use 
Countable;
use 
IteratorAggregate;
use 
Serializable;
use 
UnexpectedValueException;

/**
 * Exposes a fluent interface for dealing with an ordered list
 * of stack-trace frames.
 */
class FrameCollection implements ArrayAccessIteratorAggregateSerializableCountable
{
    
/**
     * @var array[]
     */
    
private $frames;

    
/**
     * @param array $frames
     */
    
public function __construct(array $frames)
    {
        
$this->frames array_map(function ($frame) {
            return new 
Frame($frame);
        }, 
$frames);
    }

    
/**
     * Filters frames using a callable, returns the same FrameCollection
     *
     * @param  callable        $callable
     * @return FrameCollection
     */
    
public function filter($callable)
    {
        
$this->frames array_filter($this->frames$callable);
        return 
$this;
    }

    
/**
     * Map the collection of frames
     *
     * @param  callable        $callable
     * @return FrameCollection
     */
    
public function map($callable)
    {
        
// Contain the map within a higher-order callable
        // that enforces type-correctness for the $callable
        
$this->frames array_map(function ($frame) use ($callable) {
            
$frame call_user_func($callable$frame);

            if (!
$frame instanceof Frame) {
                throw new 
UnexpectedValueException(
                    
"Callable to " __METHOD__ " must return a Frame object"
                
);
            }

            return 
$frame;
        }, 
$this->frames);

        return 
$this;
    }

    
/**
     * Returns an array with all frames, does not affect
     * the internal array.
     *
     * @todo   If this gets any more complex than this,
     *         have getIterator use this method.
     * @see    FrameCollection::getIterator
     * @return array
     */
    
public function getArray()
    {
        return 
$this->frames;
    }

    
/**
     * @see IteratorAggregate::getIterator
     * @return ArrayIterator
     */
    
public function getIterator()
    {
        return new 
ArrayIterator($this->frames);
    }

    
/**
     * @see ArrayAccess::offsetExists
     * @param int $offset
     */
    
public function offsetExists($offset)
    {
        return isset(
$this->frames[$offset]);
    }

    
/**
     * @see ArrayAccess::offsetGet
     * @param int $offset
     */
    
public function offsetGet($offset)
    {
        return 
$this->frames[$offset];
    }

    
/**
     * @see ArrayAccess::offsetSet
     * @param int $offset
     */
    
public function offsetSet($offset$value)
    {
        throw new \
Exception(__CLASS__ ' is read only');
    }

    
/**
     * @see ArrayAccess::offsetUnset
     * @param int $offset
     */
    
public function offsetUnset($offset)
    {
        throw new \
Exception(__CLASS__ ' is read only');
    }

    
/**
     * @see Countable::count
     * @return int
     */
    
public function count()
    {
        return 
count($this->frames);
    }

    
/**
     * @see Serializable::serialize
     * @return string
     */
    
public function serialize()
    {
        return 
serialize($this->frames);
    }

    
/**
     * @see Serializable::unserialize
     * @param string $serializedFrames
     */
    
public function unserialize($serializedFrames)
    {
        
$this->frames unserialize($serializedFrames);
    }

    
/**
     * @param Frame[] $frames Array of Frame instances, usually from $e->getPrevious()
     */
    
public function prependFrames(array $frames)
    {
        
$this->frames array_merge($frames$this->frames);
    }

    
/**
     * Gets the innermost part of stack trace that is not the same as that of outer exception
     *
     * @param  FrameCollection $parentFrames Outer exception frames to compare tail against
     * @return Frame[]
     */
    
public function topDiff(FrameCollection $parentFrames)
    {
        
$diff $this->frames;

        
$parentFrames $parentFrames->getArray();
        
$p count($parentFrames)-1;

        for (
$i count($diff)-1$i >= && $p >= 0$i--) {
            
/** @var Frame $tailFrame */
            
$tailFrame $diff[$i];
            if (
$tailFrame->equals($parentFrames[$p])) {
                unset(
$diff[$i]);
            }
            
$p--;
        }
        return 
$diff;
    }
}