![]() 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/Postgresql/ |
<?php namespace DoctrineExtensions\Query\Postgresql; use Doctrine\ORM\Query\AST\Functions\FunctionNode; use Doctrine\ORM\Query\AST\PathExpression; use Doctrine\ORM\Query\Lexer; use Doctrine\ORM\Query\Parser; use Doctrine\ORM\Query\SqlWalker; /** * @author Roberto JĂșnior <[email protected]> * @author Vaskevich Eugeniy <[email protected]> */ class StringAgg extends FunctionNode { private $orderBy = null; private $expression = null; private $delimiter = null; private $isDistinct = false; public function parse(Parser $parser) { $parser->match(Lexer::T_IDENTIFIER); $parser->match(Lexer::T_OPEN_PARENTHESIS); $lexer = $parser->getLexer(); if ($lexer->isNextToken(Lexer::T_DISTINCT)) { $parser->match(Lexer::T_DISTINCT); $this->isDistinct = true; } $this->expression = $parser->PathExpression(PathExpression::TYPE_STATE_FIELD); $parser->match(Lexer::T_COMMA); $this->delimiter = $parser->StringPrimary(); if ($lexer->isNextToken(Lexer::T_ORDER)) { $this->orderBy = $parser->OrderByClause(); } $parser->match(Lexer::T_CLOSE_PARENTHESIS); } public function getSql(SqlWalker $sqlWalker) { return \sprintf( 'string_agg(%s%s, %s%s)', ($this->isDistinct ? 'DISTINCT ' : ''), $sqlWalker->walkPathExpression($this->expression), $sqlWalker->walkStringPrimary($this->delimiter), ($this->orderBy ? $sqlWalker->walkOrderByClause($this->orderBy) : '') ); } }