GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Passed
Pull Request — master (#40)
by Issei
11:11
created

Collection::getIterator()   A

Complexity

Conditions 4
Paths 5

Size

Total Lines 18
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 10
CRAP Score 4.0119

Importance

Changes 0
Metric Value
cc 4
eloc 9
nc 5
nop 0
dl 0
loc 18
ccs 10
cts 11
cp 0.9091
crap 4.0119
rs 9.2
c 0
b 0
f 0
1
<?php
2
3
namespace DusanKasan\Knapsack;
4
5
use ArrayIterator;
6
use DusanKasan\Knapsack\Exceptions\InvalidArgument;
7
use DusanKasan\Knapsack\Exceptions\InvalidReturnValue;
8
use IteratorAggregate;
9
use Traversable;
10
11
class Collection implements IteratorAggregate, \Countable, \Serializable
12
{
13
    use CollectionTrait;
14
15
    /**
16
     * @var Traversable
17
     */
18
    protected $input;
19
20
    /**
21
     * @var callable
22
     */
23
    private $inputFactory;
24
25
    /**
26
     * @param callable|array|Traversable $input If callable is passed, it must return an array|Traversable.
27
     */
28 107
    public function __construct($input)
29
    {
30 107
        if (is_callable($input)) {
31 81
            $this->inputFactory = $input;
32 81
            $input = $input();
33 81
        }
34
35 107
        if (is_array($input)) {
36 92
            $this->input = new ArrayIterator($input);
37 107
        } elseif ($input instanceof Traversable) {
38 81
            $this->input = $input;
39 81
        } else {
40 2
            throw $this->inputFactory ? new InvalidReturnValue : new InvalidArgument;
41
        }
42 105
    }
43
44
    /**
45
     * Static alias of normal constructor.
46
     *
47
     * @param callable|array|Traversable $input
48
     * @return Collection
49
     */
50 8
    public static function from($input)
51
    {
52 8
        return new self($input);
53
    }
54
55
    /**
56
     * Returns lazy collection of values, where first value is $input and all subsequent values are computed by applying
57
     * $function to the last value in the collection. By default this produces an infinite collection. However you can
58
     * end the collection by throwing a NoMoreItems exception.
59
     *
60
     * @param mixed $input
61
     * @param callable $function
62
     * @return Collection
63
     */
64 2
    public static function iterate($input, callable $function)
65
    {
66 2
        return iterate($input, $function);
67
    }
68
69
    /**
70
     * Returns a lazy collection of $value repeated $times times. If $times is not provided the collection is infinite.
71
     *
72
     * @param mixed $value
73
     * @param int $times
74
     * @return Collection
75
     */
76 3
    public static function repeat($value, $times = -1)
77
    {
78 3
        return repeat($value, $times);
79
    }
80
81
    /**
82
     * Returns a lazy collection of numbers starting at $start, incremented by $step until $end is reached.
83
     *
84
     * @param int $start
85
     * @param int|null $end
86
     * @param int $step
87
     * @return Collection
88
     */
89 2
    public static function range($start = 0, $end = null, $step = 1)
90
    {
91 2
        return \DusanKasan\Knapsack\range($start, $end, $step);
92
    }
93
94
    /**
95
     * {@inheritdoc}
96
     * @throws InvalidReturnValue
97
     */
98 104
    public function getIterator()
99
    {
100 104
        if ($this->inputFactory) {
101 80
            $input = call_user_func($this->inputFactory);
102
103 80
            if (is_array($input)) {
104 1
                $input = new ArrayIterator($input);
105 1
            }
106
107 80
            if (!($input instanceof Traversable)) {
108
                throw new InvalidReturnValue;
109
            }
110
111 80
            $this->input = $input;
112 80
        }
113
114 104
        return $this->input;
115
    }
116
117
    /**
118
     * {@inheritdoc}
119
     */
120 1
    public function count()
121
    {
122 1
        return $this->size();
123
    }
124
125
    /**
126
     * {@inheritdoc}
127
     */
128 1
    public function serialize()
129
    {
130 1
        return serialize(
131 1
            toArray(
132 1
                map(
133 1
                    $this->input,
134 1
                    function ($value, $key) {
135 1
                        return [$key, $value];
136
                    }
137 1
                )
138 1
            )
139 1
        );
140
    }
141
142
    /**
143
     * {@inheritdoc}
144
     */
145 1
    public function unserialize($serialized)
146
    {
147 1
        $this->input = dereferenceKeyValue(unserialize($serialized));
148 1
    }
149
}
150