GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Passed
Push — master ( 778995...e0837d )
by Baptiste
03:36
created

UnsignedLongInteger::definitionSet()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 4
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 0
dl 0
loc 5
ccs 4
cts 4
cp 1
crap 1
rs 10
c 0
b 0
f 0
1
<?php
2
declare(strict_types = 1);
3
4
namespace Innmind\AMQP\Transport\Frame\Value;
5
6
use Innmind\AMQP\{
7
    Transport\Frame\Value,
8
    Exception\OutOfRangeValue,
9
};
10
use Innmind\Math\{
11
    Algebra\Integer,
12
    DefinitionSet\Set,
13
    DefinitionSet\Range,
14
};
15
use Innmind\Stream\Readable;
16
17
final class UnsignedLongInteger implements Value
18
{
19
    private static $definitionSet;
20
21
    private $value;
22
    private $original;
23
24 260
    public function __construct(Integer $value)
25
    {
26 260
        $this->original = $value;
27 260
    }
28
29 134
    public static function of(Integer $value): self
30
    {
31 134
        if (!self::definitionSet()->contains($value)) {
32 4
            throw new OutOfRangeValue($value, self::definitionSet());
33
        }
34
35 130
        return new self($value);
36
    }
37
38 152
    public static function fromStream(Readable $stream): Value
39
    {
40 152
        [, $value] = \unpack('N', (string) $stream->read(4));
41
42 152
        return new self(new Integer($value));
43
    }
44
45 136
    public function original(): Integer
46
    {
47 136
        return $this->original;
48
    }
49
50 258
    public function __toString(): string
51
    {
52 258
        return $this->value ?? $this->value = \pack('N', $this->original->value());
53
    }
54
55 134
    public static function definitionSet(): Set
56
    {
57 134
        return self::$definitionSet ?? self::$definitionSet = Range::inclusive(
58 2
            new Integer(0),
59 134
            new Integer(4294967295)
60
        );
61
    }
62
}
63