C:\xampp\phpMyAdmin\vendor\symfony\expression-language\Lexer.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
<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Symfony\Component\ExpressionLanguage;

/**
 * Lexes an expression.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 */
class Lexer
{
    
/**
     * Tokenizes an expression.
     *
     * @param string $expression The expression to tokenize
     *
     * @return TokenStream A token stream instance
     *
     * @throws SyntaxError
     */
    
public function tokenize($expression)
    {
        
$expression str_replace(array("\r""\n""\t""\v""\f"), ' '$expression);
        
$cursor 0;
        
$tokens = array();
        
$brackets = array();
        
$end strlen($expression);

        while (
$cursor $end) {
            if (
' ' == $expression[$cursor]) {
                ++
$cursor;

                continue;
            }

            if (
preg_match('/[0-9]+(?:\.[0-9]+)?/A'$expression$match0$cursor)) {
                
// numbers
                
$number = (float) $match[0];  // floats
                
if (preg_match('/^[0-9]+$/'$match[0]) && $number <= PHP_INT_MAX) {
                    
$number = (int) $match[0]; // integers lower than the maximum
                
}
                
$tokens[] = new Token(Token::NUMBER_TYPE$number$cursor 1);
                
$cursor += strlen($match[0]);
            } elseif (
false !== strpos('([{'$expression[$cursor])) {
                
// opening bracket
                
$brackets[] = array($expression[$cursor], $cursor);

                
$tokens[] = new Token(Token::PUNCTUATION_TYPE$expression[$cursor], $cursor 1);
                ++
$cursor;
            } elseif (
false !== strpos(')]}'$expression[$cursor])) {
                
// closing bracket
                
if (empty($brackets)) {
                    throw new 
SyntaxError(sprintf('Unexpected "%s"'$expression[$cursor]), $cursor$expression);
                }

                list(
$expect$cur) = array_pop($brackets);
                if (
$expression[$cursor] != strtr($expect'([{'')]}')) {
                    throw new 
SyntaxError(sprintf('Unclosed "%s"'$expect), $cur$expression);
                }

                
$tokens[] = new Token(Token::PUNCTUATION_TYPE$expression[$cursor], $cursor 1);
                ++
$cursor;
            } elseif (
preg_match('/"([^"\\\\]*(?:\\\\.[^"\\\\]*)*)"|\'([^\'\\\\]*(?:\\\\.[^\'\\\\]*)*)\'/As'$expression$match0$cursor)) {
                
// strings
                
$tokens[] = new Token(Token::STRING_TYPEstripcslashes(substr($match[0], 1, -1)), $cursor 1);
                
$cursor += strlen($match[0]);
            } elseif (
preg_match('/not in(?=[\s(])|\!\=\=|not(?=[\s(])|and(?=[\s(])|\=\=\=|\>\=|or(?=[\s(])|\<\=|\*\*|\.\.|in(?=[\s(])|&&|\|\||matches|\=\=|\!\=|\*|~|%|\/|\>|\||\!|\^|&|\+|\<|\-/A'$expression$match0$cursor)) {
                
// operators
                
$tokens[] = new Token(Token::OPERATOR_TYPE$match[0], $cursor 1);
                
$cursor += strlen($match[0]);
            } elseif (
false !== strpos('.,?:'$expression[$cursor])) {
                
// punctuation
                
$tokens[] = new Token(Token::PUNCTUATION_TYPE$expression[$cursor], $cursor 1);
                ++
$cursor;
            } elseif (
preg_match('/[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*/A'$expression$match0$cursor)) {
                
// names
                
$tokens[] = new Token(Token::NAME_TYPE$match[0], $cursor 1);
                
$cursor += strlen($match[0]);
            } else {
                
// unlexable
                
throw new SyntaxError(sprintf('Unexpected character "%s"'$expression[$cursor]), $cursor$expression);
            }
        }

        
$tokens[] = new Token(Token::EOF_TYPEnull$cursor 1);

        if (!empty(
$brackets)) {
            list(
$expect$cur) = array_pop($brackets);
            throw new 
SyntaxError(sprintf('Unclosed "%s"'$expect), $cur$expression);
        }

        return new 
TokenStream($tokens$expression);
    }
}
x

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