Completed
Push — master ( 0ce86f...2fe179 )
by
unknown
30s
created

Collection   A

Complexity

Total Complexity 27

Size/Duplication

Total Lines 145
Duplicated Lines 25.52 %

Coupling/Cohesion

Components 1
Dependencies 0

Test Coverage

Coverage 82.61%

Importance

Changes 0
Metric Value
wmc 27
lcom 1
cbo 0
dl 37
loc 145
ccs 57
cts 69
cp 0.8261
rs 10
c 0
b 0
f 0

17 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A count() 0 4 1
A isEmpty() 0 8 2
A getArray() 0 4 1
A jsonSerialize() 0 4 1
A getIterator() 0 4 1
A offsetExists() 0 4 1
A offsetGet() 0 4 1
A offsetSet() 0 4 1
A offsetUnset() 0 6 2
A clear() 0 4 1
A mutate() 0 9 2
A map() 11 11 2
A filter() 13 13 3
A each() 0 8 2
A not() 13 13 3
A reduce() 0 10 2

How to fix   Duplicated Code   

Duplicated Code

Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.

Common duplication problems, and corresponding solutions are:

1
<?php
2
declare(strict_types = 1);
3
4
namespace Zewa;
5
6
use Zewa\Interfaces\CollectionInterface;
7
8
/**
9
 * Class Collection
10
 * @package App\Models
11
 */
12
class Collection implements CollectionInterface
13
{
14
    /**
15
     * @var array
16
     */
17
    public $collection = [];
18
19
    /**
20
     * If $data is passed, populate collection
21
     *
22
     * @param $data array
23
     *
24
     * @access public
25
     */
26 14
    public function __construct(array $data = [])
27
    {
28 14
        $this->collection = $data;
29 14
    }
30
31 1
    public function count() : int
32
    {
33 1
        return count($this->collection);
34
    }
35
36 3
    public function isEmpty() : bool
37
    {
38 3
        if (! empty($this->collection)) {
39 1
            return false;
40
        }
41
42 2
        return true;
43
    }
44
45 4
    public function getArray() : array
46
    {
47 4
        return $this->collection;
48
    }
49
50 1
    public function jsonSerialize() : array //@TODO: this should return text i think (wrong)
51
    {
52 1
        return $this->collection;
53
    }
54
55 1
    public function getIterator() : \ArrayIterator
56
    {
57 1
        return new \ArrayIterator($this->collection);
58
    }
59
60 3
    public function offsetExists($offset)
61
    {
62 3
        return array_key_exists($offset, $this->collection);
63
    }
64
65 1
    public function offsetGet($offset)
66
    {
67 1
        return $this->collection[$offset] ?? null;
68
    }
69
70 1
    public function offsetSet($offset, $value)
71
    {
72 1
        $this->collection[$offset] = $value;
73 1
    }
74
75 1
    public function offsetUnset($offset)
76
    {
77 1
        if ($this->offsetExists($offset)) {
78 1
            unset($this->collection[$offset]);
79
        }
80 1
    }
81
82 4
    public function clear()
83
    {
84 4
        $this->collection = [];
85 4
    }
86
87
    public function mutate($mutation)
88
    {
89
        $result = [];
90
        foreach ($this->collection as $item) {
91
            $result[] = new $mutation($item);
92
        }
93
        $this->clear();
94
        $this->collection = $result;
95
    }
96
97 1 View Code Duplication
    public function map(callable $func)
0 ignored issues
show
Duplication introduced by
This method seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
98
    {
99 1
        $result = [];
100
101 1
        foreach ($this->collection as $key => $item) {
102 1
            $result[$key] = $func($item);
103
        }
104
105 1
        $this->clear();
106 1
        $this->collection = $result;
107 1
    }
108
109 1 View Code Duplication
    public function filter(callable $func)
0 ignored issues
show
Duplication introduced by
This method seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
110
    {
111 1
        $result = [];
112
113 1
        foreach ($this->collection as $key => $item) {
114 1
            if ($func($key, $item)) {
115 1
                $result[$key] = $item;
116
            }
117
        }
118
119 1
        $this->clear();
120 1
        $this->collection = $result;
121 1
    }
122
123 1
    public function each(callable $func)
124
    {
125 1
        $result = [];
126
127 1
        foreach ($this->collection as $key => $item) {
128 1
            $result[$key] = $func($key, $item);
129
        }
130 1
    }
131
132 1 View Code Duplication
    public function not(callable $func)
0 ignored issues
show
Duplication introduced by
This method seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
133
    {
134 1
        $result = [];
135
136 1
        foreach ($this->collection as $key => $item) {
137 1
            if (! $func($key, $item)) {
138 1
                $result[$key] = $item;
139
            }
140
        }
141
142 1
        $this->clear();
143 1
        $this->collection = $result;
144 1
    }
145
146
    public function reduce($initial, callable $func)
147
    {
148
        $accumulator = $initial;
149
150
        foreach ($this->collection as $item) {
151
            $accumulator = $func($accumulator, $item);
152
        }
153
154
        return $accumulator;
155
    }
156
}
157