![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/vendor/beberlei/doctrineextensions/src/Query/Mysql/ |
<?php namespace DoctrineExtensions\Query\Mysql; use Doctrine\ORM\Query\AST\ArithmeticExpression; use Doctrine\ORM\Query\AST\Functions\FunctionNode; use Doctrine\ORM\Query\AST\OrderByClause; use Doctrine\ORM\Query\Lexer; use Doctrine\ORM\Query\Parser; use Doctrine\ORM\Query\SqlWalker; class Over extends FunctionNode { /** @var ArithmeticExpression */ private $arithmeticExpression; /** @var OrderByClause|null */ private $orderByClause; public function getSql(SqlWalker $sqlWalker): string { return isset($this->orderByClause) && count($this->orderByClause->orderByItems) > 0 ? $sqlWalker->walkArithmeticExpression($this->arithmeticExpression) . ' OVER (' . trim($sqlWalker->walkOrderByClause($this->orderByClause)) . ')' : $sqlWalker->walkArithmeticExpression($this->arithmeticExpression) . ' OVER ()'; } public function parse(Parser $parser): void { $lexer = $parser->getLexer(); $parser->match(Lexer::T_IDENTIFIER); $parser->match(Lexer::T_OPEN_PARENTHESIS); $this->arithmeticExpression = $parser->ArithmeticExpression(); if (!$lexer->isNextToken(Lexer::T_CLOSE_PARENTHESIS)) { $parser->match(Lexer::T_COMMA); $this->orderByClause = $parser->OrderByClause(); } $parser->match(Lexer::T_CLOSE_PARENTHESIS); } }