Passed
Pull Request — master (#90)
by Aleksei
07:03
created

CachedCount::cacheCount()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 0
dl 0
loc 6
ccs 0
cts 4
cp 0
crap 2
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Yii\Cycle\Data\Reader\Cache;
6
7
use Countable;
8
9
final class CachedCount
10
{
11
    private ?int $count = null;
12
    private ?Countable $collection;
13
14
    public function __construct(Countable $collection)
15
    {
16
        $this->collection = $collection;
17
    }
18
19
    /**
20
     * @psalm-internal Yiisoft\Yii\Cycle\Data\Reader
21
     */
22
    public function getCount(): int
23
    {
24
        return $this->count ?? $this->cacheCount();
25
    }
26
27
    private function cacheCount(): int
28
    {
29
        /** @psalm-suppress PossiblyNullReference */
30
        $this->count = $this->collection->count();
0 ignored issues
show
Bug introduced by
The method count() does not exist on null. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

30
        /** @scrutinizer ignore-call */ 
31
        $this->count = $this->collection->count();

This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.

This is most likely a typographical error or the method has been renamed.

Loading history...
31
        $this->collection = null;
32
        return $this->count;
33
    }
34
}
35