. */ /** * Doctrine_Hydrate_RecordDriver * Hydration strategy used for creating collections of entity objects. * * @package Doctrine * @subpackage Hydrate * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link www.phpdoctrine.com * @since 1.0 * @version $Revision$ * @author Konsta Vesterinen * @author Roman Borschel */ class Doctrine_Hydrator_RecordDriver extends Doctrine_Locator_Injectable { protected $_collections = array(); protected $_records = array(); protected $_mappers = array(); public function getElementCollection($component) { $coll = new Doctrine_Collection($component); $this->_collections[] = $coll; return $coll; } public function getLastKey($coll) { $coll->end(); return $coll->key(); } public function initRelated($record, $name) { return true; /* if ( ! is_array($record)) { $record[$name]; return true; } return false; */ } public function registerCollection(Doctrine_Collection $coll) { $this->_collections[] = $coll; } /** * isIdentifiable * returns whether or not a given data row is identifiable (it contains * all primary key fields specified in the second argument) * * @param array $row * @param Doctrine_Table $table * @return boolean */ public function isIdentifiable(array $row, Doctrine_Table $table) { $primaryKeys = $table->getIdentifierColumnNames(); if (is_array($primaryKeys)) { foreach ($primaryKeys as $id) { if ( ! isset($row[$id])) { return false; } } } else { if ( ! isset($row[$primaryKeys])) { return false; } } return true; } public function getNullPointer() { return self::$_null; } public function getElement(array $data, $component) { $component = $this->_getClassnameToReturn($data, $component); if ( ! isset($this->_mappers[$component])) { $this->_mappers[$component] = Doctrine_Manager::getInstance()->getMapper($component); } $record = $this->_mappers[$component]->getRecord($data); if ( ! isset($this->_records[$record->getOid()]) ) { $record->clearRelated(); $this->_records[$record->getOid()] = $record; } return $record; } public function flush() { // take snapshots from all initialized collections foreach ($this->_collections as $key => $coll) { $coll->takeSnapshot(); } } /** * Check the dataset for a discriminator column to determine the correct * class to instantiate. If no discriminator column is found, the given * classname will be returned. * * @return string The name of the class to instantiate. * @todo Can be optimized performance-wise. */ protected function _getClassnameToReturn(array $data, $className) { if ( ! isset($this->_mappers[$className])) { $this->_mappers[$className] = Doctrine_Manager::getInstance()->getMapper($className); } $discCol = $this->_mappers[$className]->getTable()->getInheritanceOption('discriminatorColumn'); if ( ! $discCol) { return $className; } $discMap = $this->_mappers[$className]->getTable()->getInheritanceOption('discriminatorMap'); foreach ($discMap as $value => $class) { if (isset($data[$discCol]) && $data[$discCol] == $value) { return $class; } } return $className; } }