Passed
Pull Request — master (#15)
by Sebastian
04:12
created

hasSpacing()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 3
rs 10
1
<?php
2
/**
3
 * File containing the {@see Mailcode_Parser_Statement_Tokenizer_Token_Variable} class.
4
 *
5
 * @package Mailcode
6
 * @subpackage Parser
7
 * @see Mailcode_Parser_Statement_Tokenizer_Token_Variable
8
 */
9
10
declare(strict_types=1);
11
12
namespace Mailcode;
13
14
/**
15
 * Token representing a variable name.
16
 *
17
 * @package Mailcode
18
 * @subpackage Parser
19
 * @author Sebastian Mordziol <[email protected]>
20
 */
21
class Mailcode_Parser_Statement_Tokenizer_Token_Variable extends Mailcode_Parser_Statement_Tokenizer_Token
22
{
23
    public const ERROR_NOT_A_VARIABLE_INSTANCE = 49501;
24
25
    /**
26
     * @return Mailcode_Variables_Variable
27
     * @throws Mailcode_Parser_Exception
28
     */
29
    public function getVariable() : Mailcode_Variables_Variable
30
    {
31
        if($this->subject instanceof Mailcode_Variables_Variable)
32
        {
33
            return $this->subject;
34
        }
35
        
36
        throw new Mailcode_Parser_Exception(
37
            'Subject is not a variable instance.',
38
            null,
39
            self::ERROR_NOT_A_VARIABLE_INSTANCE
40
        );
41
    }
42
    
43
    public function getNormalized() : string
44
    {
45
        return $this->getVariable()->getFullName();
46
    }
47
48
    public function hasSpacing(): bool
49
    {
50
        return true;
51
    }
52
}
53