Dictionary::offsetSet()   A
last analyzed

Complexity

Conditions 3
Paths 2

Size

Total Lines 8
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 3

Importance

Changes 0
Metric Value
dl 0
loc 8
ccs 5
cts 5
cp 1
rs 9.4285
c 0
b 0
f 0
cc 3
eloc 4
nc 2
nop 2
crap 3
1
<?php
2
3
namespace Minerva\Collections;
4
5
use Minerva\Collections\Basis\Abstractions\AbstractStorage;
6
use Minerva\Collections\Basis\Exceptions\InvalidOffsetTypeException;
7
use Minerva\Collections\Basis\Exceptions\MaxCapacityReachedException;
8
use Minerva\Collections\Basis\Exceptions\OverrideOperationException;
9
use Minerva\Collections\Basis\Exceptions\ReadOnlyStorageException;
10
use Minerva\Collections\Basis\Interfaces\DictionaryInterface;
11
12
/**
13
 * Dicionário de dados
14
 *
15
 * @author  Lucas A. de Araújo <[email protected]>
16
 * @package Minerva\Collections
17
 */
18
class Dictionary extends AbstractStorage implements DictionaryInterface
19
{
20
    /**
21
     * Define se o override de dados é permitido
22
     *
23
     * @var bool
24
     */
25
    protected $overrideAllowed = true;
26
27
    /**
28
     * Retorna se a classe permite override
29
     *
30
     * @return boolean
31
     */
32 1
    public function isOverrideAllowed()
33
    {
34 1
        return $this->overrideAllowed;
35
    }
36
37
    /**
38
     * Define o comportamento do objeto acerca do override
39
     *
40
     * @param boolean $overrideAllowed
41
     */
42 1
    public function setOverrideAllowed($overrideAllowed)
43
    {
44 1
        $this->overrideAllowed = $overrideAllowed;
45 1
    }
46
47
    /**
48
     * Define um valor para uma chave
49
     *
50
     * Esse método tem por finalidade apenas adicionar uma especialização
51
     * para os contextos de utilização de um dicionário de dados.
52
     *
53
     * @param mixed $offset
54
     * @param mixed $value
55
     * @throws MaxCapacityReachedException
56
     * @throws ReadOnlyStorageException
57
     * @throws OverrideOperationException
58
     */
59 2
    public function offsetSet($offset, $value)
60
    {
61 2
        if($this->offsetExists($offset) && !$this->isOverrideAllowed())
62 2
            throw new OverrideOperationException();
63
        
64
        
65 2
        parent::offsetSet($offset, $value);
66 2
    }
67
68
    /**
69
     * Retorna a chave do elemento atual no dicionário
70
     *
71
     * @return int|float|bool|string
72
     */
73 2
    public function key()
74
    {
75 2
        $keys = [];
76
        
77 2
        foreach ($this->storage as $key => $item){
78 2
            $keys[] = $key;
79 2
        }
80
        
81 2
        if(isset($keys[$this->current]))
82 2
            return $keys[$this->current];
83 2
    }
84
85
    /**
86
     * Retorna o elemento atual
87
     *
88
     * @return mixed
89
     */
90 1
    public function current()
91
    {
92 1
        return $this->storage[$this->key()];
93
    }
94
95
    /**
96
     * Verifica se a posição atual é válida
97
     *
98
     * @return bool
99
     */
100 2
    public function valid()
101
    {
102 2
        return isset($this->storage[$this->key()]);
103
    }
104
}