Completed
Push — master ( 7510c8...82c7bd )
by Kirill
08:19
created

InputFieldDefinitionNode::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\Common\DirectivesProvider;
16
use Railt\SDL\Compiler\Ast\TypeHintNode;
17
use Railt\SDL\Compiler\Ast\Value\BaseValueNode;
18
19
/**
20
 * Class InputFieldDefinitionNode
21
 */
22
class InputFieldDefinitionNode extends Rule
23
{
24
    use DirectivesProvider;
25
    use DescriptionProvider;
26
27
    /**
28
     * @return string
29
     */
30
    public function getFieldName(): string
31
    {
32
        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...
33
    }
34
35
    /**
36
     * @return null|TypeHintNode|NodeInterface
37
     */
38
    public function getTypeHint(): TypeHintNode
39
    {
40
        return $this->first('TypeHint', 1);
41
    }
42
43
    /**
44
     * @return null|BaseValueNode|NodeInterface
45
     */
46
    public function getDefaultValue(): ?BaseValueNode
47
    {
48
        return $this->first('Value', 1);
49
    }
50
}
51