Passed
Pull Request — master (#275)
by Sergei
02:49
created

InputDataTrait::inputData()   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 1
dl 0
loc 5
ccs 4
cts 4
cp 1
crap 1
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Form\Field\Base\InputData;
6
7
trait InputDataTrait
8
{
9
    private ?InputDataInterface $inputData = null;
10
11 500
    final public function inputData(InputDataInterface $inputData): static
12
    {
13 500
        $new = clone $this;
14 500
        $new->inputData = $inputData;
15 500
        return $new;
16
    }
17
18 598
    final protected function getInputData(): InputDataInterface
19
    {
20 598
        if ($this->inputData === null) {
21 113
            $this->inputData = new PureInputData();
22
        }
23
24 598
        return $this->inputData;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this->inputData could return the type null which is incompatible with the type-hinted return Yiisoft\Form\Field\Base\...Data\InputDataInterface. Consider adding an additional type-check to rule them out.
Loading history...
25
    }
26
}
27