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
|
<?php
declare(strict_types=1);
namespace Doctrine\ORM\Query\AST\Functions;
use Doctrine\ORM\Query\AST\Node;
use Doctrine\ORM\Query\AST\SimpleArithmeticExpression;
use Doctrine\ORM\Query\Lexer;
use Doctrine\ORM\Query\Parser;
use Doctrine\ORM\Query\SqlWalker;
/**
* "LOCATE" "(" StringPrimary "," StringPrimary ["," SimpleArithmeticExpression]")"
*
* @link www.doctrine-project.org
*/
class LocateFunction extends FunctionNode
{
/** @var Node */
public $firstStringPrimary;
/** @var Node */
public $secondStringPrimary;
/** @var SimpleArithmeticExpression|bool */
public $simpleArithmeticExpression = false;
/** @inheritdoc */
public function getSql(SqlWalker $sqlWalker)
{
$platform = $sqlWalker->getConnection()->getDatabasePlatform();
$firstString = $sqlWalker->walkStringPrimary($this->firstStringPrimary);
$secondString = $sqlWalker->walkStringPrimary($this->secondStringPrimary);
if ($this->simpleArithmeticExpression) {
return $platform->getLocateExpression(
$secondString,
$firstString,
$sqlWalker->walkSimpleArithmeticExpression($this->simpleArithmeticExpression)
);
}
return $platform->getLocateExpression($secondString, $firstString);
}
/** @inheritdoc */
public function parse(Parser $parser)
{
$parser->match(Lexer::T_IDENTIFIER);
$parser->match(Lexer::T_OPEN_PARENTHESIS);
$this->firstStringPrimary = $parser->StringPrimary();
$parser->match(Lexer::T_COMMA);
$this->secondStringPrimary = $parser->StringPrimary();
$lexer = $parser->getLexer();
if ($lexer->isNextToken(Lexer::T_COMMA)) {
$parser->match(Lexer::T_COMMA);
$this->simpleArithmeticExpression = $parser->SimpleArithmeticExpression();
}
$parser->match(Lexer::T_CLOSE_PARENTHESIS);
}
}
|