. */ /** * FromClause ::= "FROM" IdentificationVariableDeclaration {"," IdentificationVariableDeclaration} * * @package Doctrine * @subpackage Query * @author Guilherme Blanco * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link http://www.phpdoctrine.org * @since 2.0 * @version $Revision$ */ class Doctrine_Query_AST_FromClause extends Doctrine_Query_AST { protected $_identificationVariableDeclarations = array(); /* Setters */ public function addIdentificationVariableDeclaration($identificationVariableDeclaration) { $this->_identificationVariableDeclarations[] = $identificationVariableDeclaration; } public function setIdentificationVariableDeclarations($identificationVariableDeclarations, $append = false) { $this->_selectExpressions = ($append === true) ? array_merge($this->_identificationVariableDeclarations, $identificationVariableDeclarations) : $identificationVariableDeclarations; } /* Getters */ public function getIdentificationVariableDeclarations() { return $this->_identificationVariableDeclarations; } /* REMOVE ME LATER. COPIED METHODS FROM SPLIT OF PRODUCTION INTO "AST" AND "PARSER" */ public function buildSql() { //echo "FromClause:\n"; //for ($i = 0; $i < count($this->_identificationVariableDeclaration);$i++) { // echo (($this->_identificationVariableDeclaration[$i] instanceof IdentificationVariableDeclaration) // ? get_class($this->_identificationVariableDeclaration[$i]) // : get_class($this->_identificationVariableDeclaration[$i])) . "\n"; //} return 'FROM ' . implode(', ', $this->_mapIdentificationVariableDeclarations()); } protected function _mapIdentificationVariableDeclarations() { return array_map( array(&$this, '_mapIdentificationVariableDeclaration'), $this->_identificationVariableDeclarations ); } protected function _mapIdentificationVariableDeclaration($value) { return $value->buildSql(); } }