. */ /** * IdentificationVariableDeclaration = RangeVariableDeclaration [IndexBy] {JoinVariableDeclaration} * * @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 $_joinVariableDeclarations = array(); public function syntax($paramHolder) { $this->_rangeVariableDeclaration = $this->AST('RangeVariableDeclaration', $paramHolder); if ($this->_isNextToken(Doctrine_Query_Token::T_INDEX)) { $paramHolder->set('componentAlias', $this->_rangeVariableDeclaration->getIdentificationVariable()); $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) ) { $this->_joinVariableDeclarations[] = $this->AST('JoinVariableDeclaration', $paramHolder); } } public function buildSql() { $str = $this->_rangeVariableDeclaration->buildSql(); for ($i = 0, $l = count($this->_joinVariableDeclarations); $i < $l; $i++) { $str .= ' ' . $this->_joinVariableDeclarations[$i]->buildSql(); } return $str; } /* Getters */ public function getRangeVariableDeclaration() { return $this->_rangeVariableDeclaration; } public function getIndexBy() { return $this->_indexBy; } public function getJoinVariableDeclarations() { return $this->_joinVariableDeclarations; } }