Completed
Push — develop ( 798002...f6aa38 )
by Neomerx
03:40
created

ErrorAggregator   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 51
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 0

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
wmc 5
lcom 1
cbo 0
dl 0
loc 51
ccs 12
cts 12
cp 1
rs 10
c 0
b 0
f 0

5 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A add() 0 6 1
A get() 0 4 1
A count() 0 4 1
A clear() 0 6 1
1
<?php namespace Limoncello\Validation\Errors;
2
3
/**
4
 * Copyright 2015-2017 [email protected]
5
 *
6
 * Licensed under the Apache License, Version 2.0 (the "License");
7
 * you may not use this file except in compliance with the License.
8
 * You may obtain a copy of the License at
9
 *
10
 * http://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing, software
13
 * distributed under the License is distributed on an "AS IS" BASIS,
14
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
 * See the License for the specific language governing permissions and
16
 * limitations under the License.
17
 */
18
19
use Limoncello\Validation\Contracts\Errors\ErrorAggregatorInterface;
20
use Limoncello\Validation\Contracts\Errors\ErrorInterface;
21
22
/**
23
 * @package Limoncello\Validation
24
 */
25
class ErrorAggregator implements ErrorAggregatorInterface
26
{
27
    /**
28
     * @var ErrorInterface[]
29
     */
30
    private $errors;
31
32
    /**
33
     * Constructor.
34
     */
35 15
    public function __construct()
36
    {
37 15
        $this->clear();
38
    }
39
40
    /**
41
     * @inheritdoc
42
     */
43 13
    public function add(ErrorInterface $error): ErrorAggregatorInterface
44
    {
45 13
        $this->errors[] = $error;
46
47 13
        return $this;
48
    }
49
50
    /**
51
     * @inheritdoc
52
     */
53 15
    public function get(): array
54
    {
55 15
        return $this->errors;
56
    }
57
58
    /**
59
     * @inheritdoc
60
     */
61 10
    public function count()
62
    {
63 10
        return count($this->get());
64
    }
65
66
    /**
67
     * @inheritdoc
68
     */
69 15
    public function clear(): ErrorAggregatorInterface
70
    {
71 15
        $this->errors = [];
72
73 15
        return $this;
74
    }
75
}
76