C:\xampp\phpMyAdmin\vendor\twig\twig\lib\Twig\Token.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
<?php

/*
 * This file is part of Twig.
 *
 * (c) Fabien Potencier
 * (c) Armin Ronacher
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

/**
 * Represents a Token.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 *
 * @final
 */
class Twig_Token
{
    protected 
$value;
    protected 
$type;
    protected 
$lineno;

    const 
EOF_TYPE = -1;
    const 
TEXT_TYPE 0;
    const 
BLOCK_START_TYPE 1;
    const 
VAR_START_TYPE 2;
    const 
BLOCK_END_TYPE 3;
    const 
VAR_END_TYPE 4;
    const 
NAME_TYPE 5;
    const 
NUMBER_TYPE 6;
    const 
STRING_TYPE 7;
    const 
OPERATOR_TYPE 8;
    const 
PUNCTUATION_TYPE 9;
    const 
INTERPOLATION_START_TYPE 10;
    const 
INTERPOLATION_END_TYPE 11;

    
/**
     * @param int    $type   The type of the token
     * @param string $value  The token value
     * @param int    $lineno The line position in the source
     */
    
public function __construct($type$value$lineno)
    {
        
$this->type $type;
        
$this->value $value;
        
$this->lineno $lineno;
    }

    public function 
__toString()
    {
        return 
sprintf('%s(%s)'self::typeToString($this->typetrue), $this->value);
    }

    
/**
     * Tests the current token for a type and/or a value.
     *
     * Parameters may be:
     *  * just type
     *  * type and value (or array of possible values)
     *  * just value (or array of possible values) (NAME_TYPE is used as type)
     *
     * @param array|int         $type   The type to test
     * @param array|string|null $values The token value
     *
     * @return bool
     */
    
public function test($type$values null)
    {
        if (
null === $values && !is_int($type)) {
            
$values $type;
            
$type self::NAME_TYPE;
        }

        return (
$this->type === $type) && (
            
null === $values ||
            (
is_array($values) && in_array($this->value$values)) ||
            
$this->value == $values
        
);
    }

    
/**
     * @return int
     */
    
public function getLine()
    {
        return 
$this->lineno;
    }

    
/**
     * @return int
     */
    
public function getType()
    {
        return 
$this->type;
    }

    
/**
     * @return string
     */
    
public function getValue()
    {
        return 
$this->value;
    }

    
/**
     * Returns the constant representation (internal) of a given type.
     *
     * @param int  $type  The type as an integer
     * @param bool $short Whether to return a short representation or not
     *
     * @return string The string representation
     */
    
public static function typeToString($type$short false)
    {
        switch (
$type) {
            case 
self::EOF_TYPE:
                
$name 'EOF_TYPE';
                break;
            case 
self::TEXT_TYPE:
                
$name 'TEXT_TYPE';
                break;
            case 
self::BLOCK_START_TYPE:
                
$name 'BLOCK_START_TYPE';
                break;
            case 
self::VAR_START_TYPE:
                
$name 'VAR_START_TYPE';
                break;
            case 
self::BLOCK_END_TYPE:
                
$name 'BLOCK_END_TYPE';
                break;
            case 
self::VAR_END_TYPE:
                
$name 'VAR_END_TYPE';
                break;
            case 
self::NAME_TYPE:
                
$name 'NAME_TYPE';
                break;
            case 
self::NUMBER_TYPE:
                
$name 'NUMBER_TYPE';
                break;
            case 
self::STRING_TYPE:
                
$name 'STRING_TYPE';
                break;
            case 
self::OPERATOR_TYPE:
                
$name 'OPERATOR_TYPE';
                break;
            case 
self::PUNCTUATION_TYPE:
                
$name 'PUNCTUATION_TYPE';
                break;
            case 
self::INTERPOLATION_START_TYPE:
                
$name 'INTERPOLATION_START_TYPE';
                break;
            case 
self::INTERPOLATION_END_TYPE:
                
$name 'INTERPOLATION_END_TYPE';
                break;
            default:
                throw new 
LogicException(sprintf('Token of type "%s" does not exist.'$type));
        }

        return 
$short $name 'Twig_Token::'.$name;
    }

    
/**
     * Returns the English representation of a given type.
     *
     * @param int $type The type as an integer
     *
     * @return string The string representation
     */
    
public static function typeToEnglish($type)
    {
        switch (
$type) {
            case 
self::EOF_TYPE:
                return 
'end of template';
            case 
self::TEXT_TYPE:
                return 
'text';
            case 
self::BLOCK_START_TYPE:
                return 
'begin of statement block';
            case 
self::VAR_START_TYPE:
                return 
'begin of print statement';
            case 
self::BLOCK_END_TYPE:
                return 
'end of statement block';
            case 
self::VAR_END_TYPE:
                return 
'end of print statement';
            case 
self::NAME_TYPE:
                return 
'name';
            case 
self::NUMBER_TYPE:
                return 
'number';
            case 
self::STRING_TYPE:
                return 
'string';
            case 
self::OPERATOR_TYPE:
                return 
'operator';
            case 
self::PUNCTUATION_TYPE:
                return 
'punctuation';
            case 
self::INTERPOLATION_START_TYPE:
                return 
'begin of string interpolation';
            case 
self::INTERPOLATION_END_TYPE:
                return 
'end of string interpolation';
            default:
                throw new 
LogicException(sprintf('Token of type "%s" does not exist.'$type));
        }
    }
}

class_alias('Twig_Token''Twig\Token'false);
x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586