Passed
Pull Request — master (#275)
by Sergei
03:07
created

InputDataTrait   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 18
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 8
c 1
b 0
f 0
dl 0
loc 18
ccs 8
cts 8
cp 1
rs 10
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A getInputData() 0 7 2
A inputData() 0 5 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Form\Field\Base;
6
7
use Yiisoft\Form\InputData\Pure\PureInputData;
8
9
trait InputDataTrait
10
{
11
    private ?InputDataInterface $inputData = null;
12
13 499
    final public function inputData(InputDataInterface $inputData): static
14
    {
15 499
        $new = clone $this;
16 499
        $new->inputData = $inputData;
17 499
        return $new;
18
    }
19
20 597
    final protected function getInputData(): InputDataInterface
21
    {
22 597
        if ($this->inputData === null) {
23 113
            $this->inputData = new PureInputData();
24
        }
25
26 597
        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\InputDataInterface. Consider adding an additional type-check to rule them out.
Loading history...
27
    }
28
}
29