. */ /** * IdentificationVariableDeclaration = RangeVariableDeclaration [IndexBy] {Join [IndexBy]} * * @package Doctrine * @subpackage Query * @author Guilherme Blanco * @author Janne Vanhala * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link http://www.phpdoctrine.org * @since 2.0 * @version $Revision$ */ class Doctrine_Query_Production_IdentificationVariableDeclaration extends Doctrine_Query_Production { protected $_rangeVariableDeclaration; protected $_indexBy; protected $_relations = array(); public function syntax($paramHolder) { $this->_rangeVariableDeclaration = $this->AST('RangeVariableDeclaration', $paramHolder); if ($this->_isNextToken(Doctrine_Query_Token::T_INDEX)) { $paramHolder->set('componentAlias', $this->_rangeVariableDeclaration); $this->_indexBy = $this->AST('IndexBy', $paramHolder); $paramHolder->remove('componentAlias'); } while ( $this->_isNextToken(Doctrine_Query_Token::T_LEFT) || $this->_isNextToken(Doctrine_Query_Token::T_INNER) || $this->_isNextToken(Doctrine_Query_Token::T_JOIN) ) { $i = count($this->_relations); $this->_relations[$i]['join'] = $this->AST('Join', $paramHolder); if ($this->_isNextToken(Doctrine_Query_Token::T_INDEX)) { $paramHolder->set('componentAlias', $this->_relations[$i]['join']->getRangeVariableDeclaration()); $this->_relations[$i]['indexBy'] = $this->AST('IndexBy', $paramHolder); $paramHolder->remove('componentAlias'); } } } public function buildSql() { // We need to bring the queryComponent and get things from there. $parserResult = $this->_parser->getParserResult(); $queryComponent = $parserResult->getQueryComponent($this->_rangeVariableDeclaration); // Retrieving connection $conn = $this->_parser->getSqlBuilder()->getConnection(); $manager = Doctrine_Manager::getInstance(); if ($manager->hasConnectionForComponent($queryComponent['metadata']->getClassName())) { $conn = $manager->getConnectionForComponent($queryComponent['metadata']->getClassName()); } $str = $conn->quoteIdentifier($queryComponent['metadata']->getTableName()) . ' ' . $conn->quoteIdentifier($parserResult->getTableAliasFromComponentAlias($this->_rangeVariableDeclaration)); for ($i = 0, $l = count($this->_relations); $i < $l; $i++) { $str .= $this->_relations[$i]['join']->buildSql() . ' ' . ((isset($this->_relations[$i]['indexby'])) ? $this->_relations[$i]['indexby']->buildSql() . ' ' : ''); } return $str; } /** * Visitor support * * @param object $visitor */ public function accept($visitor) { $this->_rangeVariableDeclaration->accept($visitor); if ($this->_indexBy) { $this->_indexBy->accept($visitor); } foreach ($this->_relations as $relation) { if ($relation['join']) { $relation['join']->accept($visitor); } if ($relation['indexby']) { $relation['indexby']->accept($visitor); } } $visitor->visitIdentificationVariable($this); } /* Getters */ public function getRangeVariableDeclaration() { return $this->_rangeVariableDeclaration; } public function getIndexBy() { return $this->_indexBy; } public function getRelations() { return $this->_relations; } }