Journal::add()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 5
ccs 3
cts 3
cp 1
crap 1
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * Derafu: Biblioteca PHP (Núcleo).
7
 * Copyright (C) Derafu <https://www.derafu.org>
8
 *
9
 * Este programa es software libre: usted puede redistribuirlo y/o modificarlo
10
 * bajo los términos de la Licencia Pública General Affero de GNU publicada por
11
 * la Fundación para el Software Libre, ya sea la versión 3 de la Licencia, o
12
 * (a su elección) cualquier versión posterior de la misma.
13
 *
14
 * Este programa se distribuye con la esperanza de que sea útil, pero SIN
15
 * GARANTÍA ALGUNA; ni siquiera la garantía implícita MERCANTIL o de APTITUD
16
 * PARA UN PROPÓSITO DETERMINADO. Consulte los detalles de la Licencia Pública
17
 * General Affero de GNU para obtener una información más detallada.
18
 *
19
 * Debería haber recibido una copia de la Licencia Pública General Affero de GNU
20
 * junto a este programa.
21
 *
22
 * En caso contrario, consulte <http://www.gnu.org/licenses/agpl.html>.
23
 */
24
25
namespace Derafu\Lib\Core\Support\Store;
26
27
use ArrayAccess;
28
use ArrayObject;
29
use Derafu\Lib\Core\Support\Store\Abstract\AbstractStore;
30
use Derafu\Lib\Core\Support\Store\Contract\JournalInterface;
31
32
/**
33
 * Clase para almacenamiento secuencial de elementos.
34
 */
35
class Journal extends AbstractStore implements JournalInterface
36
{
37
    /**
38
     * Constructor del Journal.
39
     *
40
     * @param array|ArrayAccess|ArrayObject $data Datos iniciales del journal.
41
     */
42 41
    public function __construct(array|ArrayAccess|ArrayObject $data = [])
43
    {
44 41
        $this->data = $this->createFrom($data);
45
    }
46
47
    /**
48
     * {@inheritDoc}
49
     */
50 41
    public function add(mixed $item): static
51
    {
52 41
        $this->data[] = $item;
53
54 41
        return $this;
55
    }
56
57
    /**
58
     * {@inheritDoc}
59
     */
60 1
    public function reverse(): array
61
    {
62 1
        return array_reverse($this->toArray());
63
    }
64
}
65