Test Failed
Push — master ( 3e22f3...90cc1b )
by Kirill
03:50
created

ArgumentDefinitionNode::getTypeHint()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
cc 1
nc 1
nop 0
dl 0
loc 4
ccs 0
cts 4
cp 0
crap 2
rs 10
c 0
b 0
f 0
1
<?php
2
/**
3
 * This file is part of Railt package.
4
 *
5
 * For the full copyright and license information, please view the LICENSE
6
 * file that was distributed with this source code.
7
 */
8
declare(strict_types=1);
9
10
namespace Railt\SDL\Compiler\Ast\Dependent;
11
12
use Railt\Parser\Ast\NodeInterface;
13
use Railt\Parser\Ast\Rule;
14
use Railt\SDL\Compiler\Ast\Common\DescriptionProvider;
15
use Railt\SDL\Compiler\Ast\TypeHintNode;
16
use Railt\SDL\Compiler\Ast\Value\ValueInterface;
17
use Railt\SDL\Compiler\Ast\Value\ValueNode;
18
19
/**
20
 * Class ArgumentDefinitionNode
21
 */
22
class ArgumentDefinitionNode extends Rule
23
{
24
    use DescriptionProvider;
25
26
    /**
27
     * @return TypeHintNode|NodeInterface
28
     */
29
    public function getTypeHint(): TypeHintNode
30
    {
31
        return $this->first('TypeHint', 1);
32
    }
33
34
    /**
35
     * @return string
36
     */
37
    public function getArgumentName(): string
38
    {
39
        return $this->first('T_NAME', 1)->getValue();
0 ignored issues
show
Bug introduced by
The method getValue() does not exist on Railt\Parser\Ast\NodeInterface. Did you maybe mean getValues()?

This check marks calls to methods that do not seem to exist on an object.

This is most likely the result of a method being renamed without all references to it being renamed likewise.

Loading history...
40
    }
41
42
    /**
43
     * @return null|ValueInterface|NodeInterface
44
     */
45
    public function getDefaultValue(): ?ValueInterface
46
    {
47
        /** @var ValueNode $value */
48
        $value = $this->first('Value', 1);
49
50
        return $value ? $value->getInnerValue() : null;
51
    }
52
}
53