*/ class ToChar extends FunctionNode { private $datetime; private $fmt; private $nls = null; public function getSql(\Doctrine\ORM\Query\SqlWalker $sqlWalker) { if ($this->nls) { return sprintf( 'TO_CHAR(%s, %s, %s)', $sqlWalker->walkArithmeticPrimary($this->datetime), $sqlWalker->walkArithmeticPrimary($this->fmt), $sqlWalker->walkArithmeticPrimary($this->nls) ); } return sprintf( 'TO_CHAR(%s, %s)', $sqlWalker->walkArithmeticPrimary($this->datetime), $sqlWalker->walkArithmeticPrimary($this->fmt) ); } public function parse(\Doctrine\ORM\Query\Parser $parser) { $lexer = $parser->getLexer(); $parser->match(Lexer::T_IDENTIFIER); $parser->match(Lexer::T_OPEN_PARENTHESIS); $this->datetime = $parser->ArithmeticExpression(); $parser->match(Lexer::T_COMMA); $this->fmt = $parser->StringExpression(); if ($lexer->isNextToken(Lexer::T_COMMA)) { $parser->match(Lexer::T_COMMA); $this->nls = $parser->StringExpression(); } $parser->match(Lexer::T_CLOSE_PARENTHESIS); } }