MediaTypeMap::getWantedType()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 9
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 6
c 0
b 0
f 0
nc 2
nop 1
dl 0
loc 9
rs 10
1
<?php
2
3
4
namespace Apie\OpenapiSchema\Map;
5
6
use Apie\CompositeValueObjects\Exceptions\InvalidKeyException;
7
use Apie\CompositeValueObjects\ValueObjectHashmapTrait;
8
use Apie\CompositeValueObjects\ValueObjectListInterface;
9
use Apie\OpenapiSchema\Spec\MediaType;
10
use Apie\TypeJuggling\AnotherValueObject;
11
use Apie\TypeJuggling\Compound;
12
use Apie\TypeJuggling\StringLiteral;
13
use Apie\TypeJuggling\TypeUtilInterface;
14
15
class MediaTypeMap implements ValueObjectListInterface
16
{
17
    use ValueObjectHashmapTrait;
18
19
    protected static function getWantedType(string $fieldName): TypeUtilInterface
20
    {
21
        if (!preg_match('#^([a-z-]+|\*)/([a-z-]+|\*)$#', $fieldName)) {
22
            throw new InvalidKeyException($fieldName);
0 ignored issues
show
Bug introduced by
The call to Apie\CompositeValueObjec...xception::__construct() has too few arguments starting with valueObject. ( Ignorable by Annotation )

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

22
            throw /** @scrutinizer ignore-call */ new InvalidKeyException($fieldName);

This check compares calls to functions or methods with their respective definitions. If the call has less arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress. Please note the @ignore annotation hint above.

Loading history...
23
        }
24
        return new Compound(
25
            $fieldName,
26
            new AnotherValueObject($fieldName, MediaType::class),
27
            new StringLiteral($fieldName)
28
        );
29
    }
30
}
31